是否有可能将数据从列A复制到列B,用于SQL表中的所有记录?
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;
但是任何列类型(除了文件或类似类型)都可以复制到字符串(字符变化)而不强制转换类型。
推荐文章
- 如何在Ruby On Rails中使用NuoDB手动执行SQL命令
- 查询JSON类型内的数组元素
- 确定记录是否存在的最快方法
- 获得PostgreSQL数据库中当前连接数的正确查询
- 在SQL选择语句Order By 1的目的是什么?
- 我如何循环通过一组记录在SQL Server?
- 如何从命令行通过mysql运行一个查询?
- 外键约束可能导致循环或多条级联路径?
- 使用LIMIT/OFFSET运行查询,还可以获得总行数
- 当恢复sql时,psql无效命令\N
- 货币应该使用哪种数据类型?
- 如何选择每一行的列值不是独特的
- 如何改变字符集(和排序)在整个数据库?
- mySQL:: insert到表,数据从另一个表?
- 如何在Postgres中获得两个字段的MIN() ?