码迷,mamicode.com
首页 > 数据库 > 详细

SQL Server 中BIT类型字段增删查改那点事

时间:2017-05-18 13:24:54      阅读:214      评论:0      收藏:0      [点我收藏+]

标签:code   类型   也会   查询   src   update   image   creat   bsp   

  

  话说BIT类型字段之前,先看“诡异”的一幕,执行Update成功,但是查询出来的结果依然是1,而不是Update的2
  当别人问起我来的时候,本人当时也是处于懵逼状态的,后面联想具体的业务突然想起来这个字段是bit类型的

  技术分享

  如果把这个现象跟BIT类型字段连续起来就不觉得奇怪了。
  废话不多,直接上代码看结果就好了。
  先建一个测试表

CREATE TABLE TestBIT
(
    Id INT IDENTITY(1,1),
    BitColumn BIT
)

按照常规来说,bit类型字段只能存0或者1,所以直接inert 0或者1当然是没有问题的。

技术分享

因为bit代表的是真假值,在insert时候赋字符串的false或者true也是没有问题的

技术分享

当然文本仅仅支持false或者true这两个字符串,其他都会报错,从报错中也会发现,在insert的时候有一个隐式转换

技术分享

  对于数值型的数据:当执行插入一个非0或者1的数值的时候,也是会插入成功的,但是(非0的值)插入后的值被隐式转换为1了
   插入非0的数值,均被转换为1,也就是true

   技术分享

   执行更新操作也一样,如果更新的是数值,更新的字符串只能为false或者true

     技术分享

   技术分享

    如果更新的是数值,并且这个数值不是0(是整数或者负数),相当于更新bit字段类型为1

   技术分享

   技术分享

 

 

 

 

 

  

SQL Server 中BIT类型字段增删查改那点事

标签:code   类型   也会   查询   src   update   image   creat   bsp   

原文地址:http://www.cnblogs.com/wy123/p/6872721.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!