MS SQL 查询结果再列转行

时间: 2023-12-31 20:04:39 浏览: 137
你可以使用 UNPIVOT 函数将 MS SQL 查询结果列转行。UNPIVOT 函数将多列的值转换为一列,并将每个值的列转换为一个新行。下面是一个示例查询,它将多列的值转换为一列: ``` SELECT Column1, Column2, Column3 FROM YourTable UNPIVOT ( Value FOR Attribute IN (Column2, Column3) ) AS UnpivotTable; ``` 在这个查询中,我们选择了三列数据 Column1、Column2 和 Column3,并使用 UNPIVOT 函数将 Column2 和 Column3 中的值转换为一列 Value,并将每个值的列转换为一个新行 Attribute。你可以根据自己的需要修改这个查询来适应你的数据。
相关问题

MS SQL 加条件查询结果再列转行

你可以在使用 UNPIVOT 函数将 MS SQL 查询结果列转行时添加条件。条件可以是任何适合你的列和值的 WHERE 子句,它将仅返回满足条件的行。下面是一个示例查询,它将多列的值转换为一列,并仅返回 Column2 中值为 'Value1' 的行: ``` SELECT Column1, Column2, Column3 FROM YourTable UNPIVOT ( Value FOR Attribute IN (Column2, Column3) ) AS UnpivotTable WHERE Attribute = 'Column2' AND Value = 'Value1'; ``` 在这个查询中,我们选择了三列数据 Column1、Column2 和 Column3,并使用 UNPIVOT 函数将 Column2 和 Column3 中的值转换为一列 Value,并将每个值的列转换为一个新行 Attribute。然后我们添加了一个 WHERE 子句,以仅返回 Attribute 等于 'Column2' 且 Value 等于 'Value1' 的行。你可以根据自己的需要修改这个查询来适应你的数据。

SQL 数据集 月份延展

<think>我们讨论的是如何将数据集按月份展开。按月份展开通常意味着将数据按月份分组,并将每个月份作为单独的列显示(即列转行或行转列),或者生成连续的月份序列来填补缺失的月份。根据引用[1]中的PIVOT示例,它实现了将月份作为列名,统计每个月份的数量。因此,如果用户想要将数据按月份展开为列,可以使用PIVOT或CASEWHEN方法。但是,用户的问题也可能是指生成连续的月份序列以填补缺失的月份(类似于之前讨论的填补缺失日期)。因此,我们需要考虑两种可能性:可能性1:将数据按月份进行透视(Pivot),将月份作为列,实现列转行(实际上是将行数据转换为列)。这适用于展示每个不同月份的数据统计值(如每个月的销售数量)。可能性2:生成一个连续的月份序列,并将原始数据与这个序列进行左连接,从而填补缺失的月份数据。由于用户提到“按月份进行扩展或展开”,并且引用[1]中提到了列转行(PIVOT),因此我们首先考虑可能性1。但是,如果用户想要的是填补缺失的月份,那么应该采用可能性2。我们再看引用[2]中提到了添加年、季度、月字段,引用[4]中提到了选择时间段(年、半年、季度、月份、日期),这些引用与时间维度有关。因此,我们将分两种情况讨论:1.使用PIVOT或CASEWHEN将月份作为列展开(即列转行)。2.生成连续月份序列以填补缺失的月份。由于用户没有明确是哪种,我们将分别说明。情况1:使用PIVOT将数据按月份展开(行转列)假设我们有一个销售数据表(sales_data),包含以下字段:-product_id:产品ID-sale_month:月份(格式为'YYYY-MM'或'MM',但引用[1]中是使用两位数字的月份字符串,如'01','02'等)-amount:销售金额我们想要将每个产品的销售数据按月份展开,即每一行代表一个产品,每一列代表一个月份的销售金额。使用PIVOT(在支持PIVOT的数据库,如SQLServer、Oracle等)的示例:```sqlSELECT*FROM(SELECTproduct_id,sale_month,amountFROMsales_data)ASsrcPIVOT(SUM(amount)--聚合函数FORsale_monthIN('01','02','03','04','05','06','07','08','09','10','11','12'))ASpvt```如果不支持PIVOT,可以使用CASEWHEN:```sqlSELECTproduct_id,SUM(CASEWHENsale_month='01'THENamountELSE0END)AS'01',SUM(CASEWHENsale_month='02'THENamountELSE0END)AS'02',--...其他月份SUM(CASEWHENsale_month='12'THENamountELSE0END)AS'12'FROMsales_dataGROUPBYproduct_id```情况2:生成连续月份序列,填补缺失月份如果我们有一组数据,但某些月份没有记录,我们希望生成一个连续的月份序列(例如从某年1月到12月),并将原始数据左连接到这个序列上,缺失的月份显示为0或NULL。生成连续月份序列的方法(以SQLServer为例,使用递归CTE):```sqlWITHmonthsAS(SELECT1ASmonth_numUNIONALLSELECTmonth_num+1FROMmonthsWHEREmonth_num<12)SELECTmonth_numFROMmonths```然后,我们可以将原始数据按月份分组,然后与这个序列进行左连接:```sqlWITHmonthsAS(SELECT1ASmonth_numUNIONALLSELECTmonth_num+1FROMmonthsWHEREmonth_num<12),monthly_salesAS(SELECTMONTH(sale_date)ASsale_month,SUM(amount)AStotal_amountFROMsales_dataWHEREYEAR(sale_date)=2024GROUPBYMONTH(sale_date))SELECTm.month_num,COALESCE(ms.total_amount,0)AStotal_amountFROMmonthsmLEFTJOINmonthly_salesmsONm.month_num=ms.sale_month```注意:这里假设我们只处理一年的数据。如果是跨年,则需要生成包括年份的连续日期。生成跨年份的连续月份(例如从2024-01到2025-12):```sqlDECLARE@startDATE='2024-01-01'DECLARE@endDATE='2025-12-01';WITHmonthsAS(SELECT@startASmonth_startUNIONALLSELECTDATEADD(MONTH,1,month_start)FROMmonthsWHEREDATEADD(MONTH,1,month_start)<=@end)SELECTmonth_startFROMmonths```然后,将原始数据按年、月分组,并与这个连续月份序列左连接。总结:用户的问题“SQL数据集按月份进行扩展或展开”可能有两种含义:1.将月份作为列展开(即列转行),使用PIVOT或CASEWHEN。2.生成连续月份序列,填补缺失月份,使用递归CTE或数字表生成序列,然后左连接。根据引用[1]的内容,用户可能更倾向于第一种(列转行)。但为了全面性,我们提供了两种方法。请用户根据实际需求选择合适的方法。相关问题:1.如何在SQL中进行行转列(PIVOT)操作?2.如何生成连续的时间序列(如月份)来填补缺失数据?3.在SQL中,如何将日期字段拆分为年、季度、月等部分?4.如何处理跨年份的连续月份生成?5.在行转列操作中,如果月份数据不完整(比如只有部分月份),如何显示所有12个月?</think>在SQL中实现数据集按月份展开,主要有两种核心方法:**透视表(PIVOT)** 和**日期序列生成**。以下是具体实现方案: ### 方法1:使用PIVOT实现月份列转行(适用于行列转换) 适用于将行数据中的月份值展开为列标题(如将销售数据按月展开为12列)。 ```sql -- SQL Server/Oracle语法示例 SELECT * FROM sales_data PIVOT ( SUM(sales_amount) -- 聚合函数 FOR sale_month IN ( -- 指定要展开的月份列 '01' AS Jan, '02' AS Feb, '03' AS Mar, '04' AS Apr, '05' AS May, '06' AS Jun, '07' AS Jul, '08' AS Aug, '09' AS Sep, '10' AS Oct, '11' AS Nov, '12' AS Dec ) ) AS pivot_table; ``` **关键点**: 1. 使用`PIVOT`语句将`sale_month`字段的值转换为列名 2. 通过聚合函数(如`SUM`/`COUNT`)计算每个单元格的值 3. 适用于支持`PIVOT`的数据库(SQL Server, Oracle等)[^1] ### 方法2:生成连续月份序列(适用于补全缺失月份) 当需要生成连续月份序列并补全缺失数据时: ```sql -- 通用SQL语法(递归CTE生成月份序列) WITH RECURSIVE month_series AS ( SELECT DATE_TRUNC('month', '2024-01-01'::DATE) AS month_start -- 起始月份 UNION ALL SELECT month_start + INTERVAL '1 month' FROM month_series WHERE month_start < DATE_TRUNC('month', CURRENT_DATE) -- 结束月份 ) SELECT TO_CHAR(ms.month_start, 'YYYY-MM') AS year_month, COALESCE(SUM(s.sales_amount), 0) AS total_sales -- 补全缺失值为0 FROM month_series ms LEFT JOIN sales_data s ON TO_CHAR(s.sale_date, 'YYYY-MM') = TO_CHAR(ms.month_start, 'YYYY-MM') GROUP BY ms.month_start; ``` **关键点**: 1. 使用递归CTE生成连续的月份起始日期 2. `DATE_TRUNC('month', ...)` 截取到月份精度 3. `LEFT JOIN`确保所有月份显示,即使无数据 4. `COALESCE`处理空值(如缺失月份显示为0)[^4] ### 特殊数据库实现方案 **Hive/Spark SQL**: ```sql -- 使用LATERAL VIEW展开序列 SELECT date_format(date_add('2024-01-01', pos), 'yyyy-MM') AS month, COALESCE(sales, 0) FROM ( SELECT posexplode(split(space(11), ' ')) AS (pos, x) -- 生成12个月 ) seq LEFT JOIN sales_data ON date_format(sale_date, 'yyyy-MM') = date_format(date_add('2024-01-01', pos), 'yyyy-MM') ``` **PostgreSQL**: ```sql -- 使用generate_series函数 SELECT TO_CHAR(month, 'YYYY-MM') AS year_month, COALESCE(SUM(sales_amount), 0) FROM generate_series( '2024-01-01'::DATE, '2024-12-01'::DATE, INTERVAL '1 month' ) AS month LEFT JOIN sales_data ON TO_CHAR(sale_date, 'YYYY-MM') = TO_CHAR(month, 'YYYY-MM') GROUP BY month; ``` ### 应用场景对比 | **场景** | **推荐方法** | **优势** | |------------------------|--------------------|----------------------------------| | 按月统计报表(行列转换) | PIVOT | 直接生成月份列,适合可视化 | | 补全缺失月份数据 | 递归CTE/LATERAL VIEW | 确保时间连续性,支持空值处理 | | 跨年数据处理 | 日期序列生成 | 自动处理年份切换,避免闰年问题 | > **提示**:处理前需确保日期字段格式统一,可使用`DATE_TRUNC`或`TO_CHAR`标准化为`YYYY-MM`格式[^2]。对性能敏感的大数据集,建议创建月份维度表。 --- ### 相关问题 1. 如何在SQL中动态生成全年12个月的月份序列? 2. 使用PIVOT时如何处理不存在的月份列? 3. 如何在不同数据库(MySQL/SQL Server/PostgreSQL)中标准化日期格式? 4. SQL中如何实现跨年度连续月份生成(如2023-12到2024-02)? 5. 对于没有递归CTE的数据库(如MySQL 5.7),如何生成月份序列?
阅读全文

相关推荐

pdf
内容概要:本文详细介绍了Maven的下载、安装与配置方法。Maven是基于项目对象模型(POM)的概念,用于项目管理和构建自动化的工具,能有效管理项目依赖、规范项目结构并提供标准化的构建流程。文章首先简述了Maven的功能特点及其重要性,接着列出了系统要求,包括操作系统、磁盘空间等。随后,分别针对Windows、macOS和Linux系统的用户提供了详细的下载和安装指导,涵盖了解压安装包、配置环境变量的具体操作。此外,还讲解了如何配置本地仓库和镜像源(如阿里云),以优化依赖项的下载速度。最后,给出了常见的错误解决方案,如环境变量配置错误、JDK版本不兼容等问题的处理方法。 适合人群:适用于初学者以及有一定经验的Java开发人员,特别是那些希望提升项目构建和依赖管理效率的技术人员。 使用场景及目标: ①帮助开发者掌握Maven的基本概念和功能特性; ②指导用户完成Maven在不同操作系统上的安装与配置; ③教会用户如何配置本地仓库和镜像源以加快依赖项下载; ④解决常见的安装和配置过程中遇到的问题。 阅读建议:由于Maven的安装和配置涉及多个步骤,建议读者按照文中提供的顺序逐步操作,并仔细检查每个环节的细节,尤其是环境变量的配置。同时,在遇到问题时,可参考文末提供的常见问题解决方案,确保顺利完成整个配置过程。
zip
资源下载链接为: https://pan.quark.cn/s/abbae039bf2a 旅行商问题(Traveling Salesman Problem, TSP)是一种经典的组合优化问题,目标是找到一条最短路径,让推销员访问一系列城市后返回起点,且每个城市只访问一次。该问题可以转化为图论问题,其中城市是节点,城市间的距离是边的权重。遗传算法是一种适合解决TSP这类NP难问题的全局优化方法,其核心是模拟生物进化过程,包括初始化、选择、交叉和变异等步骤。 初始化:生成初始种群,每个个体(染色体)表示一种旅行路径,通常用随机序列表示,如1到18的整数序列。 适应度计算:适应度函数用于衡量染色体的优劣,即路径总距离。总距离越小,适应度越高。 选择过程:采用轮盘赌选择机制,根据适应度以一定概率选择个体进入下一代,适应度高的个体被选中的概率更大。 交叉操作:一般采用单点交叉,随机选择交叉点,交换两个父代个体的部分基因段生成子代。 变异操作:采用均匀多点变异,随机选择多个点进行变异,变异点的新值在预设范围内随机生成,以维持种群多样性。 反Grefenstette编码:为确保解的可行性,需将变异后的Grefenstette编码转换回原始城市序列,即对交叉和变异结果进行反向处理。 迭代优化:重复上述步骤,直至满足终止条件,如达到预设代数或适应度阈值。 MATLAB是一种强大的数值和科学计算工具,非常适合实现遗传算法。通过编写源程序,可以构建遗传算法框架,处理TSP问题的细节,包括数据结构定义、算法流程控制以及适应度计算、选择、交叉和变异操作的实现。遗传算法虽不能保证找到最优解,但在小规模TSP问题中能提供不错的近似解。对于大规模TSP问题,可结合局部搜索、多算法融合等策略提升解的质量。在实际应用中,遗传算法常与其他优化方法结合,用于解决复杂的调度和路径规划问题。

最新推荐

recommend-type

SQL知识点之列转行Unpivot函数

在本篇文章中,我们将深入探讨SQL的Unpivot函数,以及如何使用它来实现列转行的操作。 首先,让我们回顾一下上一篇文章中提到的Pivot函数。Pivot函数是用于将数据的行转换为列,通常用于数据透视或汇总,使得特定的...
recommend-type

在SQL查询中使用LIKE来代替IN查询的方法

在SQL查询中,我们经常需要根据一组特定的ID来筛选数据,这时通常会使用`IN`操作符。例如,以下查询会返回`Orders`表中`OrderGUID`为指定值的记录: ```sql SELECT * FROM Orders WHERE OrderGUID IN('BC71D821-9E...
recommend-type

SQL查询字段被包含语句

在SQL查询中,当需要查找含有特定字段或字符串的数据时,`LIKE`关键字通常是首选工具。`LIKE`关键字配合通配符 `%` 可以帮助我们进行模糊匹配。例如,如果我们有一个`ConnectName`表,其中`name`字段存储着联系人的...
recommend-type

mybatis 实现 SQL 查询拦截修改详解

在MyBatis框架中,SQL查询拦截修改是一种高级特性,它允许开发者在SQL执行的特定阶段插入自定义的逻辑,如添加额外的日志记录、性能分析、安全性检查等。这主要是通过实现`Interceptor`接口来完成的。 `Interceptor...
recommend-type

SQL删除多列语句的写法

在SQL中,对数据库表结构进行修改是一项常见的任务,其中包括添加、删除或修改表的列。本篇文章将详细讲解如何使用SQL语句删除多列,特别关注在SQL Server环境下删除多列的正确方法。 首先,我们需要理解SQL Server...
recommend-type

cc65 Windows完整版发布:6502 C开发工具

cc65是一个针对6502处理器的完整C编程开发环境,特别适用于Windows操作系统。6502处理器是一种经典的8位微处理器,于1970年代被广泛应用于诸如Apple II、Atari 2600、NES(任天堂娱乐系统)等早期计算机和游戏机中。cc65工具集能够允许开发者使用C语言编写程序,这对于那些希望为这些老旧系统开发软件的程序员来说是一大福音,因为相较于汇编语言,C语言更加高级、易读,并且具备更好的可移植性。 cc65开发工具包主要包含以下几个重要组件: 1. C编译器:这是cc65的核心部分,它能够将C语言源代码编译成6502处理器的机器码。这使得开发者可以用高级语言编写程序,而不必处理低级的汇编指令。 2. 链接器:链接器负责将编译器生成的目标代码和库文件组合成一个单独的可执行程序。在6502的开发环境中,链接器还需要处理各种内存段的定位和映射问题。 3. 汇编器:虽然主要通过C语言进行开发,但某些底层操作仍然可能需要使用汇编语言来实现。cc65包含了一个汇编器,允许程序员编写汇编代码段。 4. 库和运行时:cc65提供了一套标准库,这些库函数为C语言提供了支持,并且对于操作系统级别的功能进行了封装,使得开发者能够更方便地进行编程。运行时支持包括启动代码、中断处理、内存管理等。 5. 开发工具和文档:除了基本的编译、链接和汇编工具外,cc65还提供了一系列辅助工具,如反汇编器、二进制文件编辑器、交叉引用器等。同时,cc65还包含丰富的文档资源,为开发者提供了详尽的使用指南、编程参考和示例代码。 cc65可以广泛用于学习和开发6502架构相关的软件,尤其适合那些对6502处理器、复古计算机或者早期游戏系统有兴趣的开发者。这些开发者可能想要创建或修改旧式游戏、系统软件、仿真器,或者进行技术研究和学习。 尽管cc65是一个功能强大的工具,但它也要求开发者对目标平台的硬件架构和操作系统有足够的了解。这是因为6502并非现代处理器,它对内存访问、I/O操作和中断管理等有着特殊的限制和要求。因此,使用cc65需要开发者具备一定的背景知识,包括但不限于6502指令集、内存映射、硬件寄存器操作等方面的内容。 此外,cc65针对Windows平台进行了优化和封装,使得它可以在Windows操作系统上无缝运行,这对于习惯于Windows环境的用户是一个好消息。不过,如果用户使用的是其他操作系统,可能需要通过相应的兼容层或虚拟机来运行Windows环境,以便使用cc65工具。 总的来说,cc65提供了一种相对简单的方式来开发运行在6502处理器上的软件。它极大地降低了开发难度,使得更多的人能够接触和参与到基于6502平台的软件开发中来,为这个历史悠久的平台注入了新的活力。
recommend-type

【CLIP模型实战】:从数据预处理到代码实现的图文相似度计算完全指南

# 1. CLIP模型概述 在人工智能领域中,CLIP(Contrastive Language-Image Pre-training)模型作为一款开创性的多模态学习技术,已经成为业界瞩目的焦点。CLIP模型是由OpenAI在2021年推出的,其创新之处在于通过大规模的图文对齐数据进行预训练,能够理解和匹配图像与自然语言描述之间的关联性。CLIP突破了传统方法在特定任务上需要大规模标注数据的限制
recommend-type

车载以太网doip协议格式

<think>首先,用户的问题是:“我想查找关于车载以太网DOIP协议的数据格式或规范”。用户引用了站内内容,其中提到DoIP是基于以太网的通讯协议,用于传输UDS协议的数据,规范于ISO13400标准。关键点:-DoIP协议:DiagnosticcommunicationoverInternetProtocol-规范:ISO13400标准-数据格式:我需要提供关于DoIP数据格式的详细信息根据系统级指令:-所有行内数学表达式使用$...$格式-独立公式使用$$...$$格式并单独成段-LaTeX语法正确-使用中文回答-生成相关问题-回答中引用的段落末尾自然地添加引用标识-回答结构清晰,帮助用
recommend-type

JavaScript中文帮助手册:初学者实用指南

### JavaScript中文帮助手册知识点概述 #### 1. JavaScript简介 JavaScript是一种轻量级的编程语言,广泛用于网页开发。它能够增强用户与网页的交互性,使得网页内容变得动态和富有生气。JavaScript能够操纵网页中的HTML元素,响应用户事件,以及与后端服务器进行通信等。 #### 2. JavaScript基本语法 JavaScript的语法受到了Java和C语言的影响,包括变量声明、数据类型、运算符、控制语句等基础组成部分。以下为JavaScript中常见的基础知识点: - 变量:使用关键字`var`、`let`或`const`来声明变量,其中`let`和`const`是ES6新增的关键字,提供了块级作用域和不可变变量的概念。 - 数据类型:包括基本数据类型(字符串、数值、布尔、null和undefined)和复合数据类型(对象、数组和函数)。 - 运算符:包括算术运算符、关系运算符、逻辑运算符、位运算符等。 - 控制语句:条件判断语句(if...else、switch)、循环语句(for、while、do...while)等。 - 函数:是JavaScript中的基础,可以被看作是一段代码的集合,用于封装重复使用的代码逻辑。 #### 3. DOM操作 文档对象模型(DOM)是HTML和XML文档的编程接口。JavaScript可以通过DOM操作来读取、修改、添加或删除网页中的元素和内容。以下为DOM操作的基础知识点: - 获取元素:使用`getElementById()`、`getElementsByTagName()`等方法获取页面中的元素。 - 创建和添加元素:使用`document.createElement()`创建新元素,使用`appendChild()`或`insertBefore()`方法将元素添加到文档中。 - 修改和删除元素:通过访问元素的属性和方法,例如`innerHTML`、`textContent`、`removeChild()`等来修改或删除元素。 - 事件处理:为元素添加事件监听器,响应用户的点击、鼠标移动、键盘输入等行为。 #### 4. BOM操作 浏览器对象模型(BOM)提供了独立于内容而与浏览器窗口进行交互的对象和方法。以下是BOM操作的基础知识点: - window对象:代表了浏览器窗口本身,提供了许多属性和方法,如窗口大小调整、滚动、弹窗等。 - location对象:提供了当前URL信息的接口,可以用来获取URL、重定向页面等。 - history对象:提供了浏览器会话历史的接口,可以进行导航历史操作。 - screen对象:提供了屏幕信息的接口,包括屏幕的宽度、高度等。 #### 5. JavaScript事件 JavaScript事件是用户或浏览器自身执行的某些行为,如点击、页面加载、键盘按键、鼠标移动等。通过事件,JavaScript可以对这些行为进行响应。以下为事件处理的基础知识点: - 事件类型:包括鼠标事件、键盘事件、表单事件、窗口事件等。 - 事件监听:通过`addEventListener()`方法为元素添加事件监听器,规定当事件发生时所要执行的函数。 - 事件冒泡:事件从最深的节点开始,然后逐级向上传播到根节点。 - 事件捕获:事件从根节点开始,然后逐级向下传播到最深的节点。 #### 6. JavaScript高级特性 随着ECMAScript标准的演进,JavaScript引入了许多高级特性,这些特性包括但不限于: - 对象字面量增强:属性简写、方法简写、计算属性名等。 - 解构赋值:可以从数组或对象中提取数据,赋值给变量。 - 模板字符串:允许嵌入表达式。 - 异步编程:Promise、async/await等用于处理异步操作。 - 模块化:使用`import`和`export`关键字导入和导出模块。 - 类和模块:引入了`class`关键字,允许使用面向对象编程风格定义类,以及模块的声明。 #### 7. 开发工具和调试技巧 为了提高JavaScript开发效率和调试问题,以下是一些常用的工具和调试技巧: - 浏览器的开发者工具:包括控制台(Console)、元素查看器(Elements)、网络监控(Network)、源码编辑器(Sources)等。 - 断点调试:在源码编辑器中设置断点,逐步执行代码,查看变量值和程序流程。 - console.log:在控制台输出日志,帮助理解程序执行流程和变量状态。 - 使用JavaScript验证工具:如JSHint、ESLint等,可以在开发过程中进行代码质量检查。 以上就是《JavaScript中文帮助手册》中可能包含的主要知识点。作为初学者,通过这些内容可以系统地学习和掌握JavaScript基础和进阶知识,实现从初学到实践的跨越。在实际应用中,还需结合具体实例和项目练习,不断加深理解和熟练操作。
recommend-type

深入理解MySQL存储引擎:InnoDB与MyISAM的终极对决

# 1. MySQL存储引擎概述 MySQL数据库的灵活性和高性能在很大程度上得益于其存储引擎架构。**存储引擎**是MySQL中用于存储、索引、查询数据的底层软件模块。不同的存储引擎拥有不同的功能和特性,允许数据库管理员针对特定的应用需求选择最佳的存储引擎。例如,**InnoDB**提供事务支持和行级锁定,适用于需要ACID(原子