sql一个关键字多个字段查询

有这样一个需求,就是用户输入一个关键字对表中的所有字段进行查询我的sql是:select*fromtablewherefield1+field2+field3+field... 有这样一个需求,就是用户输入一个关键字对表中的所有字段进行查询 我的sql是: select * from table where field1 +field2 +field3 +field4 +field5 like '%key%'

但是这样做有个问题,就是当某个字段为空(NULL)的时候,查询失败(没有结果),求解决方法,或更好的查询方法。
展开
 我来答
szm341
推荐于2017-12-15 · TA获得超过6726个赞
知道大有可为答主
回答量:5005
采纳率:100%
帮助的人:5177万
展开全部
可以通过全文索引来实现
当然你的方法也可以,每个字段用上去空函数如isnull(field1,'')+isnull(field2,'')
追问
弱弱的问一句,你所说的全文索引是什么?
追答
全文索引可以将数据库中全部字段作为查询列,用一个筛选条件查询
具体语法跟作用你可以搜搜,效率应该比你的方案要好
wangzhiqing999
2012-11-21 · TA获得超过1.6万个赞
知道大有可为答主
回答量:7048
采纳率:100%
帮助的人:3366万
展开全部
如果是 oracle 使用 nvl 函数
如果是 sql server 使用 isnull函数
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友2686294
2012-11-21 · 超过11用户采纳过TA的回答
知道答主
回答量:62
采纳率:0%
帮助的人:26.1万
展开全部
select * from table where nvl(field1,'') +nvl(field2,'') +nvl(field3,'') +nvl(field4,'') +nvl(field5,'') like '%key%'

nvl(field,'')是个函数,把控制置为‘’
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
好听名子
2012-11-21
知道答主
回答量:24
采纳率:0%
帮助的人:6.2万
展开全部
你为什么不这样select * from table where like '%key%'呢,加上field1 +field2 +field3 +field4 +field5你是想干嘛使啊?
追问
field1 +field2 +field3 +field4 +field5 是各个字段值相加再like的方法,
另外select * from table where like '%key%'这个语句能执行吗???
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
匿名用户
2012-11-21
展开全部
select * from table where field1 like '%key%' or field2 like '%key%' or field3 like '%key%' or field4 like '%key%' or field5 like '%key%'
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(3)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式