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

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

相关文章

Python调用Orator ORM进行数据库操作

《Python调用OratorORM进行数据库操作》OratorORM是一个功能丰富且灵活的PythonORM库,旨在简化数据库操作,它支持多种数据库并提供了简洁且直观的API,下面我们就... 目录Orator ORM 主要特点安装使用示例总结Orator ORM 是一个功能丰富且灵活的 python O

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

Python如何计算两个不同类型列表的相似度

《Python如何计算两个不同类型列表的相似度》在编程中,经常需要比较两个列表的相似度,尤其是当这两个列表包含不同类型的元素时,下面小编就来讲讲如何使用Python计算两个不同类型列表的相似度吧... 目录摘要引言数字类型相似度欧几里得距离曼哈顿距离字符串类型相似度Levenshtein距离Jaccard相

在不同系统间迁移Python程序的方法与教程

《在不同系统间迁移Python程序的方法与教程》本文介绍了几种将Windows上编写的Python程序迁移到Linux服务器上的方法,包括使用虚拟环境和依赖冻结、容器化技术(如Docker)、使用An... 目录使用虚拟环境和依赖冻结1. 创建虚拟环境2. 冻结依赖使用容器化技术(如 docker)1. 创

关于Spring @Bean 相同加载顺序不同结果不同的问题记录

《关于Spring@Bean相同加载顺序不同结果不同的问题记录》本文主要探讨了在Spring5.1.3.RELEASE版本下,当有两个全注解类定义相同类型的Bean时,由于加载顺序不同,最终生成的... 目录问题说明测试输出1测试输出2@Bean注解的BeanDefiChina编程nition加入时机总结问题说明

java父子线程之间实现共享传递数据

《java父子线程之间实现共享传递数据》本文介绍了Java中父子线程间共享传递数据的几种方法,包括ThreadLocal变量、并发集合和内存队列或消息队列,并提醒注意并发安全问题... 目录通过 ThreadLocal 变量共享数据通过并发集合共享数据通过内存队列或消息队列共享数据注意并发安全问题总结在 J

使用Navicat工具比对两个数据库所有表结构的差异案例详解

《使用Navicat工具比对两个数据库所有表结构的差异案例详解》:本文主要介绍如何使用Navicat工具对比两个数据库test_old和test_new,并生成相应的DDLSQL语句,以便将te... 目录概要案例一、如图两个数据库test_old和test_new进行比较:二、开始比较总结概要公司存在多

MySQL数据库函数之JSON_EXTRACT示例代码

《MySQL数据库函数之JSON_EXTRACT示例代码》:本文主要介绍MySQL数据库函数之JSON_EXTRACT的相关资料,JSON_EXTRACT()函数用于从JSON文档中提取值,支持对... 目录前言基本语法路径表达式示例示例 1: 提取简单值示例 2: 提取嵌套值示例 3: 提取数组中的值注意

Java文件与Base64之间的转化方式

《Java文件与Base64之间的转化方式》这篇文章介绍了如何使用Java将文件(如图片、视频)转换为Base64编码,以及如何将Base64编码转换回文件,通过提供具体的工具类实现,作者希望帮助读者... 目录Java文件与Base64之间的转化1、文件转Base64工具类2、Base64转文件工具类3、

查询SQL Server数据库服务器IP地址的多种有效方法

《查询SQLServer数据库服务器IP地址的多种有效方法》作为数据库管理员或开发人员,了解如何查询SQLServer数据库服务器的IP地址是一项重要技能,本文将介绍几种简单而有效的方法,帮助你轻松... 目录使用T-SQL查询方法1:使用系统函数方法2:使用系统视图使用SQL Server Configu