MySql 比较时返回 NULL

标签 mysql comparison

我遇到了一个问题。

谁能解释一下为什么

SELECT (null <> 'TEST STRING')

SELECT (null != 'TEST STRING')

返回 NULL 而不是您所期望的 bool 值 true?

我不是在寻找解决方案,而是在寻找 SQL 为何如此运行的解释。

无论使用哪种语言,您都希望进行任何比较都会返回 bool 值。

最佳答案

不能使用 NULL 运算符执行算术比较。因此,当您使用 NULL 执行算术运算时,如 <>!=它给你 NULL(一个无意义的值),这违背了你对 bool 值的期望。

MySQL可以引用 NULL 在 MySQL 中如何工作的解释。

还要注意的是,在MySql中NULL是特殊的,它的意思是unknown在编程中它的值意味着 undefined value .

关于MySql 比较时返回 NULL,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29715316/

相关文章:

powershell - 为什么枚举后比较运算符不起作用?

php - MySQL 查询,获取 user_ID,然后获取 Restaurant_ID,然后从与用户表中的电子邮件匹配的 3 个表中获取 restaurantName

mysql - 在 Wordpress 中查询 mysql 替换

python - 为 mysql-python (MySQLdb) 更改 django 中的 CLIENT_FOUND_ROWS 标志?

ajax - Ajax 库的比较

Java:反向排序而不保持顺序

php - 如何对两个不同的数组值执行真假比较

mysql - 在 Laravel 中,我想将列类型从 varchar 更改为 double,它会出错。但是在创建列时它可以正常工作

python - 使用 App Engine 连接到 MySQL 数据库

mysql - SELECT by A列OR B列在数据库中的数据比较顺序是什么