FIND_IN_SET 这个MYSQL查询能用吗?
时间:2011-09-01
来源:互联网
FIND_IN_SET 我感觉凡是用了这个查询的都非常慢呀。
比如我有一个程序是要做这个功能,查询某个代理商下,所有顾客的交易额。
那第一步要先查出所有顾客的用户名,然后用逗号连接起来,类似这样: $aaa= "user1,user2,user3";
然后这样查:
select * from orders where pay='ok' and FIND_IN_SET( username, '$aaa')
这样查询程序运行超级慢,只7万条记录,不应该这样,但要实现这样的功能,又一定要这样查询,真是郁闷了。
select * from orders where pay='ok' and ( username='user1' or username='user2' or username='user3' )
这样也可以查,估计效率也好不到哪里去,看来MYSQL要统计代理商下会员的一些信息,真的是不行了。
而且如果一个代理商下几百个用户名,那更要把服务器搞挂了。
比如我有一个程序是要做这个功能,查询某个代理商下,所有顾客的交易额。
那第一步要先查出所有顾客的用户名,然后用逗号连接起来,类似这样: $aaa= "user1,user2,user3";
然后这样查:
select * from orders where pay='ok' and FIND_IN_SET( username, '$aaa')
这样查询程序运行超级慢,只7万条记录,不应该这样,但要实现这样的功能,又一定要这样查询,真是郁闷了。
select * from orders where pay='ok' and ( username='user1' or username='user2' or username='user3' )
这样也可以查,估计效率也好不到哪里去,看来MYSQL要统计代理商下会员的一些信息,真的是不行了。
而且如果一个代理商下几百个用户名,那更要把服务器搞挂了。
作者: yanglei1979 发布时间: 2011-09-01
你要这么查,什么服务器都受不了。
作者: Coseylee 发布时间: 2011-09-01
明明是自己的数据库设计不对,却怪数据库不给力。。。
作者: imint0 发布时间: 2011-09-01
相关阅读 更多
热门阅读
-
office 2019专业增强版最新2021版激活秘钥/序列号/激活码推荐 附激活工具
阅读:74
-
如何安装mysql8.0
阅读:31
-
Word快速设置标题样式步骤详解
阅读:28
-
20+道必知必会的Vue面试题(附答案解析)
阅读:37
-
HTML如何制作表单
阅读:22
-
百词斩可以改天数吗?当然可以,4个步骤轻松修改天数!
阅读:31
-
ET文件格式和XLS格式文件之间如何转化?
阅读:24
-
react和vue的区别及优缺点是什么
阅读:121
-
支付宝人脸识别如何关闭?
阅读:21
-
腾讯微云怎么修改照片或视频备份路径?
阅读:28