如何将数据从一列复制到同一张表中的另一列?

是否有可能将数据从列A复制到列B,用于SQL表中的所有记录?

412038 次浏览

这个怎么样

UPDATE table SET columnB = columnA;

这将更新每一行。

UPDATE table_name SET
destination_column_name=orig_column_name
WHERE condition_if_necessary

如果没有启用安全模式,这将更新该列中的所有行。

UPDATE table SET columnB = columnA;

如果启用了安全模式,则需要使用where子句。 我使用主键大于0基本上所有将更新

UPDATE table SET columnB = columnA where table.column>0;

如果你想在PostgresSQL中将一个列复制到另一个具有不同数据类型的列,你必须先转换/转换为该数据类型,否则它将返回

查询1:ERROR: column "test_date"类型的时间戳没有 但是表达式的类型字符是可变的 Table_name set test_date = date_string_col ^提示:你需要重写或强制转换表达式

一个将varchar转换为时间戳的例子:

update table_name set timestamp_col = date_string_col::TIMESTAMP;

一个将varchar转换为int的例子:

update table_name set int_column = string_col::INTEGER;

但是任何列类型(除了file或类似类型)都可以复制到string(character varying)而不强制转换类型。