查询mysql中某字段为Null的数据
查询mysql 中某字段为空值的数据,于是写成了下⾯的样式,但返回的结果跟想要的不⼀样
错误:SELECT coupon_id FROM `t_coupon_info` WHERE remains_num = ""
正确:SELECT coupon_id FROM `t_coupon_info` WHERE remains_num IS NULL
查了⼀下,mysql空值和null是有区别的
陷阱⼀:空值不⼀定为空
  空值是⼀个⽐较特殊的字段。在MySQL数据库中,在不同的情形下,空值往往代表不同的含义。这是MySQL数据库的⼀种特性。如在普通的字段中(字符型的数据),空值就是表⽰空值。但是如果将⼀个空值的数据插⼊到TimesTamp类型的字段中,空值就不⼀定为空。此时为出现什么情况呢
  我先创建了⼀个表。在这个表中有两个字段:User_id(其数据类型是int)、Date(其数据类型是TimesTamp)。现在往这个表中插⼊⼀条记录,其中往Date字段中插⼊的是⼀个NULL空值。可是当我们查询时,其结果显⽰的却是插⼊记录的当前时间。这是怎么⼀回事呢?其实这就是在MySQL数据库中执⾏SQL语句时经常会遇到的⼀个陷阱:空值不⼀定为空。在操作时,明明插⼊的是⼀个空值的数据,但是最后查询得到的却不是⼀个空值。
  在MySQL数据库中,NULL对于⼀些特殊类型的列来说,其代表了⼀种特殊的含义,⽽不仅仅是⼀个空值。对于这些特殊类型的列,各位读者主要是要记住两个。⼀个就是笔者上⾯举的TimesTamp数据类型。如果往这个数据类型的列中插⼊Null值,则其代表的就是系统的当前时间。另外⼀个是具有auto_increment属性的列。如果往这属性的列中插⼊Null值的话,则系统会插⼊⼀个正整数序列。⽽如果在其他数据类型中,如字符型数据的列中插⼊Null的数据,则其插⼊的就是⼀个空值。
  陷阱⼆:空值不⼀定等于空字符
  在MySQL中,空值(Null)与空字符(’’)相同吗?答案是否定的。
  在同⼀个数据库表中,同时插⼊⼀个Null值的数据和⼀个’’空字符的数据,然后利⽤Select语句进⾏查询。显然其显⽰的结果是不相同的。从这个结果中就可以看出,空值不等于空字符。这就是在MySQL中执⾏SQL语句遇到的第⼆个陷阱。在实际⼯作中,空值数据与空字符往往表⽰不同的含义。员可以根据实际的需要来进⾏选择。如对于电话号码等字段,可以默认设置为空值(表⽰根本不知道对⽅的电话号码)或者设置为空字符(表⽰后来取消了这个号码)等等。由于他们在数据库中会有不同的表现形式,所以数据库管理员需要区别对待。笔者更加喜欢使⽤空值,⽽不是空字符。这主要是因为针对空值这个数据类型有⼏个⽐较特殊的运算字符。如果某个字段是空字符,数据库中是利⽤字段名称来代替。相反,如果插⼊的是空值,则直接显⽰的是NULL。这跟其他数据库的显⽰⽅式也是不同的。
  ⼀是IS NULL 和IS NOT NULL关键字。如果要判断某个字段是否含⽤空值的数据,需要使⽤特殊的关键字。其中前者表⽰这个字段为空,后者表⽰这个字段为⾮空。在Select语句的查询条件中这两个关键字⾮常的有⽤。如需要查询所有电话号码为空的⽤户(需要他们补充电话号码信息),就可以在查询条件中加⼊is not null关键字。
  ⼆是Count等统计函数,在空值上也有特殊的应⽤。如现在需要统计⽤户信息表中有电话号码的⽤户数量,此时就可以使⽤count函数、同时将电话号码作为参数来使⽤。因为在统计过程中,这个函数会⾃动忽略空值的数据。此时统计出来的就是有电话号码的⽤户信息。如果采⽤的是空字符的数据,则这个函数会将其统计进去。统计刚才建⽴的两条记录时,系统统计的结果是1,⽽不是2。可见系统⾃动将Null值的数据忽略掉了。
判断NULL⽤is null  或者 is not null。 sql语句⾥可以⽤ifnull函数来处理
mysql中select判断空字符串‘’,要⽤ ='' 或者 <>''。sql语句⾥可以⽤if(col,col,0)处理,即:当col为true时(⾮null,及⾮'')显⽰,否则打印0

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。