开发者

SQL to fill columns based on columns of associated table

开发者 https://www.devze.com 2022-12-11 09:02 出处:网络
Suppose I have table first_table which has an FK to table second_table table second_table which has column called name_field

Suppose I have

  • table first_table which has an FK to table second_table
  • table second_table which has column called name_field

Now, I want to add a column in first_table called name_field and fill it with the one on the associated second_table.

How should I fill the values purely using SQL?

(this is Oracle, if 开发者_运维技巧that matters)


You can make a trigger in the FK table to do so automaticaly:

UPDATE table1
SET <field> = (select <field> from inserted where id=table1.id)


update (select first_table.name_field nf1,
               second_table.name_field nf2
          from first_table,
               second_table
          where ... (join condition) ...
        )
set nf1 = nf2


Potentially there are 2 different tasks: 1) initialize values in the new column I think that syntax below is the most universal UPDATE table1 SET <field> = (select <field> from table2 where id=table1.id) 2) synchronize values between 2 column in 2 tables based on the approach of j.a.estevan

0

精彩评论

暂无评论...
验证码 换一张
取 消