2016-12-14 53 views
1

我想从brs.parts表中的字符更改为布尔值。 该列的数据为Y/N至今。 我使用下面的命令默认为列“xxxx”不能自动转换为在Postgres DB中键入布尔值

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 
); 

回答

5

你必须改变类型之前下降默认约束:

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; 

参见:Changing a column from string to string array in postgresql

+0

我不认为'USING is_dpm_scanned :: BOOLEAN'正在工作。您可能需要'使用is_dpm_scanned ='Y'' –

+0

它运作良好 - https://www.postgresql.org/docs/current/static/datatype-boolean.html – klin

+0

Thanx它的工作 – sromit