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
);
我不认为'USING is_dpm_scanned :: BOOLEAN'正在工作。您可能需要'使用is_dpm_scanned ='Y'' –
它运作良好 - https://www.postgresql.org/docs/current/static/datatype-boolean.html – klin
Thanx它的工作 – sromit