【发布时间】:2020-09-14 21:55:43
【问题描述】:
我在 MySQL 中有一个存储过程,如下所示:
CREATE PROCEDURE `sample_search`(
IN upperrange decimal(2,0),
IN lowerrange decimal(2,0),
IN name varchar(31),
IN age varchar(20)
)
BEGIN
Select
name,
age,
rank,
FROM sampledatabase
WHERE rank BETWEEN lowerrange AND upperrange
AND name LIKE name
AND age LIKE age;
END
当我这样调用程序时:
Call sample_search(20, 10, '%bob%', '%teen%');
返回对范围的搜索,但不会根据通配符进行搜索。
|name |age |rank |
|%bob% |%teen% |15 |
|%bob% |%teen% |16 |
它只是填写了我要搜索的内容。如果我将程序更改为:
CREATE PROCEDURE `sample_search`(
IN upperrange decimal(2,0),
IN lowerrange decimal(2,0),
IN name varchar(31),
IN age varchar(20)
)
BEGIN
Select
name,
age,
rank,
FROM sampledatabase
WHERE rank BETWEEN lowerrange AND upperrange
AND name LIKE CONCAT('%', name, '%')
AND age LIKE CONCAT('%', age, '%');
END
我得到相同的结果。任何想法我做错了什么?
【问题讨论】:
标签: mysql string stored-procedures where-clause sql-like