有这么一个需求,满足只有一个输入框的条件下,支持不同数据列的搜索结果。

说白了,就是这个 输入框  既可以用来 搜索姓名,也可以搜索 年龄,地址等。

分析:

一般情况下,我们的一个输入框对应 数据库 的某一列信息的搜索,比如,要搜索姓名为 ‘李’ 姓开头的,那么对应的 sql 就是

where name like '李%'

但是,现在输入框有了不确定性,不知道用户到底会输入什么,导致我们后台的 sql 不知道该如何对应了,

比如,用户输入 18,很明显,用户是想搜索 年龄为 18 的用户,如果 后台sql 还是 where name like '18%',那么就会 搜索不到内容了。

方案一:

我们可以用 or 这种关键字来实现 多字段匹配,

比如:where name like '%搜索内容%' or age like '%搜索内容%'

这种方案对于 搜索字段比较 少的可以尝试,但是效率不高。

方案二:推荐

我们可以换一种思路

假设我们的数据库每一行都有一个完整的列 (colum),这个列的内容为 该行所有字段的内容。

那么我们搜索的sql 的可以改写为 where colum like '%搜索内容%'

这样 不论搜索 姓名 ,还是 年龄,地址 等,我们都可以查到。

既然到这里了,我相信你已经明白该怎么做了。

其实,就是用 sql 把需要可能 被用户搜索的 数据库字段拼接 起来,然后再  like '%搜索内容%'  就可以了。

oracle 做法

可以采用 instr() 函数,这里说下 INSTR()函数的作用

INSTR(参数1,参数2)其实是一个查找字符串的函数,返回的是字符串查找的位置,它有两个参数都是字符类型,如果找到则返回参数2在参数1中的位置,如果没有找到则返回 0。

SELECT INSTR('abcde', 'a') FROM DUAL;

--------------------------------------------

1

--------------------------------------------

结果分析,因为a在abcde的第一个位置,所以返回1

SELECT INSTR('abcde', 'f') FROM DUAL;

--------------------------------------------

0

--------------------------------------------

结果分析,因为f在abcde串中找不到,所以返回0

这里 对比 like 与 instr() 函数, 如果对性能 要求比较严格的 童鞋,记得来这里 用 instr () 来 替换 like 关键字

colum like '%搜索内容%'
等价于
instr(colum, '搜索内容', 1, 1)>0

colum like '搜索内容%'
等价于
instr(colum, '搜索内容', 1, 1)=1

colum  like '%搜索内容'
等价于
instr(colum, '搜索内容', 1, -1)=length(colum)-length('搜索内容')+1

sql:

oracle    ||   代表拼接多个 数据库列

一般情况:where instr(姓名||年龄||地址,'搜索内容',1,1) > 0

如果两个数据列相邻,采用 ',' 分割,防止搜索到不匹配内容:

where instr(姓名|| ',' || 年龄|| ',' || 地址 ,'搜索内容',1,1) > 0

如果字段为空,可以用 nvl (字段名,''),来处理,他的意思是 用 ‘’代替 空的内容

mysql

concat 拼接多个数据库 列

instr 查询

where instr (concat(姓名,年龄,地址),'搜索内容') > 0

Oracle 实现 一个关键字 匹配多个 字段的更多相关文章

  1. mysql 实行模糊查询 一个输入值匹配多个字段和多个输入值匹配一个字段

    mysql 实行模糊查询  一个输入值匹配多个字段 MySQL单表多字段模糊查询可以通过下面这个SQL查询实现 为啥一定要150字以上  真的麻烦  还不让贴代码了 SELECT * FROM `ma ...

  2. Lucene实战之关键字匹配多个字段

    前言 当我们输入关键字时希望可以支持筛选多个字段,这样搜索内容的覆盖率就会大一些. 匹配多个字段主要用 MultiFieldQueryParser类. 单一字段搜索 QueryParser parse ...

  3. mongodb一个关键字对多个字段同时查询,mongodb $or $and查询

    $query = '{ "$and": [                 {"$or": [{"reported": {"$ex ...

  4. oracle 实现多字段匹配一个关键字查询语句

    oracle 实现多字段匹配一个关键字查询语句:有两种方法(经测试,10g中不能用,11g才行): 第一种. select * from table where ('字段名1' ||'字段名2' || ...

  5. oracle中一个字符串包含另一个字符串中的所有字符

    oracle中一个字符串包含另一个字符串中的所有字符 --解决监理报告中所勾选的标段信息,与该用户所管理的标段字符串不匹配的问题. select * from a where instr(a,b)&g ...

  6. Oracle 指数 一个简短的引论

    1 索引创建语法: CREATE UNIUQE | BITMAP INDEX <schema>.<index_name>       ON <schema>.< ...

  7. Oracle Start With关键字

    Oracle Start With关键字 前言 旨在记录一些Oracle使用中遇到的各种各样的问题. 同时希望能帮到和我遇到同样问题的人. Start With (树查询) 问题描述: 在数据库中, ...

  8. ORACLE中一个字符占多少字节?

    问题描述 或许你会说一个中文字符占2个字节,这是一定的?如何计算一个字符串的字节数? 解决方案 在oracle中一个字符特别是中文占几个字节是不同的. 比如我创立一个表create table tes ...

  9. oracle 12c 新特性之不可见字段

    在Oracle 11g R1中,Oracle以不可见索引和虚拟字段的形式引入了一些不错的增强特性.继承前者并发扬光大,Oracle 12c 中引入了不可见字段思想.在之前的版本中,为了隐藏重要的数据字 ...

随机推荐

  1. javascript(函数式编程思考) ---> Map-Filter-quicksort-Collatz序列-Flodl-Flodr

    let add = x=>x+1; //Map :: ( a -> b) -> [a] -> [b] let Map = function(f,arr){ //闭包存储累积对象 ...

  2. 两种常见JS面向象写法

    基于构造函数 function Circle(r) { this.r = r; } Circle.PI = 3.14159; Circle.prototype.area = function() { ...

  3. [图文][提供可行性脚本] CentOS 7 Fencing+Pacemaker三节点搭建高可用集群

    实验说明: 实验环境: 宿主机系统   :Fedora 28 WorkStation 虚拟机管理器 :Virt-Manager 1.5.1 虚拟机配置   :ha1  CentOS 7.2 1511 ...

  4. jenkins学习笔记(一)

    windows下安装jenkins步骤 1.下载 官网路径:https://jenkins.io/ 2.安装 直接双击安装程序即可 centos7下安装命令: wget -O /etc/yum.rep ...

  5. 蓝牙学习(5) -- sockets

    Frames 由下图可以看出 - SDU由多个I-frames中的Information Payload组成 - 一个I-frames又拆分成多个HCI data payload socket buf ...

  6. HUAWEI交换机配置telnet登录

    Huawei交换机配置Telnet登录 一,交换机开启Telnet服务 <Huawei>system-view                                        ...

  7. PyQt5(2)、垃圾分类小程序(2)——初代窗口程序可执行文件

    又是一天时间(又没做大作业).今天的心路历程:(1)前端后端怎么连接?(2)后端数据库插数据(3)完全没用上之前的字典反查法(4)突然发现面向对象编程其实很好用,甚至越用越上瘾(5)QLineEdit ...

  8. Python9-迭代器-生成器-day13

    迭代器# print('__iter__' in dir(int))# print('__iter__' in dir(list))# print('__iter__' in dir(dict))# ...

  9. pymongo使用方法

    MongoDB存储     在这里我们来看一下Python3下MongoDB的存储操作,在本节开始之前请确保你已经安装好了MongoDB并启动了其服务,另外安装好了Python     的PyMong ...

  10. Django中的app及mysql数据库篇(ORM操作)

    Django常见命令 在Django的使用过程中需要使用命令让Django进行一些操作,例如创建Django项目.启动Django程序.创建新的APP.数据库迁移等. 创建Django项目 一把我们都 ...