神通数据库字段空与非空

神通数据库可以在建表时指定字段非空或可空,

-- 指定column1字段非空
CREATE TABLE SYSDBA.tmp_test1(column1 varchar(100) NOT NULL)

--尝试向column1字段插入空值
INSERT INTO  SYSDBA.tmp_test1(column1) VALUES(NULL)

会收到插入失败的提示:

而如果建表时不添加NOT NULL关键字,那么空值是可以被插入到:

-- 指定column1字段可以为空
CREATE TABLE SYSDBA.tmp_test2(column1 varchar(100))

--尝试向column1字段插入空值
INSERT INTO  SYSDBA.tmp_test2(column1) VALUES(NULL)

空值被成功插入

那么对于已有的表,如何实现字段非空和可为空之间的修改转换呢?

1. 将非空字段修改为可为空

ALTER TABLE SYSDBA.tmp_test1 MODIFY  column1 varchar(200) NULL

2.将可为空字段修改为非空

ALTER TABLE SYSDBA.tmp_test1 MODIFY  column1 varchar(200)  NOT NULL

注意如果修改前,被修改字段中有null值那么会报错

SQL 错误 [40000]: ERROR, 属性信息出错, ALTER TABLE: Attribute "COLUMN1" contains NULL values

此时需要先将null值替换掉,比如替换为字符串类型的'NULL'

UPDATE SYSDBA.tmp_test1 SET column1='NULL' WHERE column1 IS null

替换完所有null值后,再次执行命令,即可完成转换。

注意:

UPDATE SYSDBA.tmp_test1 SET column1='NULL' WHERE column1 IS null

改行命令不能修改字段名,得使用以下命令更改神通数据库表中某字段名:

ALTER TABLE SYSDBA.tmp_test1 RENAME COLUMN column1 TO column2

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值