gpt4 book ai didi

php - LIKE % XX(YY)GG % 在 MySQL 中不起作用

转载 作者:行者123 更新时间:2023-11-29 23:44:43 25 4
gpt4 key购买 nike

我使用存储过程来检查表中是否存在名称,方法是使用以下代码片段..

BEGIN
IF ids = 0 THEN
SELECT * FROM table_name WHERE `table_id` = alb_id AND name LIKE CONCAT('%',var_name,'%');
END IF;
END

如果名称不包含任何特殊字符或括号(例如 XXXX),我得到了解决方案。

如果名称中包含任何括号,则表示未得出结果,例如 XX(YY)GG。

建议我最好的解决方案

编辑:

如果名称已经存在,我不应该再次插入它,对于这种情况,我使用了这个过程。如果它返回 mysql_num_rows > 0 意味着我不会插入,否则我会将名称插入到我的表中..

我的样本名称是,..

  • 转盘(现场原声)
  • 隐藏我的心
  • 像你这样的人(现场原声)
  • 现在(娜娜娜)
  • 让你更长久
  • 像你这样的人

在名称列表中“Someone Like You”和“Someone Like You (Live Acoustic)”是两个不同的名称,我想识别名称“Someone Like You (Live Acoustic)”是否已经存在..

我该怎么办?

最佳答案

CREATE TABLE `stack_test` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`text` varchar(100) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB CHARSET=utf8;


INSERT INTO `blur_new`.`stack_test` (`id`, `text`) VALUES ('1', 'run (rabbit) run');
INSERT INTO `blur_new`.`stack_test` (`id`, `text`) VALUES ('2', 'test');

set @a = 'n (rabbit)';
select * from stack_test where text like concat('%',@a,'%');

结果:1 |跑(兔子)跑

所以,它有效。

检查where子句中的其余条件

检查你如何传递值

您可能需要检查数据类型。我感觉有些不对劲

关于php - LIKE % XX(YY)GG % 在 MySQL 中不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26001565/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com