mysql 语句将逗号隔开的字符串作为条件,查询全部数据
时间: 2024-02-22 08:55:57 浏览: 73
你可以使用 MySQL 中的 LIKE 和 CONCAT 函数来实现。具体步骤如下:
1. 将逗号隔开的字符串转换成一个以逗号为分隔符的字符串,例如:
```
SET @str = '1,2,3';
SET @new_str = CONCAT(',', @str, ',');
```
2. 使用 LIKE 函数进行查询,例如:
```
SELECT * FROM your_table WHERE CONCAT(',', column_name, ',') LIKE CONCAT('%,', @search_str, ',%');
```
其中,column_name 是你想要查询的列名,@search_str 是我们上面转换得到的以逗号为分隔符的字符串。这条 SQL 语句会查询出所有 column_name 列中包含 1、2 或 3 的所有行。
相关问题
mysql 逗号隔开的字符串,作为条件查询多条数据
你可以使用 MySQL 中的 FIND_IN_SET 函数来实现。具体步骤如下:
1. 将逗号隔开的字符串转换成一个数组,例如:
```
SET @str = '1,2,3';
SET @arr = REPLACE(@str, ',', "','");
SET @arr = CONCAT("'", @arr, "'");
```
2. 使用 FIND_IN_SET 函数进行查询,例如:
```
SELECT * FROM your_table WHERE FIND_IN_SET(column_name, @arr);
```
其中,column_name 是你想要查询的列名,@arr 是我们上面转换得到的数组。这条 SQL 语句会查询出 column_name 列中值为 1、2 或 3 的所有行。
mysql把逗号隔开的字符串分割
如果你需要将一个逗号隔开的字符串分割成多个值并返回一个结果集,可以使用 MySQL 中的内置函数 `SUBSTRING_INDEX()` 和 `UNION ALL` 运算符。下面是一个示例查询:
```
SELECT SUBSTRING_INDEX(SUBSTRING_INDEX('apple,banana,orange', ',', n.digit+1), ',', -1) AS fruit
FROM
(SELECT 0 digit UNION ALL SELECT 1 UNION ALL SELECT 2 UNION ALL SELECT 3) n
WHERE
n.digit < LENGTH('apple,banana,orange') - LENGTH(REPLACE('apple,banana,orange', ',', '')) + 1
```
这将返回一个包含拆分后每个值的行集合。在这个示例中,我们将字符串 'apple,banana,orange' 分割成三个部分:'apple'、'banana' 和 'orange'。你可以将这个查询作为一个子查询,将其结果与其他表进行联接,或者按照需要进行进一步处理。
如果你想将分割后的值以多行的形式返回,可以使用 `UNION ALL` 运算符连接多个 `SELECT` 语句,每个 `SELECT` 语句返回一个值。下面是一个示例查询:
```
SELECT SUBSTRING_INDEX(SUBSTRING_INDEX('apple,banana,orange', ',', n.digit+1), ',', -1) AS fruit
FROM
(SELECT 0 digit UNION ALL SELECT 1 UNION ALL SELECT 2 UNION ALL SELECT 3) n
WHERE
n.digit < LENGTH('apple,banana,orange') - LENGTH(REPLACE('apple,banana,orange', ',', '')) + 1
UNION ALL
SELECT SUBSTRING_INDEX(SUBSTRING_INDEX('grape,pear,melon', ',', n.digit+1), ',', -1) AS fruit
FROM
(SELECT 0 digit UNION ALL SELECT 1 UNION ALL SELECT 2 UNION ALL SELECT 3) n
WHERE
n.digit < LENGTH('grape,pear,melon') - LENGTH(REPLACE('grape,pear,melon', ',', '')) + 1
```
在这个示例中,我们使用两个 `SELECT` 语句分别处理两个逗号隔开的字符串,然后使用 `UNION ALL` 运算符将它们的结果集合并成一个结果集。
阅读全文