作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我需要将一个字符串数组作为参数传递给 MySQL 存储例程。数组可能很长,并且其元素数量不固定。然后,我想将字符串值放入具有一列的内存表中,以便我可以处理数据。我不知道这是否可以在 MySQL 中完成。也许需要肮脏的解决方法。
例如,我有字符串值:
Banana, Apple, Orange
现在我想从我的 MySQL Fruits
表中获取这些水果的数据。伪代码:
create function GetFruits(Array fruitArray)
declare @temp table as
fruitName varchar(100)
end
@temp = convert fruitArray to table
select * from Fruits where Name in (select fruitName from @temp)
end
Microsoft SQL Server 允许您使用TEXT
数据类型并将数组作为 XML 字符串提交,从而快速创建内存表。然而,我认为这种技术在 MySQL 中是不可能的。
任何有关如何执行此操作的帮助将不胜感激!
最佳答案
您可以在列表中传递一个字符串并使用 prepared statements运行查询,例如-
DELIMITER $$
CREATE PROCEDURE GetFruits(IN fruitArray VARCHAR(255))
BEGIN
SET @sql = CONCAT('SELECT * FROM Fruits WHERE Name IN (', fruitArray, ')');
PREPARE stmt FROM @sql;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;
END
$$
DELIMITER ;
使用方法:
SET @fruitArray = '\'apple\',\'banana\'';
CALL GetFruits(@fruitArray);
关于mysql - 将数组传递给 MySQL 存储例程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49317496/
我最近购买了《C 编程语言》并尝试了 Ex 1-8这是代码 #include #include #include /* * */ int main() { int nl,nt,nb;
早上好!我有一个变量“var”,可能为 0。我检查该变量是否为空,如果不是,我将该变量保存在 php session 中,然后调用另一个页面。在这个新页面中,我检查我创建的 session 是否为空,
我正在努力完成 Learn Python the Hard Way ex.25,但我无法理解某些事情。这是脚本: def break_words(stuff): """this functio
我是一名优秀的程序员,十分优秀!