字符串变量作mysql查询条件

当你的查询条件是一个字符串变量时,你该怎么办,比如字符串可能是“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);



  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
MySQL中,有两种常用的方法可以进行字符串拼接。首先是使用`CONCAT`函数,它可以将多个字符串连接在一起。例如,`CONCAT('string1', 'string2', 'string3')`会返回一个由这三个字符串拼接而成的结果。这种方式是无缝拼接的。 其次是使用`CONCAT_WS`函数,它在拼接字符串时可以指定一个分隔符。例如,`CONCAT_WS('/', 'string1', 'string2', 'string3')`会返回一个由这三个字符串以斜杠为分隔符拼接而成的结果。这种方式是带缝拼接的。 如果你想在MySQL存储过程中进行字符串拼接,可以借助这两个函数来实现。下面是一个示例存储过程,演示了如何使用循环和查询来进行字符串拼接,并将结果更新到表中的某一行记录中。 首先,我们定义了一些变量,包括要拼接的字符串查询结果的局部变量等等。然后,我们使用`DECLARE`语句定义了一个游标`report`,并通过`SELECT`语句从表中查询数据。接着,我们使用`DECLARE CONTINUE HANDLER`语句设置了循环结束条件。然后,我们打开游标,并使用`FETCH`语句将查询结果赋值给相应的变量。接下来,我们使用`WHILE`循环进行拼接操,将查询结果逐个拼接到字符串中。最后,我们关闭游标,并使用`UPDATE`语句将拼接好的字符串更新到表中的指定行记录中。 通过这个示例,你可以根据自己的具体需求修改存储过程来完成字符串拼接的操。希望对你有所帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

沉默王二

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值