Postgresql 列“的默认值”;xxxx“;无法自动强制转换为Postgres DB中的布尔类型

Postgresql 列“的默认值”;xxxx“;无法自动强制转换为Postgres DB中的布尔类型,postgresql,Postgresql,我正在尝试将brs.parts表中的一列从字符变量更新为布尔值。 到目前为止,该列的数据为是/否。 我正在使用下面的命令 ALTER TABLE brs.parts ALTER COLUMN is_dpm_scanned TYPE BOOLEAN USING is_dpm_scanned::BOOLEAN 但我得到了以下错误: *********错误********** ERROR: default for column "is_dpm_scanned" cannot be cast aut

我正在尝试将brs.parts表中的一列从字符变量更新为布尔值。 到目前为止,该列的数据为是/否。 我正在使用下面的命令

ALTER TABLE brs.parts ALTER COLUMN is_dpm_scanned TYPE BOOLEAN USING is_dpm_scanned::BOOLEAN

但我得到了以下错误:

*********错误**********

ERROR: default for column "is_dpm_scanned" cannot be cast automatically to type boolean
SQL state: 42804

表格定义为:

CREATE TABLE brs.parts (
    id serial NOT NULL PRIMARY KEY,
    webcrt_part_id INTEGER,
    event_id INTEGER,
    webcrt_job_id INTEGER,
    incoming_serial_number CHARACTER VARYING(256),
    outgoing_serial_number CHARACTER VARYING(256), 
    part_number CHARACTER VARYING(256),
    tag_number NUMERIC,
    is_dpm_scanned CHARACTER VARYING(1) DEFAULT 'N'::CHARACTER VARYING,
    current_operation_id INTEGER,
    creation_date DATE,
    created_by CHARACTER VARYING(20) NOT NULL,
    last_updated_date DATE,
    last_updated_by CHARACTER VARYING(20) NOT NULL,
    is_delete CHARACTER VARYING(1) DEFAULT 'N'::CHARACTER VARYING
);

在更改类型之前,必须删除默认约束:

ALTER TABLE parts 
    ALTER COLUMN is_dpm_scanned DROP DEFAULT,
    ALTER COLUMN is_dpm_scanned TYPE BOOLEAN USING is_dpm_scanned::BOOLEAN,
    ALTER COLUMN is_dpm_scanned SET DEFAULT FALSE;

另请参见:.

如果将整数列强制转换为布尔值,则需要明确指定哪些值被视为
true
,哪些值被视为
false
。通常,0映射到
false
,其他所有内容映射到
true
。要执行此操作,请执行以下操作:

ALTER TABLE mytable ALTER mycolumn TYPE bool使用
如果mycolumn=0,则为FALSE
否则是真的
结束;