浅谈mysql返回Boolean类型的几种情况


Posted in MySQL onJune 04, 2021

mysql返回Boolean类型

浅谈mysql返回Boolean类型的几种情况

第一种情况,直接返回

select id='22aa' from mytest where age=202  返回1 可封装为true
select count(*)=1 from mytest where age=202  返回1 可封装为true
select count(*)=0 from mytest where age=202  返回0 可封装为false
select count(*)<3 from mytest where age=202  返回1 可封装为true
select count(*)<=1 from mytest where age=202  返回1 可封装为true
select name="aa" from mytest where age=10  当name为null时,sql不会报错,返回结果也为nul,参照第二种情况的sql 3 代码会报错

总结:

这种情况类似于java中的判断语句。只是java中=是赋值的意思,所以用了==来做判断,而mysql中赋值用set,判断就直接用=。

第二种情况,返回0或者1也能达到目的

select enable from mytest where age=202  返回1  可封装为true
select count(*) from mytest  返回4  可封装为Boolean类型,但为false
select enable from mytest where age=201 返回null  不可封装为Boolean类型,代码会直接报错
select id from mytest where age=202   返回'22aa'   可封装为Boolean类型,但为false
select id from mytest where age=202   返回'true'   可封装为Boolean类型,但为true
select id from mytest where age=202   返回'false'   可封装为Boolean类型,false
//特殊情况
select * from mytest  报错Expected one result (or null) to be returned by selectOne(), but found: 4
select * from mytest where age=202  返回一组数据false 2019-08-28 202 15 1 ,可以封装为false
select * from mytest where age=202  返回一组数据true 2019-08-28 202 15 1 ,可以封装为true
select * from mytest where age=202  返回一组数据aaaa2019-08-28 202 15 1 ,可以封装为false

总结:

Mybatis是根据查询到的记录数进行转换的(1=true,0=false)

需要注意的地方:如果查询到多条记录(大于1),返回的却是false, 这时就与我们的期望的刚好相反。这里,可以换其它方法,可以通过返回记录数,进行判断,也可以保证记录在数据库是唯一的。也可以直接用第一种情况解决。

根据第4、5、6条sql语句的测试,如果字符串是"true",就可以封装为true,如果为"false"就可以封装为false,其他情的字符串都为false。

(猜测,并不准确,需要到mysql官网上来查,如果返回的字段是字符串,将其转为Boolean时是按什么规则转换的,猜测是类似于java中的字符串转Boolean方法:Boolean.valueOf(“aaa”) //false,该方法如下)

浅谈mysql返回Boolean类型的几种情况

浅谈mysql返回Boolean类型的几种情况 至于8、9、10的sql返回一组,而接受数据的只要一个时的情况,为什么就取了id的值来封装,有待继续研究。

MySQL Boolean类型的坑

MySQL中,Boolean只是 tinyint(1) 的别名,也就是说,MySQL中并没有真正的bool类型。而SQLAlchemy生成SQL的时候并没有检测到 这一点,这就导致一个问题,当使用 bool 类型作为查询条件时,用不上索引,从而导致扫表的行为:

> SELECT COUNT(*) FROM message WHERE message.is_national = 1 AND message.updated_at > '2020-01-01 00:00:00' AND message.deleted_at IS NULL;
+----------+
| COUNT(*) |
+----------+
| 0        |
+----------+
1 row in set
Time: 0.018s
> SELECT COUNT(*) FROM message WHERE message.is_national is true AND message.updated_at > '2020-01-01 00:00:00' AND message.deleted_at IS NULL;
+----------+
| COUNT(*) |
+----------+
| 0        |
+----------+
1 row in set
Time: 2.162s

注意观察第一行和第二行的时间,很明显第二行没有用上索引,我们来看看 EXPLAIN 的结果便知道了:

> EXPLAIN SELECT COUNT(*) FROM message WHERE message.is_national = 1 AND message.updated_at > '2020-01-01 00:00:00' AND message.de
        leted_at IS NULL;
| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
| 1  | SIMPLE | message | ref  | ix_message_updated_at,idx_updated_at_is_national,ix_message_is_national | ix_message_is_national | 1 | const | 1 | Using where |

> EXPLAIN SELECT COUNT(*) FROM message WHERE message.is_national is true AND message.updated_at > '2020-01-01 00:00:00' AND messag
        e.deleted_at IS NULL;
| id | select_type | table   | type | possible_keys | key    | key_len | ref    | rows    | Extra |
| 1  | SIMPLE | message | ALL  | ix_message_updated_at,idx_updated_at_is_national | <null> | <null>  | <null> | 一个很大的数字 | Using whe
re |

对此,我只想说,太坑了!

以上为个人经验,希望能给大家一个参考,也希望大家多多支持三水点靠木。

MySQL 相关文章推荐
mysql多表查询-笔记七
Apr 05 MySQL
如何使用Maxwell实时同步mysql数据
Apr 08 MySQL
将图片保存到mysql数据库并展示在前端页面的实现代码
May 02 MySQL
安装配置mysql及Navicat prenium的详细流程
Jun 10 MySQL
如何搭建 MySQL 高可用高性能集群
Jun 21 MySQL
mysql如何能有效防止删库跑路
Oct 05 MySQL
MySQL基于索引的压力测试的实现
Nov 07 MySQL
VS2019连接MySQL数据库的过程及常见问题总结
Nov 27 MySQL
mysql创建存储过程及函数详解
Dec 04 MySQL
mysql中整数数据类型tinyint详解
Dec 06 MySQL
详细介绍MySQL中limit和offset的用法
May 06 MySQL
mysql 获取相邻数据项
May 11 MySQL
Mysql 设置boolean类型的操作
Jun 04 #MySQL
MySQL中的布尔值,怎么存储false或true
mysql外连接与内连接查询的不同之处
Mysql systemctl start mysqld报错的问题解决
Jun 03 #MySQL
你知道哪几种MYSQL的连接查询
Jun 03 #MySQL
MySQL中in和exists区别详解
Jun 03 #MySQL
MySQL 不等于的三种使用及区别
Jun 03 #MySQL
You might like
使PHP自定义函数返回多个值
2006/11/26 PHP
WordPress主题制作中自定义头部的相关PHP函数解析
2016/01/08 PHP
9个比较实用的php代码片段
2016/03/15 PHP
PHP入门教程之面向对象基本概念实例分析
2016/09/11 PHP
js转义字符介绍
2013/11/05 Javascript
QQ登录背景闪动效果附效果演示源码下载
2015/09/22 Javascript
TypeOf这些知识点你了解吗
2016/02/21 Javascript
JavaScript学习笔记之ES6数组方法
2016/03/25 Javascript
jQuery选择器及jquery案例详解(必看)
2016/05/20 Javascript
js动态添加的DIV中的onclick事件简单实例
2016/07/25 Javascript
Angularjs 制作购物车功能实例代码
2016/09/14 Javascript
js实现加载更多功能实例
2016/10/27 Javascript
JQuery统计input和textarea文字输入数量(代码分享)
2016/12/29 Javascript
vue2.0嵌套路由实现豆瓣电影分页功能(附demo)
2017/03/13 Javascript
AngularJS中ng-class用法实例分析
2017/07/06 Javascript
分享vue.js devtools遇到一系列问题
2017/10/24 Javascript
Element-ui table中过滤条件变更表格内容的方法
2018/03/02 Javascript
JS与jQuery判断文本框还剩多少字符可以输入的方法
2018/09/01 jQuery
React 全自动数据表格组件——BodeGrid的实现思路
2019/06/12 Javascript
跟老齐学Python之复习if语句
2014/10/02 Python
Python访问纯真IP数据库脚本分享
2015/06/29 Python
运用TensorFlow进行简单实现线性回归、梯度下降示例
2018/03/05 Python
利用Python读取txt文档的方法讲解
2018/06/23 Python
使用PyInstaller将Pygame库编写的小游戏程序打包为exe文件及出现问题解决方法
2019/09/06 Python
Django框架HttpRequest对象用法实例分析
2019/11/01 Python
用HTML5.0制作网页的教程
2010/05/30 HTML / CSS
英国品牌男装折扣网站:Brown Bag
2018/03/08 全球购物
我能否用void** 指针作为参数, 使函数按引用接受一般指针
2013/02/16 面试题
检查机关党的群众路线个人整改措施
2014/10/04 职场文书
优秀少先队辅导员事迹材料
2014/12/24 职场文书
房屋质量投诉书
2015/07/02 职场文书
仓库管理制度范本
2015/08/04 职场文书
礼貌问候语大全
2015/11/10 职场文书
公安干警正风肃纪心得体会
2016/01/15 职场文书
详解Java线程池是如何重复利用空闲线程的
2021/06/26 Java/Android
mybatis 获取无数据的字段不显示的问题
2021/07/15 Java/Android