再分析下我们的思路并没有问题,那么怎么才能用这个字符串作为查询条件,并最终得出我们想要的结果呢?根据网上的资料得知,查询条件in的内容只能是数字型的,所以他并不支持字符串的查询,所以这里我们还需要一个函数,instr.说实话这也是我第一次知道这个函数,毕竟对mysql真的只是会一点增删改查的皮毛,哈哈.那么接下来我们来试试这个函数的效果,最终的sql为
SELECT GROUP_CONCAT(`name`) FROM address WHERE INSTR( (SELECT CONCAT_WS(',', province, city, district) FROM `user` WHERE id = 1), id ) ;
执行后的结果也是我们想要的.当然上边的语句只是实现了查找到地址的结果,具体的可以根据业务需求继续修改,mysql的函数不得不说确实很强大.今后还是要多学习才是;
另:instr函数的使用有很大的局限性,详情可参考:http://1000zx.cn/article/243316.htm
所以,最终的sql为:
SELECT GROUP_CONCAT(`name`) FROM address WHERE INSTR( CONCAT( ',', (SELECT CONCAT_WS(',', province, city, district) FROM `user` WHERE id = 1), ',' ), CONCAT(',', id, ',') ) ;
到此这篇关于mysql查询结果实现多列拼接查询的文章就介绍到这了,更多相关mysql 多列拼接查询内容请搜索
更多相关Mysql内容来自木庄网络博客
标签:Mysql
相关阅读 >>
更多相关阅读请进入《mysql》频道 >>
数据库系统概念 第6版
本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。