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


这个怎么样

UPDATE table SET columnB = columnA;

这将更新每一行。


UPDATE table_name SET
    destination_column_name=orig_column_name
WHERE condition_if_necessary

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

UPDATE表SET columnB = columnna;

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

SET columnB = columnna where table.column>0;


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

查询1错误:错误:列"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;

但是任何列类型(除了文件或类似类型)都可以复制到字符串(字符变化)而不强制转换类型。