sql查询的相关有关问题

WBOY
发布: 2016-06-13 13:33:14
原创
756 人浏览过

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:既然说到全表扫描的问题,你是怎么做的呢?

相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!