向 ima_file里的ima021 插入imatemp字段的ima021,当imatemp的ima01与ima_file里的ima01一致就插入
时间: 2024-03-27 14:39:44 浏览: 161
好的,您的需求是在 ima_file 表中的 ima021 记录中插入一个 imatemp 字段,并且只有在 imatemp 的 ima01 字段与 ima_file 表中的 ima01 字段一致时才进行插入操作。如果我理解得正确的话,您可以考虑使用如下的 SQL 语句来实现:
```
INSERT INTO ima_file(ima021, imatemp)
SELECT t1.ima021, 'your_value'
FROM ima_file t1
WHERE t1.ima01 = 'your_ima01_value'
AND NOT EXISTS(
SELECT 1
FROM ima_file t2
WHERE t2.ima01 = 'your_ima01_value'
AND t2.ima021 = 'your_value'
)
```
请将上述 SQL 语句中的 'your_value' 替换为您实际要插入的 imatemp 字段的值,将 'your_ima01_value' 替换为您要插入的记录对应的 ima01 字段的值。此外,需要注意的是,上述 SQL 语句中的 NOT EXISTS 子句用于排除已经存在相同 ima021 和 imatemp 值的记录。
相关问题
LET g_sql = " g_bma01_a.bma_file.bma01,", " l_ver.ima_file.ima05,", " p_i.type_file.num5,", " l_ima05.ima_file.ima05, ", " l_ima08.ima_file.ima08,",
这段代码是一个字符串赋值操作,其中包含多个字段的名称,这些字段名称可能用于SQL查询中的表格中。具体来说,这些字段名称包括:
- g_bma01_a.bma_file.bma01
- l_ver.ima_file.ima05
- p_i.type_file.num5
- l_ima05.ima_file.ima05
- l_ima08.ima_file.ima08
这些字段名称可能代表不同的表格和列,但需要根据上下文来确定。
用 WITH bom_tree(bmb01, bmb03, bmb53) AS ( -- 先将成品加入递归表达式 SELECT bmb01, bmb03, bmb53 FROM bmb_file WHERE bmb01 = '1' UNION ALL -- 递归查询元件 SELECT b.bmb01, b.bmb03, SUM(b.bmb53 * t.bmb53) AS cost FROM bom_tree t JOIN bmb_file b ON t.bmb03 = b.bmb01 WHERE b.bmb04 = '1' -- 只查询原材料 GROUP BY b.bmb01, b.bmb03)-- 最终查询结果 SELECT bmb03, SUM(bmb53) AS cost FROM bom_tree WHERE bmb01 IS NULL GROUP BY bmb03;这个代码优化,价格不再是bmb表中的bmb53,而是ima_file中的ima53,ima_file 是料件信息表,ima01是料件编号
根据你的描述,我了解到你想要对使用递归查询所有料件的成本价的 SQL 代码进行优化,使其可以使用 `ima_file` 表中的 `ima53` 价格来计算成本价。下面是修改后的 SQL 代码:
```
WITH bom_tree(bmb01, bmb03, cost) AS (
-- 先将成品加入递归表达式
SELECT bmb01, bmb03, CAST(NULL AS DECIMAL(18, 4)) AS cost
FROM bmb_file
WHERE bmb01 = '1'
UNION ALL
-- 递归查询元件
SELECT b.bmb01, b.bmb03, CAST(SUM(COALESCE(i.ima53, b.bmb53) * t.cost) AS DECIMAL(18, 4)) AS cost
FROM bom_tree t
JOIN bmb_file b ON t.bmb03 = b.bmb01
LEFT JOIN ima_file i ON i.ima01 = b.bmb03
WHERE b.bmb04 = '1' -- 只查询原材料
GROUP BY b.bmb01, b.bmb03
)
-- 最终查询结果
SELECT bmb03, CAST(SUM(cost) AS DECIMAL(18, 4)) AS cost
FROM bom_tree
WHERE bmb01 IS NULL
GROUP BY bmb03;
```
在这个修改后的 SQL 代码中,我们使用了一个 `ima_file` 表来获取所有原材料的 `ima53` 价格。具体来说,我们在递归查询中使用了一个 `LEFT JOIN` 来将 `bmb_file` 表和 `ima_file` 表连接起来,如果某个元件在 `ima_file` 表中存在对应的 `ima53` 价格,则使用该价格来计算成本价;否则,仍然使用 `bmb53` 价格来计算成本价。另外,我们在递归查询的结果集中添加了一个 `cost` 字段来存储当前料件的成本价。
最终,我们在查询结果时,对所有 `bmb01` 为 `NULL` 的记录进行分组并求和,得到每个料件的总成本价。
希望这个修改后的 SQL 代码可以满足你的需求。如果你有任何疑问或需要进一步的帮助,请随时告诉我。
阅读全文