时间:2021-05-23
项目使用postgreSql数据库,先需要将库中的某个表中的某个字段类型由Varchar改成Int,直接右键设计表,修改类型为int,保存的时候报错,错误如下:
意思就是,这个crt_user字段不能自动转换成成类型bigint,需要使用USING表达式来转换。
这是在库中运行修改字段的类型的sql:
ALTER TABLE auth_client_service ALTER COLUMN crt_userSET DATA TYPE int8 USING crt_user:: int8, ALTER COLUMN crt_userSET 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)
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有错误或未考虑完全的地方,望不吝赐教。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
PostgreSql数据库中varchar类型与sqlserver中字段用法有差别,PostgreSql中如果字段设置为varchar类型长度为10,则无论存字
常用字段类型bit(0和1),datetime,int,varchar,nvarchar(可能含有中文用nvarchar)Varchar,nvarchar和ch
最近学习了Oracle修改字段类型方法,留做记录。有一个表名为tb,字段段名为name,数据类型nchar(20)。1、假设字段数据为空,则不管改为什么字段类型
在有些场景下,我们需要对我们的varchar类型的字段做修改,而修改的结果为两个字段的拼接或者一个字段+字符串的拼接。如下所示,我们希望将xx_role表中的n
在上篇文章给大家讲了MySQL数据库中把int转化varchar引发的慢查询,本文给大家介绍Mysql数据库中把varchar类型转化为int类型的方法,一起看