解决postgreSql 将Varchar类型字段修改为Int类型报错的问题
项目使用postgreSql数据库,先需要将库中的某个表中的某个字段类型由Varchar改成Int,直接右键设计表,修改类型为int,保存的时候报错,错误如下:
意思就是,这个crt_user字段不能自动转换成成类型bigint,需要使用USING表达式来转换。
这是在库中运行修改字段的类型的sql:
ALTER TABLE auth_client_service ALTER COLUMN crt_user SET DATA TYPE int8 USING crt_user:: int8, ALTER COLUMN crt_user SET DEFAULT 0;
至此,类型修改成功。
补充:PostgreSQL中将Integer类型的字段转换成Varchar类型的字段
rt,直接用pgadmin是没有办法进行这个转换的。
通过执行sql却是可以做到的,关键是添加USING表达式,这个表达式的意思是如何初始化这个字段。
比如下面的例子将整形转换成varchar(16)类型
ALTER TABLE app.app_high_school_score
ALTER COLUMN chinese TYPE character varying(16) USING (chinese::character varying(16));
USING 中也可以使用CAST操作符,例如:
USING CAST(column_name AS integer)
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。如有错误或未考虑完全的地方,望不吝赐教。
相关文章
SQL Server数据迁移至PostgreSQL出错的解释以及解决方案
最近对SQL Server到PostgreSQL的数据迁移时出现了问题,返回的错误为:invalid byte sequence for encoding "UTF8": 0x00。经查证pg源代码,该问题引起的原因是sql server的字符类型字段中含有空字符\0,该字符在pg中不支持。2014-09-09解决PostgreSQL服务启动后占用100% CPU卡死的问题
前文书说到,今天耗费了九牛二虎之力,终于驯服了NTFS权限安装好了PostgreSQL,却不曾想,服务启动后,新的状况又出现了。2009-08-08postgresql 利用fdw来实现不同数据库之间数据互通(推荐)
这篇文章主要介绍了postgresql 利用fdw来实现不同数据库之间数据互通,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2021-02-02PostgreSQL实战之启动恢复读取checkpoint记录失败的条件详解
这篇文章主要给大家介绍了关于PostgreSQL实战之启动恢复读取checkpoint记录失败的条件的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考借鉴,下面随着小编来一起学习学习吧2018-08-08
最新评论