gball个人知识库
首页
基础组件
基础知识
算法&设计模式
  • 操作手册
  • 数据库
  • 极客时间
  • 每日随笔
  • 学习
  • 面试
  • 心情杂货
  • 实用技巧
  • 友情链接
  • 画图工具 (opens new window)
关于
  • 网盘 (opens new window)
  • 分类
  • 标签
  • 归档
项目
GitHub (opens new window)

ggball

后端界的小学生
首页
基础组件
基础知识
算法&设计模式
  • 操作手册
  • 数据库
  • 极客时间
  • 每日随笔
  • 学习
  • 面试
  • 心情杂货
  • 实用技巧
  • 友情链接
  • 画图工具 (opens new window)
关于
  • 网盘 (opens new window)
  • 分类
  • 标签
  • 归档
项目
GitHub (opens new window)
  • 面试

  • 数据库

    • mysql

      • mysql思维导图
      • 7全文索引
      • mysql导入导出
      • mysql服务
      • mysql基本语句
      • mysql之sql_mode
        • sql函数
        • 每年,每季,每月,每周的最后一天
        • 数据库小笔记
        • 重新认识mysql
        • mysql系统配置与启动选项
        • 字符集和比较规则
        • InnoDB记录结构
        • InnoDB数据页结构
        • B+树索引的由来
        • mysql之InnoDB数据目录结构
        • explain之访问方法
        • EXPLAIN 语句输出的各个列解释
        • mysql之InnoDB的BufferPool
        • mysql之事务
        • redo日志(上)
        • redo日志(下)
        • MVCC并发管理控制
        • undo log了解
      • pg

      • redis

    • linux

    • node

    • tensorFlow

    • 基础组件

    • 基础知识

    • 算法与设计模式

    • 分布式

    • 疑难杂症

    • go学习之旅

    • 极客时间

    • 知识库
    • 数据库
    • mysql
    ggball
    2021-08-30

    mysql之sql_mode

    # Msql的sql_mode修改

    # 问题复现

    今天突然发现MySQL服务器升级之后sql_mode变成宽松摸索了,危害如下: img

    # 临时解决

    set global sql_mode='strict_trans_tables'(阿里服务器默认是:strict_trans_tables) img

    # 重启失效验证

    上面这种方式在MySQL重启后就会失效,想要永久生效还得联系运维工程师,eg: img

    # 配置文件

    PS:为了防止再出现升级后SQL_Mode改变,以后在配置文件中设置SQL_Mode img

    img

    # 知识点

    • SQL Model

      :定义MySQL对约束的响应行为:

      • 会话修改:

        • mysql> set [session] sql_model='xx_mode'
        • mysql> set @@session.sql_mode='xx_mode'
        • PS:只在当前会话生效
      • 全局修改:需要有权限,并且不会立即生效,对以后新建的会话生效(从全局继承的)

        • mysql> set global sql_mode='xx_mode'
        • mysql> set @@global.sql_mode='xx_mode'
        • PS:MySQL重启后失效
      • 配置修改:永远生效:

        • eg:vi /etc/my.cnf,在[mysqld]下添加sql_mode='xx',然后重启数据库

        • PS:从MySQL8开始,可通过

          set persist
          
          1

          命令将全局变量的修改持久化到配置文件中

          • 持久化到/var/lib/mysql/mysqld-auto.cnf配置文件中
          • eg:set persist log_timestamps='SYSTEM';(需要root权限)
      • 常用mode

        :(阿里服务器默认是:

        strict_trans_tables
        
        1

        )

        • traditional:使用传统模型,不允许对非法值做插入操作

        • strict_all_tables:对所有表做严格约束

        • strict_trans_tables:对所有支持事物类型的表做严格约束

          :

          • PS:最常见,主要对事物型的存储引擎生效,其他的没效果(如果插入数据不符合规范,则中断当前操作)
        • no_engine_substitution:建表的时候指定不可用存储引擎会报错

        • only_full_group_by

          :检验

          group by
          
          1

          语句的合法性

          • 要求在在分组查询语句中,把所有没有使用聚合函数的列,列出来

          • eg:

            select count(url),name from file_records group by url;
            
            1
            • 使用了name字段,name不是聚合函数,那必须在group by中写一下
        • PS:生存环境下最好不要修改,容易报错对业务产生影响(严格变宽松没事)

        • 查询当前设置:select @@sql_mode

    博客转发 (opens new window))

    上次更新: 2025/06/04, 15:06:15
    mysql基本语句
    sql函数

    ← mysql基本语句 sql函数→

    最近更新
    01
    AIIDE
    03-07
    02
    githubActionCICD实战
    03-07
    03
    windows安装Deep-Live-Cam教程
    08-11
    更多文章>
    Theme by Vdoing
    总访问量 次 | 总访客数 人
    | Copyright © 2021-2025 ggball | 赣ICP备2021008769号-1
    • 跟随系统
    • 浅色模式
    • 深色模式
    • 阅读模式
    ×

    评论

    • 评论 ssss
    • 回复
    • 评论 ssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssss
    • 回复
    • 评论 ssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssss
    • 回复
    ×