簡體   English   中英

在臨時表中添加新列

[英]Adding a new column in a temporary table

我在PostgreSQL函數中有一個臨時表,我想插入一個新的VARCHAR列。 它的值應取決於表的另一列,稱為“金額”。

當金額為正數時,我希望將列行的值記為貸方;當金額為負數時,應將借方列記為借方。

我還有一個要求:我想將“金額”列的值四舍五入為兩位小數

您需要ALTER TABLE ... ADD COLUMN然后是UPDATE

我最初說的是ALTER TABLE ... ADD COLUMN ... USING但這在兩個方面是錯誤的。 ADD COLUMN會采用DEFAULT而不是USING並且您不能一pass而就,因為DEFAULT表達式和USING表達式都不能引用其他列。

因此,您必須執行以下操作:

 ALTER TABLE tablename ADD COLUMN colname varchar;
 UPDATE tablename SET colname = ( CASE WHEN othercol < 0 THEN 'Credit' ELSE 'Debit' END );

仔細考慮零應該是“借方”還是“貸方”,並相應地調整CASE

對於舍入,請使用round(amount,2) 您的問題中沒有足夠的細節讓我確定如何做。 可能是通過使用UPDATE thetable SET amount = round(amount,2)UPDATE臨時表來實現的UPDATE thetable SET amount = round(amount,2)但是如果沒有上下文,很難知道那是否正確。 該語句不可逆轉地丟棄信息,因此只能在數據副本上使用。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM