我有一个令人讨厌的、令人讨厌的数据布局,我被迫使用它。我终于使用 C# 和 for 循环得到了一个有效的查询,一遍又一遍地执行相同的查询,但调整了调用哪些字段,但现在我想知道是否可以使用 while 循环来完成它。我收到错误,我不确定是否是因为我使用 Faircom/C-tree 作为数据库,或者我的查询是否有问题。我通常是Mysql用户。
该表有 20 个我关心并想要提取到 csv 列表中的字段。它们是 codetype1-codetype20,我希望它类似于 value1、value2、value3...
,现在我一次将它们全部取回。问题是 codetype1 依赖于另一个字段来确定我去哪里查找该代码的信息,这就是 case 语句的原因。
DROP PROCEDURE IF EXISTS proc_loop_test;
CREATE PROCEDURE proc_loop_test()
SET @index = 1;
WHILE(@index < 21) DO
SELECT Replace(Concat(To_char(apptid), To_char(.@index) ), ' ', '') AS reference_id,
apptid AS a_reference_id,
CASE
WHEN c.ee > 0 THEN d.amt
ELSE insfee.amt
END AS amount,
CASE
WHEN c.ee > 0 THEN Rtrim(e.moneyname)
ELSE insname.namefeecatid
END AS moneyschedule_name,
CASE codetype@index
WHEN 1 THEN rtrim(a.descript)
ELSE rtrim(b.descript0)
END AS description,
CASE codetype@index
WHEN 1 THEN rtrim(a.abbrevdescript)
ELSE rtrim(b.abbrev0)
END AS abbreviated_description,
CASE codetype@index
WHEN 1 THEN rtrim(a.thiscode)
ELSE rtrim(b.thiscode0)
END AS code
FROM meetings
LEFT JOIN
(
SELECT admin.table2.procid,
admin.table2.this_code_id,
admin.v_table1.descript,
admin.v_table1.abbrevdescript,
admin.v_table1.thiscode
FROM admin.table2
INNER JOIN admin.v_table1
ON admin.table2.this_code_id = admin.v_table1.this_code_id) AS a
ON meetings.codeid@index = a.procid
LEFT JOIN
(
SELECT admin.v_table1.descript AS descript0,
admin.v_table1.abbrevdescript AS abbrev0,
admin.v_table1.thiscode AS thiscode0,
admin.v_table1.this_code_id
FROM admin.v_table1) AS b
ON meetings.codeid@index = b.this_code_id
LEFT JOIN
(
SELECT patid AS id,
ee
FROM admin.customer) AS c
ON meetings.patid = c.id
LEFT JOIN
(
SELECT this_code_id AS redid,
eecategoryid,
amt
FROM admin.eeule) AS d
ON c.ee = d.eecategoryid
AND d.redid = b.this_code_id
LEFT JOIN
(
SELECT eecategoryid AS namefeecatid,
moneyname
FROM admin.eeulenames) AS e
ON d.eecategoryid = e.namefeecatid
LEFT JOIN (SELECT pi.customer_id,
pi.primarykk_id AS picid,
pi.primarykk_name,
pi.first_name,
pi.last_name,
i.groupname,
i.ee
FROM admin.v_pir AS pi
LEFT JOIN admin.money AS i
ON pi.primarykk_id = i.insid) AS
ins
ON ins.customer_id = c.id
LEFT JOIN (SELECT this_code_id AS redid,
eecategoryid,
amt
FROM admin.eeule) AS insfee
ON ins.ee = insfee.eecategoryid
AND insfee.redid = b.this_code_id
LEFT JOIN (SELECT eecategoryid AS namefeecatid,
moneyname
FROM admin.eeulenames) AS insname
ON insfee.eecategoryid = insname.namefeecatid
WHERE codeid@index >= 1
END WHILE;
END;
我从未使用过 while 循环,虽然我有所了解,但我应该选择它来进入某些内容,我是否需要创建一个临时表,或者可以将其全部存储在内存中直到结束循环并返回。
无论如何,当您将 @index
替换为连接格式 ".index . "
最佳答案
根据您提供的信息,强烈建议您联系供应商解决此问题。然而,您正尝试使用 mySQL 专有语法创建存储过程。每个数据库供应商的存储过程支持都是独一无二的。 FairCom 的 c-treeACE SQL 实际上使用 Java 来实现跨平台支持,并使用 .NET for Windows。
https://docs.faircom.com/doc/jspt/#cover.htm
存储过程开发需要对高度依赖于应用程序的数据库布局有深入的了解。在这种情况下,可能涉及许多遗留应用程序依赖项。同样,您最好的信息来源将是您的应用程序供应商。
关于mysql - 用于选择字段名称的 while 循环?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49265833/