workbench(mysql、sqlServer)执行SQL脚本时遇到的问题(持续更新)

本文档记录了在使用MySQL和SQLServer执行脚本时遇到的两种常见错误及其解决方法。第一种是由于开启GTID一致性导致的'CREATE TABLE...SELECT'语句执行失败,解决方法包括关闭GTID一致性或者将语句拆分为两个独立步骤。第二种是在安全更新模式下尝试更新无主键条件的表,错误码1175,解决方法是禁用安全更新模式或修改SQL语句确保使用主键作为更新条件。
摘要由CSDN通过智能技术生成

这里记录mysql、sqlServer脚本执行遇到的各种问题,方便追溯

解决:Statement violates GTID consistency: CREATE TABLE … SELECT. 0.000 sec

1、情况描述

在执行sql:create table 表A as select * from 表B时,发现sql执行后,并未生成新的表,而是提示Statement violates GTID consistency: CREATE TABLE … SELECT.

2、问题分析

MySQL5.6及以上的版本,开启了 enforce_gtid_consistency=true 功能导致的,MySQL官方解释说当启用 enforce_gtid_consistency 功能的时候,MySQL只允许能够保障事务安全,并且能够被日志记录的SQL语句被执行,像create table … select 和 create temporarytable语句,以及同时更新事务表和非事务表的SQL语句或事务都不允许执行。

3、解决方法

方法一(推荐):
执行命令 :SET @@GLOBAL.ENFORCE_GTID_CONSISTENCY = off;
或在配置文件中 :ENFORCE_GTID_CONSISTENCY = off;

方法二:
create table 表A as select 表B 的方式会拆分成两部分:

create table 表A like 表B ;
insert into 表A select *from 表B ;

解决:Error Code: 1175. You are using safe update mode and you tried to update a table without a WHERE that uses a KEY column.

1、情况描述

在workbench执行delete from table where ...的脚本时,报错:Error Code: 1175. You are using safe update mode and you tried to update a table without a WHERE that uses a KEY column.
To disable safe mode, toggle the option in Preferences -> SQL Editor and reconnect. 0.047 sec

2、原因

在mysql的safe-updates模式中,如果where后跟的条件不是主键,就会出现这种错误。

3、解决方案

方法一(推荐):
执行命令:SET SQL_SAFE_UPDATES = 0;
然后在重新执行一遍你要删除的内容。

方法二:
调整sql,where条件中加入主键

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值