认知幻像:在不同数据库之间迁移时,总有些什么改变了?

2024-01-13 08:59

本文主要是介绍认知幻像:在不同数据库之间迁移时,总有些什么改变了?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

当我们在不同数据库之间迁移时,总有一些认知幻像,下意识的以为,某些事应该还是那样

但是事实上,有些事情永远的改变了,我们需要认识到这些变化,并且刷新认知。

最近有朋友在“云和恩墨大讲堂”的微信群提出了一个这样的问题,以下SQL的输出结果是什么?

create table enmotest (a int, b int );

insert into enmotest values(1,1);

update enmotest set a=a+1,b=b+a;

select * from enmotest;

要想回答这个问题,首先要跳出自我熟悉的认知,例如,Oracle 和 MySQL DBA看到的答案可能完全不同。而两者又很可能不熟悉另外一种数据库的工作原理,甚至缺少触手可得的验证环境。

现在借助墨天轮的 SQLRUN 工具,一切都非常简单,尝鲜地址:

        https://modb.pro/sqlrun

我们验证一下不同数据库的表现。

1. Oracle 数据库,对于 Oracle 开发者很熟悉,结果可想而知是 (2,2)

06bf23d3ee1f7568ac4459cda04f7247.png

2. MogDB 数据库,和O表达相同,结果是 (2,2)

5c66b90f1cf6841abbe1e35621ce85c4.png

3. MySQL 数据库,这会让Oracle开发者惊讶,结果是(2,3)

37f9a9edde3cc3c75017aeb6a0d6fc7e.png

4. OceanBase 数据库,表达和 MySQL 一致,结果是(2,3)

e44c151e1dae0392d337713db9638fd0.png

在国产数据库的替代过程中,开发者也一定要深入了解不同数据库的细微差异,以避免因为简单的疏忽而产生严重的生产事故。

2023 数据技术嘉年华大会,将会在4.7 ~ 4.8 北京开幕,大会特设数据迁移专场,欢迎接受我的赠票邀请(扫码),共享数据库技术盛会,免费报名链接:

https://modb.pro/event/804/395289

对于上面的用例,通过 MySQL 的 Binlog 日志,还可以进一步审视后台的工作逻辑。

#230331 11:20:52 server id 1  end_log_pos 975 CRC32 0x67f56d5b  Update_rows: table id 95 flags: STMT_END_F

### UPDATE `enmotech`.`enmotest`

### WHERE

###   @1=1

###   @2=1

### SET

###   @1=2

###   @2=3

# at 975

#230331 11:20:52 server id 1  end_log_pos 1006 CRC32 0x72b8ef24         Xid = 31

这就是 MySQL 的工作原理,在手册上有这样一段说明:

> Single-table UPDATE assignments are generally evaluated from left to right. For multiple-table updates, there is no guarantee that assignments are carried out in any particular order.

> If you set a column to the value it currently has, MySQL notices this and does not update it.

MySQL 单表更新赋值,通常是从左到右计算,这样先完成的计算结果就会影响后面的计算。对于多表更新,不保证按任何特定的顺序执行分配。

如果 update 赋值前后的结果不变, MySQL 不会执行update, 所以不能通过SQL影响行数来判断业务逻辑的执行情况。

这些行为都和Oracle完全不同


云和恩墨大讲堂 | 一个分享交流的地方

长按,识别二维码,加入万人交流社群

请备注:云和恩墨大讲堂

  点个“在看” 

你的喜欢会被看到❤

这篇关于认知幻像:在不同数据库之间迁移时,总有些什么改变了?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/600919

相关文章

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

SpringBoot实现不同接口指定上传文件大小的具体步骤

《SpringBoot实现不同接口指定上传文件大小的具体步骤》:本文主要介绍在SpringBoot中通过自定义注解、AOP拦截和配置文件实现不同接口上传文件大小限制的方法,强调需设置全局阈值远大于... 目录一  springboot实现不同接口指定文件大小1.1 思路说明1.2 工程启动说明二 具体实施2

如何通过try-catch判断数据库唯一键字段是否重复

《如何通过try-catch判断数据库唯一键字段是否重复》在MyBatis+MySQL中,通过try-catch捕获唯一约束异常可避免重复数据查询,优点是减少数据库交互、提升并发安全,缺点是异常处理开... 目录1、原理2、怎么理解“异常走的是数据库错误路径,开销比普通逻辑分支稍高”?1. 普通逻辑分支 v

Python与MySQL实现数据库实时同步的详细步骤

《Python与MySQL实现数据库实时同步的详细步骤》在日常开发中,数据同步是一项常见的需求,本篇文章将使用Python和MySQL来实现数据库实时同步,我们将围绕数据变更捕获、数据处理和数据写入这... 目录前言摘要概述:数据同步方案1. 基本思路2. mysql Binlog 简介实现步骤与代码示例1

使用shardingsphere实现mysql数据库分片方式

《使用shardingsphere实现mysql数据库分片方式》本文介绍如何使用ShardingSphere-JDBC在SpringBoot中实现MySQL水平分库,涵盖分片策略、路由算法及零侵入配置... 目录一、ShardingSphere 简介1.1 对比1.2 核心概念1.3 Sharding-Sp

Go语言连接MySQL数据库执行基本的增删改查

《Go语言连接MySQL数据库执行基本的增删改查》在后端开发中,MySQL是最常用的关系型数据库之一,本文主要为大家详细介绍了如何使用Go连接MySQL数据库并执行基本的增删改查吧... 目录Go语言连接mysql数据库准备工作安装 MySQL 驱动代码实现运行结果注意事项Go语言执行基本的增删改查准备工作

Python Flask实现定时任务的不同方法详解

《PythonFlask实现定时任务的不同方法详解》在Flask中实现定时任务,最常用的方法是使用APScheduler库,本文将提供一个完整的解决方案,有需要的小伙伴可以跟随小编一起学习一下... 目录完js整实现方案代码解释1. 依赖安装2. 核心组件3. 任务类型4. 任务管理5. 持久化存储生产环境

MySQL 数据库表操作完全指南:创建、读取、更新与删除实战

《MySQL数据库表操作完全指南:创建、读取、更新与删除实战》本文系统讲解MySQL表的增删查改(CURD)操作,涵盖创建、更新、查询、删除及插入查询结果,也是贯穿各类项目开发全流程的基础数据交互原... 目录mysql系列前言一、Create(创建)并插入数据1.1 单行数据 + 全列插入1.2 多行数据

MySQL 数据库表与查询操作实战案例

《MySQL数据库表与查询操作实战案例》本文将通过实际案例,详细介绍MySQL中数据库表的设计、数据插入以及常用的查询操作,帮助初学者快速上手,感兴趣的朋友跟随小编一起看看吧... 目录mysql 数据库表操作与查询实战案例项目一:产品相关数据库设计与创建一、数据库及表结构设计二、数据库与表的创建项目二:员

MybatisPlus中removeById删除数据库未变解决方案

《MybatisPlus中removeById删除数据库未变解决方案》MyBatisPlus中,removeById需实体类标注@TableId注解以识别数据库主键,若字段名不一致,应通过value属... 目录MyBATisPlus中removeBypythonId删除数据库未变removeById(Se