首页  >  文章  >  后端开发  >  sql查询的相关有关问题

sql查询的相关有关问题

WBOY
WBOY原创
2016-06-13 10:20:28900浏览

sql查询的相关问题
表结构
 id name nasid
  1 nas1 1,2,3
  2 nas2 2,3,4
  3 nas3 2,3,5


我现在有个两个nasid:1,2
我想查询上面三条数据中nasid包含1,2(至少包含一个数字)的所有数据

这个sql该怎么写呢,请各位高手给点思路,尝试过like,但是效率太低

------解决方案--------------------
select * from 表 where find_in_set('1',nasid) or find_in_set('2',nasid)
------解决方案--------------------
全表扫描,效率高不了的
------解决方案--------------------
用正则找吧。。


SELECT * FROM `2012` WHERE `2012` REGEXP '(1|2)+'

刚测了一下,你可到我系统test数据库中执行一下看看
------解决方案--------------------
正则简单一点的还行,稍复杂的一点的就相当不给力了。有现在的函数当然得用现成的函数.
to amani11:既然说到全表扫描的问题,你是怎么做的呢?

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn