完美解决mysqlin条件语句只读取一条信息问题的2种方案
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了完美解决mysqlin条件语句只读取一条信息问题的2种方案,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2136字,纯文字阅读大概需要4分钟。
内容图文
![完美解决mysqlin条件语句只读取一条信息问题的2种方案](/upload/InfoBanner/zyjiaocheng/583/0e48dbdf14f042eabf3d3b1c714ef1e5.jpg)
今天同事在编写MYSQL查询语句时遇到一个很奇怪的问题,使用mysql多表查询,一个表中的某个字段作为另一表的in查询条件,只能读取一条信息,而直接用数字的话可以正常读取
SQL语句如下:
select a.id,a.title,b.idlist,b.aid from table a,table2 b where a.id in(b.idlist) and b.aid=2
table2表中的idlist字段是varchar类型,保存table表中的多个id信息即
1,2,3,4
用上面的语句可以正常查询但只能查询到一条信息但是用下面的语句的话却可以正常读取
select a.id,a.title,b.idlist,b.aid from table a,table2 b where a.id in(1,2,3,4) and b.aid=2
很奇怪的问题,开始以为是数据类型的问题,但要保存成1,2,3,4
这种格式的数据只能用字符类型,想了很多办法都没有解决问题,直到查到MYSQL中的FIND_IN_SET()函数,下面是关于FIND_IN_SET()函数的基本介绍说明
语法:FIND_IN_SET(str,strlist)
定义:
1. 假如字符串str在由N子链组成的字符串列表strlist中,则返回值的范围在1到N之间。
2. 一个字符串列表就是一个由一些被‘,'符号分开的自链组成的字符串。
3. 如果第一个参数是一个常数字符串,而第二个是typeSET列,则FIND_IN_SET()函数被优化,使用比特计算。
4. 如果str不在strlist或strlist为空字符串,则返回值为0。
5. 如任意一个参数为NULL,则返回值为NULL。这个函数在第一个参数包含一个逗号(‘,')时将无法正常运行。
strlist:一个由英文逗号“,”链接的字符串,例如:"a,b,c,d",该字符串形式上类似于SET类型的值被逗号给链接起来。
示例:SELECT FIND_IN_SET('b','a,b,c,d'); //返回值为2,即第2个值
好了,先试试能不能用,把原SQL语句修改成
select a.id,a.title,b.idlist,b.aid from table a,table2 b where FIND_IN_SET(a.id,b.idlist) and b.aid=2
执行一下修改后的语句,终于可以正常读取了,分析一下原因,最终还是因为数据类型的问题,我们直接in(b.idlist)时,读取的b.idlist是字符类型,而in只接受数字,虽说都带有“,”号但实际上是完全不同的.
好了问题解决了,如果还想知道更多关于FIND_IN_SET()函数的使用方法,可以看一下页面的相关文章
您可能感兴趣的文章:
- 分析Mysql表读写、索引等操作的sql语句效率优化问题
- MySQL根据某一个或者多个字段查找重复数据的sql语句
- PHP获取MySQL执行sql语句的查询时间方法
- Mysql查询最近一条记录的sql语句(优化篇)
- Mysql 根据一个表数据更新另一个表的某些字段(sql语句)
- MySQL 截取字符串函数的sql语句
- 使用SQL语句查询MySQL,SQLServer,Oracle所有数据库名和表名,字段名
- 提升MYSQL查询效率的10个SQL语句优化技巧
- 一条sql语句完成MySQL去重留一
- MySQL语句整理及汇总介绍
内容总结
以上是互联网集市为您收集整理的完美解决mysqlin条件语句只读取一条信息问题的2种方案全部内容,希望文章能够帮你解决完美解决mysqlin条件语句只读取一条信息问题的2种方案所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。