【实用】mysql配置 及将线上数据导入本地 问题解决及记录

[ERR] 1292 - Incorrect datetime value: '0000-00-0000:00:00' for column 'BIRTH_DATE' at row 1

此问题是mysql当前配置不支持日期为空,或者为'0000-00-0000:00:00'得情况

1、直接在数据库执行

复制代码
# 修改全局
set @@global.sql_mode = 'ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';
# 修改当前
set @@sql_mode = 'ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';

2、然后刷新,重新连接数据库,就解决问题了

出现这种情况就是:数据库不支持Datetime为0的情况,更换一下模式就可以了

也可以配置到mysql.ini下(windows)

执行报错Unknown error 3065。

mysql中distinct和order by 一起用时,order by的字段必须在select中
mysql 5.7.14

SELECT DISTINCT evt_tim FROM evt_etl ORDER BY evt_id ASC;
执行报错Unknown error 3065。

因为找不到3065错误的详细信息,因此做了一下测试:

- 1.SELECT DISTINCT evt_id FROM evt_etl ORDER BY evt_id ASC;

- 2.SELECT DISTINCT evt_tim,evt_id FROM evt_etl ORDER BY evt_id ASC;

- 3.SELECT evt_tim FROM evt_etl ORDER BY evt_id ASC;
1,2,3 这三条语句均执行正确。

mysql distinct和order by 一起用时,order by的字段必须在select中。

网上查了一下资料,原因总结如下:

首先,在mysql中distinct 的执行顺序高于order by。
第二,distinct执行时会对查询的记录进行去重,产生一张虚拟的临时表;
第三,order by执行时对查询的虚拟临时表进行排序,产生新的虚拟临时表。
综合来看,如果order by的字段不在select中,执行sql语句时首先执行distinct,之后产生的虚拟临时表中没有order by的字段,所以再执行order by时会报错。

解决方法

检查mysql中是否设置了这个

复制代码
sql_mode=STRICT_TRANS_TABLES

<p>这个错误信息通常出现在 MySQL 中,它表示 MySQL 配置文件中没有定义 <code>sql_mode</code> 参数,或者您的 MySQL 版本不支持它。<code>sql_mode</code> 参数用于控制 MySQL 在执行查询时的行为。具体来说,<code>NO_ENGINE_SUBSTITUTION</code> 参数会禁止 MySQL 在找不到指定的存储引擎时使用默认存储引擎进行替换,而 <code>STRICT_TRANS_TABLES</code> 参数会启用严格的事务模式,不允许插入无效的数据。</p>

STRICT_TRANS_TABLES</code> 参数会启用严格的事务模式

实际上就是sql写得不规范时,mysql是严格模式时某些sql就会报错

但是mysql没有设置该模式或是其它模式时,这些sql正常

由于生产没有启用该模式,所以这里也去掉该设置,测试环境运行正常

相关推荐
晋阳十二夜5 小时前
【压力测试之_Jmeter链接Oracle数据库链接】
数据库·oracle·压力测试
GDAL6 小时前
Node.js v22.5+ 官方 SQLite 模块全解析:从入门到实战
数据库·sqlite·node.js
DCTANT7 小时前
【原创】国产化适配-全量迁移MySQL数据到OpenGauss数据库
java·数据库·spring boot·mysql·opengauss
程序员岳焱9 小时前
Java 与 MySQL 性能优化:MySQL全文检索查询优化实践
后端·mysql·性能优化
喜欢敲代码的程序员9 小时前
SpringBoot+Mybatis+MySQL+Vue+ElementUI前后端分离版:项目搭建(一)
spring boot·mysql·elementui·vue·mybatis
AI、少年郎9 小时前
Oracle 进阶语法实战:从多维分析到数据清洗的深度应用(第四课)
数据库·oracle
赤橙红的黄9 小时前
自定义线程池-实现任务0丢失的处理策略
数据库·spring
钢铁男儿10 小时前
C# 委托(调用带引用参数的委托)
java·mysql·c#
叁沐10 小时前
MySQL 02 日志系统:一条SQL更新语句是如何执行的?
mysql
DataGear10 小时前
如何在DataGear 5.4.1 中快速制作SQL服务端分页的数据表格看板
javascript·数据库·sql·信息可视化·数据分析·echarts·数据可视化