回答

收藏

PostgreSQL:插入另一个表

技术问答 技术问答 220 人阅读 | 0 人回复 | 2023-09-14

我试图将数据从另一个表插入到一个表中,这些表只有一个共同的列。问题是,TABLE1列不接受空值,所以我不能把它们留空,也不能从TABLE二中获取。  \; ^/ \. u, p1 |1 @" d4 F
我有TABLE1:id,col_1(不为null),col_2(不为null),col_3(不为null)4 |( N1 k/ p7 m6 U- Q" J+ t
和TABLE2:id,col_a,col_b,col_c
+ R& X, ]2 p: U1 A% ~8 V( I, E那么如何将ID从TABLE2插入TABLE并用如 data1”,“ data2”,“ data3等硬编码字符串填充col_1-3?
0 t- u4 e8 x( M% n7 ]) s9 H# m' CINSERT INTO TABLE1 (id) SELECT id FROM TABLE2 WHERE col_a = "something";将导致:2 {$ R; ~3 F1 D5 t% ^8 p
错误:“ col_1列中的空值违反了非空约束
3 r5 `  N' f3 H  s- ~* g$ G
                                                               
& H) b. F5 e4 x/ [7 C    解决方案:                                                               
! }8 O/ n0 {# ~3 q' j                                                                只需在SELECT中提供文字值即可:
' r# R+ ^$ c7 r- T8 v/ ^INSERT INTO TABLE1 (id,col_1,col_2,col_3)SELECT id,'data1','data2','data3'FROM TABLE2WHERE col_a = 'something';列表可以包含任何值表达式:
; ~9 D* i' A3 \, U但不需要引用列表中的表达式FROM表达式中的任何任何列。例如,它们可以是常量算术表达式。
. C  ^( a# f$ ^字符串文字必须是值表达式。
分享到:
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则