sybase上关于default值的一个怪问题

     今天碰到一个bug,是这样的:

     当我通过web界面向test表插入一条记录时候,sybase报如下错误:

     Insert Object Error: Implicit conversion from datatype 'INT' to 'VARCHAR' is not allowed

     test表结构是这样的 :

     create  table  test (

         id int not null,

         name varchar(10) null,

         team  varchar(10) default 20 null

    ) 

   这个语句是可以成功执行的.

   后来查找到原因如下:

   插入记录时,我没有设置 team的值,就好像执行如下的语句一样:

   insert into test ( id , name ) values ( 1, 'test' )

   因为 没有设置 team 字段的值,所以 sybase就用 20 来作为缺省值来设置 team 的值,但因为 team为varchar型的,所以就报上面那个错误了 , 后来把default 值设为 '20'  就可以了.

    我不明白的是,为什么sybase在建表的时候不指出这样的错误 ,  而非要到实际使用的时候才报错 ?

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值