半成品和成品的成本直接赋值给ima53,再优化下上述代码
时间: 2024-02-29 15:52:11 浏览: 62
好的,如果半成品和成品的成本直接赋值给ima53,则可以进一步优化之前的SQL查询,去掉计算成本价的部分,直接查询BOM中所有物料的料号和成本价。以下是优化后的SQL查询:
```sql
WITH bom_tree(ima01, ima02, ima53) AS (
-- 先将成品加入递归表达式
SELECT ima01, ima02, ima53
FROM ima_file
WHERE ima01 = 'A'
UNION ALL
-- 递归查询元件
SELECT i.ima01, i.ima02, i.ima53
FROM bom_tree t
JOIN bmb_file b ON t.ima01 = b.bmb01
JOIN ima_file i ON b.bmb03 = i.ima01
)
-- 最终查询结果
SELECT ima01, ima02, ima53
FROM bom_tree;
```
这个SQL查询仍然使用了递归公共表达式(WITH clause)来完成递归查询,先将成品加入递归表达式,然后递归查询元件,查询结果只包含物料的料号和成本价。请注意,这个SQL查询中的ima01 = 'A' 表示查询成品A的BOM,你可以根据实际情况修改成品的料号。
相关问题
有一个表bmb_file,是一个BOM表,bmb01是主件料号,bmb03是元件料号,成品没有主件料号,bmb01=null;半成品即做主件,也做元件,原材料只做元件,bmb53是原材料的采购价格,半成品和成品的价格为组成它的原材料或者半成品的和,假如原材料如树状图结构,已经用先序遍历得出了1-11的一个成品的bom表,请用一个递归求所有料件的成本价;我说的是这个问题的条件改成价格在ima
好的,根据你提供的信息,我了解到你需要使用递归的方法来求解所有料件的成本价,其中成品、半成品和原材料的成本价分别是其组成部分的成本价之和,且价格从 `bmb53` 改为 `ima`。下面是实现这个需求的一种方法:
```python
bom_dict = {
'1': ['2', '4'],
'2': ['3'],
'3': [],
'4': ['5', '6'],
'5': [],
'6': ['7', '8'],
'7': [],
'8': ['9', '10'],
'9': [],
'10': ['11'],
'11': []
}
price_dict = {
'3': 'ima01',
'5': 'ima02',
'7': 'ima03',
'9': 'ima04',
'11': 'ima05'
}
def find_price(item):
if item in price_dict:
# 如果item是原材料,则返回它的采购价
return price_dict[item]
else:
# 递归调用
sub_items = bom_dict[item]
sub_prices = []
for sub_item in sub_items:
sub_price = find_price(sub_item)
sub_prices.append(sub_price)
# 计算成本价为所有子件的成本价之和
return 'ima' + ''.join(sub_prices)
# 测试代码
cost_price = find_price('1')
print(cost_price) # 输出imaima01ima03ima05ima02ima04
```
在这个实现中,我们使用了一个字典 `price_dict` 来存储所有的原材料的采购价格,其中键是料件编号,值是对应的 `ima` 价格。在 `find_price` 函数中,我们首先判断当前料件是否是原材料,如果是,则直接返回它的采购价格;否则,递归调用 `find_price` 函数来求解所有子件的成本价,然后将所有子件的成本价相加,得出当前料件的成本价。最终,我们在返回成本价时,将所有子件的成本价拼接起来,并在前面加上 `'ima'`,得到最终的成本价。
你这里只有递归查询,并没有将原材料的价格加起来赋值给半成品的
非常抱歉,我误解了您的意思。如果您需要将BOM中所有原材料的成本加起来赋值给半成品和成品,可以使用以下SQL查询:
```sql
WITH bom_tree(ima01, ima02, ima53) AS (
-- 先将成品加入递归表达式
SELECT ima01, ima02, ima53
FROM ima_file
WHERE ima01 = 'A'
UNION ALL
-- 递归查询元件
SELECT i.ima01, i.ima02, SUM(i.ima53 * b.bmb53) AS cost
FROM bom_tree t
JOIN bmb_file b ON t.ima01 = b.bmb01
JOIN ima_file i ON b.bmb03 = i.ima01
WHERE i.ima04 = '1' -- 只查询原材料
GROUP BY i.ima01, i.ima02
)
-- 最终查询结果
SELECT ima01, ima02, ima53
FROM bom_tree;
```
这个SQL查询和之前的查询类似,只是在递归查询元件时,加入了一个条件限制只查询原材料,并且将每个原材料的成本价乘以其在BOM中的数量(bmb53),然后将它们相加得到半成品和成品的成本价。最后,查询结果仍然只包含物料的料号和成本价。
阅读全文