字符串变量作mysql查询条件


原文:http://blog.csdn.net/qing_gee/article/details/41646503

 

当你的查询条件是一个字符串变量时,你该怎么办,比如字符串可能是“0001ME,0002BL”,也可能是“0001ME”,那么如何根据条件得到想要的结果呢,我来告诉你instr方法的厉害之处。

 

1.开始的时候一直在将字符串str转换为in函数的参数,如下

SELECT * FROM stocks_orderlist s where s.scode in ("0001ME","0002BL") LIMIT 10;

SELECT CONVERT(CONCAT("\'",REPLACE("0001ME,0002BL","\,","\'\,\'"),"\'"),CHAR);

SELECT * FROM stocks_orderlist s where s.scode in (CONVERT(CONCAT("\"",REPLACE("0001ME,0002BL","\,","\"\,\""),"\""),CHAR)) LIMIT 10;

虽然把str转成了in所要的东西,但是后来想想,in的参数是一个列表集合,我及时把str转换成了所谓的in参数的形式,但是肯定还是一个字符串,于是又忙碌了半天,有点想放弃的感觉,但是回头想想,肯定是自己没有找到合适的办法,于是就找到了instr函数

 

2.instr函数,看帮助文档的意思是找出substr在str中第一次出现问题,尝试如下

SELECT INSTR("0001ME,0002BL","0003ME");
SELECT INSTR("0001ME,0002BL","0001ME");
SELECT INSTR("0001ME,0002BL","0002BL");
SELECT * FROM stocks_orderlist s where INSTR("0001ME,0002BL",s.scode);


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM