是否有可能将数据从列A复制到列B,用于SQL表中的所有记录?
这个怎么样
UPDATE table SET columnB = columnA;
这将更新每一行。
UPDATE table_name SET destination_column_name=orig_column_name WHERE condition_if_necessary
如果没有启用安全模式,这将更新该列中的所有行。
如果启用了安全模式,则需要使用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)而不强制转换类型。
character varying