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

时间:2014-09-23 17:51:02

标签: php mysql stored-procedures sql-like

我使用存储过程通过使用以下代码片段来检查表中是否存在名称。

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意味着我不会插入,否则我会将名字插入我的表..

我的样本名称是......

  • 转动表(实时声学)
  • 隐藏我的心
  • 有人喜欢你(Live Acoustic)
  • 现在(Na Na Na)
  • 让你更长久
  • 有人喜欢你

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

我该怎么办?

1 个答案:

答案 0 :(得分:0)

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子句

中的其余条件

检查你如何传递值

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