mysql如何存储boolean类型

MySQL没有内置的boolean数据类型。存储布尔值(true/false)的最佳方式是使用 TINYINT(1) 类型。在该类型中,1 代表 TRUE0 代表 FALSE。虽然可以使用 BOOLEAN 关键字,但MySQL会将其自动转换为 TINYINT(1)

详细操作指南

  1. 建表定义

    使用 TINYINT(1)BOOLEAN(会被自动转换)。

    sql

    sql 复制代码
    CREATE TABLE example (
        id INT PRIMARY KEY,
        is_active TINYINT(1) -- 推荐
        -- or is_active BOOLEAN (会被转换成TINYINT(1))
    );
  2. 插入数据

    直接使用 TRUE/FALSE 关键字,或数字 1/0

    sql

    sql 复制代码
    INSERT INTO example (id, is_active) VALUES (1, TRUE);
    INSERT INTO example (id, is_active) VALUES (2, 0);
  3. 查询数据

    查询结果仍为数字0或1。

    sql

    sql 复制代码
    SELECT * FROM example WHERE is_active = 1; -- 查询为true的记录

关键点与注意事项

  • 兼容性TRUEFALSE 是常量,分别等价于 10
  • ORM映射 :在Java (Hibernate/MyBatis) 中,TINYINT(1) 通常映射为 Boolean 类型,即 1 -> true0 -> false
  • 为什么是TINYINT(1) :虽然 TINYINT 可以存储 -128 到 127,但 TINYINT(1) 的设计初衷是为了明确表示这是一个布尔值字段。
相关推荐
葫芦和十三2 小时前
图解 MongoDB 21|选举与 failover:Primary 是怎么选出来的
后端·mongodb·agent
GetcharZp2 小时前
26k Star 开源内网穿透神器 NetBird,一分钟实现全球设备互联!
后端
考虑考虑3 小时前
Mybatis实现批量插入
java·后端·mybatis
咖啡八杯4 小时前
GoF设计模式——中介者模式
java·后端·spring·设计模式
lizhongxuan6 小时前
多Agent之间的区别
后端
杨充8 小时前
1.面向对象设计思想
后端
IT_陈寒8 小时前
Java的Date类又坑了我一次,改用时间戳真香
前端·人工智能·后端
systemPro9 小时前
2.6亿条设备数据,历史查询从超时到50ms,我做了什么
后端
要阿尔卑斯吗9 小时前
提示词优化启示:为什么“按顺序输出“比“关键度评分“更有效
后端
她的男孩10 小时前
后台接口加密别只会 HTTPS,ForgeAdmin 的 RSA + SM4/AES 源码拆解
后端·面试·开源