无法将数字类型转换为布尔值

飞雨云
ALTER TABLE products ALTER COLUMN power_price DROP DEFAULT;
ALTER TABLE products ALTER COLUMN power_price TYPE bool USING (power_price::boolean);
ALTER TABLE products ALTER COLUMN power_price SET NOT NULL;
ALTER TABLE products ALTER COLUMN power_price SET DEFAULT false;

Postgres给我这个错误:

查询失败:错误:无法将数字类型转换为布尔值

欧文·布兰德斯特(Erwin Brandstetter)

使用:

ALTER TABLE products ALTER power_price TYPE bool USING (power_price::int::bool);

numeric之间没有定义直接转换boolean您可以integer用作中间立场。text将是中间立场的另一个候选者,因为每种类型都可以从/强制转换text价值1 / 0当然是必须的。

更好的是,用一个命令完成所有操作,以获得更好的性能和更短的锁定时间:

ALTER TABLE products
  ALTER power_price DROP DEFAULT
 ,ALTER power_price TYPE bool USING (power_price::int::bool)
 ,ALTER power_price SET NOT NULL
 ,ALTER power_price SET DEFAULT false;

手册中有关的详细信息ALTER TABLE

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章