Welcome 微信登录

首页 / 数据库 / MySQL / Oracle 表中的列带有default值的陷阱

在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
IDNAME
1name
当用下面的SQL语句插入行的时候,不会给name列赋默认值.
insert into test values(2,null)
查询结果发现ID为2的行的name的值为空:select * from test
IDNAME
1name
2 
select * from test where name is null 能将ID为2的行查询出来.
同样,在通过JAVA代码用JDBC,一些ORM框架插入数据的时候,也需要注意同样的问题.
  1. private static void testNULL() throws SQLException {              
  2.     String sqlstr = "insert into test values(?,?)";       
  3.     Connection conn = NONXADBUtil.getConnection("jdbc:oracle:thin:@xxx:orcl""xxx""xxx");  
  4.     PreparedStatement sta = conn.prepareStatement(sqlstr);    
  5.       
  6.     sta.setInt(13);  
  7.     sta.setString(2null);##1  
  8.       
  9.     sta.executeUpdate();  
  10.     sta.close();  
  11.     conn.commit();  
  12.     conn.close();  
  13. }  
上面的代码插入的行,name列也不会被赋值为默认值,将##1处改为sta.setString(2, "")同样插入的是空值(null).更多Oracle相关信息见Oracle 专题页面 http://www.linuxidc.com/topicnews.aspx?tid=12Oracle 中用一个表的数据更新另一个表的数据什么是Oracle Key-Preserved Table和什么样的视图可以进行DML操作相关资讯      Oracle基础教程 
  • Oracle块编程返回结果集详解  (11/10/2013 10:45:58)
  • Oracle基础教程之设置系统全局区  (08/22/2013 14:24:00)
  • Oracle基础教程知识点总结  (06/18/2013 07:43:32)
  • Oracle基础教程之tkprof程序详解  (10/22/2013 11:49:50)
  • Oracle基础教程之sqlplus汉字乱码  (07/18/2013 16:30:00)
  • Oracle 管理之 Linux 网络基础  (02/16/2013 18:37:35)
本文评论 查看全部评论 (0)
表情: 姓名: 字数