• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >Mysql > MySQL NULL 值处理

MySQL NULL 值处理

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-12-05

匿名通过本文主要向大家介绍了MySQL, NULL, PHP MySQL NULL 值处理等相关知识,希望本文的分享对您有所帮助
MySQL使用 SQL SELECT 命令及 WHERE 子句来读取数据表中的数据,但是当提供的查询条件字段为 NULL 时,该命令可能就无法正常工作。

为了处理这种情况,MySQL提供了三大运算符:

IS NULL: 当列的值是NULL,此运算符返回true。

IS NOT NULL: 当列的值不为NULL, 运算符返回true。

关于 NULL 的条件比较运算是比较特殊的。你不能使用 = NULL 或 != NULL 在列中查找 NULL 值 。

在MySQL中,NULL值与任何其它值的比较(即使是NULL)永远返回false,即 NULL = NULL 返回false 。

MySQL中处理NULL使用IS NULL和IS NOT NULL运算符。

在命令提示符中使用 NULL 值

以下实例中假设数据库 RUNOOB 中的表 tcount_tbl 含有两列 runoob_author 和 runoob_count, runoob_count 中设置插入NULL值。

尝试以下实例:

MariaDB [RUNOOB]> select * from tcount_tbl;
+---------------+--------------+
| runoob_author | runoob_count |
+---------------+--------------+
| mahran | 20 |
| mahran | NULL |
| Jen | NULL |
| Gill | 20 |
| John Poul | 1 |
| Sanjay | 1 |
+---------------+--------------+
6 rows in set (0.00 sec)

以下实例中你可以看到 = 和 != 运算符是不起作用的:

MariaDB [RUNOOB]> SELECT * FROM tcount_tbl WHERE runoob_count = NULL;Empty set (0.00 sec)

MariaDB [RUNOOB]> SELECT * FROM tcount_tbl WHERE runoob_count != NULL;Empty set (0.00 sec)

查找数据表中 runoob_count 列是否为 NULL,必须使用IS NULL和IS NOT NULL,如下实例:

MariaDB [RUNOOB]> SELECT * FROM tcount_tbl where runoob_count IS NULL;
+---------------+--------------+
| runoob_author | runoob_count |
+---------------+--------------+
| mahran | NULL |
| Jen | NULL |
+---------------+--------------+
2 rows in set (0.00 sec)

MariaDB [RUNOOB]> SELECT * FROM tcount_tbl where runoob_count IS NOT NULL;
+---------------+--------------+
| runoob_author | runoob_count |
+---------------+--------------+
| mahran | 20 |
| Gill | 20 |
| John Poul | 1 |
| Sanjay | 1 |
+---------------+--------------+
4 rows in set (0.00 sec)

使用PHP脚本处理 NULL 值

PHP脚本中你可以在 if...else 语句来处理变量是否为空,并生成相应的条件语句。

以下实例中PHP设置了$runoob_count变量,然后使用该变量与数据表中的 runoob_count 字段进行比较:

<?php

$dbhost ='localhost:3036';

$dbuser ='root';

$dbpass ='rootpassword';

$conn = mysql_connect($dbhost, $dbuser, $dbpass);

if(! $conn )

{

die('Could not connect: '. mysql_error());

}

if( isset($runoob_count ))

{

$sql ='SELECT runoob_author, runoob_count

FROM tcount_tbl

WHERE runoob_count IS NOT NULL';

}

else

{

$sql ='SELECT runoob_author, runoob_count

FROM tcount_tbl

WHERE runoob_count IS NULL';

}

mysql_select_db('RUNOOB');

$retval = mysql_query( $sql, $conn );

if(! $retval )

{

die('Could not get data: '. mysql_error());

}

while($row = mysql_fetch_array($retval, MYSQL_ASSOC))

{

echo "Author:{$row['runoob_author']} <br> ".

"Count: {$row['runoob_count']} <br> ".

"--------------------------------<br>";

}

echo "Fetched data successfully\n";

mysql_close($conn);

?>

运行结果:

bc388e51-0eaa-34e2-919a-f7d50150f19a.png

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 分享下mysql各个主要版本之间的差异
  • MySQL essential版本和普通版本有什么区别?
  • redhat 5.4下安装MYSQL全过程
  • 如何用SQL命令查看Mysql数据库大小
  • 解析mysql中如何获得数据库的大小
  • 解析mysql修改为utf8后仍然有乱码的问题
  • 5个常用的MySQL数据库管理工具详细介绍
  • 解析在MySQL里创建外键时ERROR 1005的解决办法
  • 解析远程连接管理其他机器上的MYSQL数据库
  • mysql 精简过程(删除一些文件)

相关文章

  • 2018-12-05MySQL入门之事务概念
  • 2017-05-11超详细mysql left join,right join,inner join用法分析
  • 2018-12-05MySQL中添加新用户权限的实例详解
  • 2017-05-11mysql:Can't start server: can't create PID file: No space left on device
  • 2018-12-05Mysql命令行导入sql数据
  • 2018-12-05MSSQL 2005 安全设置图文教程
  • 2018-12-05Linux下安装MySQL-5.7教程(图文)
  • 2017-05-11SQL查询超时的设置方法(关于timeout的处理)
  • 2018-12-05mysql存储引擎和数据类型(二)_MySQL
  • 2018-12-05Mysql5.7.19在Centos7下安装教程详解

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • mysql数据库导出excel xml等格式文件
    • 深入Mysql字符集设置分析
    • Mysql使用insert插入多条记录批量新增数据实例教程
    • 将Session值储存于SQL Server中
    • navicat 8 创建数据库与创建用户分配权限图文方法
    • 利用SQL注入漏洞登录后台的实现方法
    • mysql处理添加外键时提示error 150 问题的解决方法
    • 利用脚本自动安装SQLServer的实现步骤分析
    • MySQL的23个需要注意的地方
    • MySQL数据库如何解决无法被其他ip访问的方法

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有