13

我想在 MySQL 中创建一个以列表为参数的存储过程。例如,假设我希望能够在一次调用中为一个项目设置多个标签,那么我想要做的是定义一个过程,该过程采用项目的 ID 和要设置的标签列表。但是,我似乎找不到任何方法来做到这一点,据我所知,没有列表数据类型,但是可以以某种方式模拟它吗?标签列表可以是逗号分隔的字符串,可以以某种方式拆分和循环吗?

您通常如何处理 MySQL 存储过程中的列表?

4

4 回答 4

9

本文对将数组解析为存储过程的问题进行了一些很好的讨论,因为存储过程只允许有效的表列数据类型作为参数。

您可以使用 mysql 中的csv表类型做一些巧妙的事情- 如果您将平面文件加载到数据库中。

您可以在存储过程中创建一个临时表,遍历 csv 列表并将其插入临时表,然后创建一个从该表中选择值的游标。上述线程中的这个答案显示了一种方法。

通常我会在进入数据库之前拆分数组,然后对每个项目单独执行查询。

于 2008-08-12T14:02:46.697 回答
1

根据您想要获得的复杂程度,您可以使用通用链接表。对于我的一个应用程序,用户可能会选择多个报告,例如要运行报告的客户列表,而不仅仅是组合框中的单个客户。我有一个包含 2 个字段的单独表格:

  • 唯一 ID(指导)
  • 物品编号

伪代码如下所示:

GUID guid = GenerateGUID()
try
  for each customer in customerList { INSERT(guid, customerId) }
  ExecuteSQLPocedure(guid)
  --the procedure can inner-join to the list table to get the list
finally
  DELETE WHERE UniqueID=guid      
于 2008-08-12T13:48:24.917 回答
0

不确定这些是否会专门在 SP 中工作,但 MySQL 5 中有 ENUM 和 SET 数据类型可以满足您的需求。 http://dev.mysql.com/doc/refman/5.0/en/enum.html http://dev.mysql.com/doc/refman/5.0/en/set.html

于 2008-08-12T13:33:06.837 回答
0

在我的 Choice 编程语言 C# 中,我实际上是在应用程序本身中执行此操作,因为 split() 函数和循环在 C# 中比在 SQL 中更容易编程,但是!

也许你应该看看SubString_Index()函数。

例如,以下将返回 google:

SELECT SUBSTRING_INDEX(SUBSTRING_INDEX('www.google.com', '.', -2), '.', 1);
于 2008-08-12T13:36:40.307 回答