Oracle 表中的列带有default值的陷阱
程序员文章站
2024-02-15 16:31:46
...
在Oracle中,对于表的列可以为其指定默认值,这样在insert数据的时候,如果该列不出现在insert语句中的时候,会为其赋上默认值.注意这
在Oracle中,对于表的列可以为其指定默认值,这样在insert数据的时候,如果该列不出现在insert语句中的时候,会为其赋上默认值.注意这里是该列不出现在insert语句中,而不是该列的值为空值的时候.如下面的表:
create table test(id number(10),name varchar2(20) default 'name')
当用下面的SQL语句插入行的时候,会给name列赋默认值.
insert into test(id) values(1)
查询结果为:select * from test
ID NAME
1 name
当用下面的SQL语句插入行的时候,不会给name列赋默认值.insert into test values(2,null)
查询结果发现ID为2的行的name的值为空:select * from test
ID NAME
1 name
2
select * from test where name is null 能将ID为2的行查询出来.同样,在通过JAVA代码用JDBC,一些ORM框架插入数据的时候,也需要注意同样的问题.
上面的代码插入的行,name列也不会被赋值为默认值,将##1处改为sta.setString(2, "")同样插入的是空值(null).
更多Oracle相关信息见Oracle 专题页面 ?tid=12
,推荐阅读
-
Oracle 表中的列带有default值的陷阱
-
Oracle 11g对大表中添加DEFAULT值的NOT NULL字段速度有大幅度的提升
-
Oracle 中列添加和不同行数的两张表合并
-
Oracle存储过程中如何根据指定的参数判断该参数的值否存在数据表
-
sqlserver中在指定数据库的所有表的所有列中搜索给定的值
-
sqlserver中在指定数据库的所有表的所有列中搜索给定的值
-
浅析Oracle 11g中对数据列默认值变化的优化
-
查询Oracle中某张指定表的列的信息 oracletablecolumn
-
Oracle中表添加带有默认值列的讨论(包括11G新特性)
-
Oracle存储过程中如何根据指定的参数判断该参数的值否存在数据表