神通数据库字段空与非空
2023-12-15 16:58:29
神通数据库可以在建表时指定字段非空或可空,
-- 指定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
文章来源:https://blog.csdn.net/qq_44540985/article/details/135011267
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!