使用POI实现JAVA操作Excel

news2024/11/24 21:06:12

Apache POI
POI提供API给JAVA程序对Microsoft Office格式档案读和写的功能

POI工具介绍

POI 是用Java编写的免费开源的跨平台的 Java API,Apache POI提供API给Java程式对Microsoft Office格式档案读和写的功能。主要是运用其中读取和输出excel的功能。

POI官网地址:

https://poi.apache.org/components/index.html

基本功能如下:

HSSF – 提供读写Excel格式(03)xls文件
XSSF – 提供读写Excel OOXML格式(07)xlsx文件
HWPF – 提供读写Word格式
HSLF – 提供读写PowerPoint格式
HDGF – 提供读写Visio格式
【注】03版本最多65535行,07版本的没有限制

可操作的文件类型

在这里插入图片描述

xls和xlsx的区别

xls是excel03版本 xlsx是excel07版本

最大的区别是行列数不同

xls最大支持65536行、256列
xlsx最大支持1048576行、16384列

poi操作

poi 操作xls
poi-ooml操作xlsx

POI - Excel写

步骤

1、导入依赖

<!-- excel工具 -->
<!--xls(03)-->
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi</artifactId>
            <version>4.1.2</version>
        </dependency>
        <!--xlsx(07)-->
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-ooxml</artifactId>
            <version>4.1.2</version>
        </dependency>
		<!-- 日期格式化工具 -->
		<dependency>
		    <groupId>joda-time</groupId>
		    <artifactId>joda-time</artifactId>
		    <version>2.12.1</version>
		</dependency>

2、编写代码

4个主要步骤:
创建工作簿 – 创建工作表 – 创建行 – 创建列

2.1、少量数据

import java.io.FileOutputStream;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import org.joda.time.DateTime;

/**
 * @author xxms
 */
public class ExcelWriteTest
{
	
    public static void main(String[] args) throws Exception {
    	POIExcel03();
    	POIExcel07();
	}
    
    public static void POIExcel03() throws Exception {
    	String PATH = "D:\\Study\\Back-end\\";
    	// 1、创建一个工作簿 03
    	Workbook workbook = new HSSFWorkbook();
    	// 2、创建一个工作表
    	Sheet sheet = workbook.createSheet("xxms观众统计表");
    	// 3、创建一个行
    	Row row1 = sheet.createRow(0);
    	// 4、创建一个单元格 (1,1)
    	Cell cell11 = row1.createCell(0);
    	cell11.setCellValue("今日新增观众");
    	// (1,2)
    	Cell cell12 = row1.createCell(1);
    	cell12.setCellValue(666);
    	
    	// 第二行
    	Row row2 = sheet.createRow(1);
    	//(2,1)
    	Cell cell21 = row2.createCell(0);
    	cell21.setCellValue("统计时间");
    	// (2,2)
    	Cell cell22 = row2.createCell(1);
    	String time = new DateTime().toString("yyyy-MM-dd HH:mm:ss");
    	cell22.setCellValue(time);
    	
    	// 生成一张表(IO流) 03版本就是使用xls结尾
    	FileOutputStream fileOutputStream = new FileOutputStream(PATH+"xxms观众统计表03.xls");
    	
    	workbook.write(fileOutputStream);
    	
    	// 关闭流
    	fileOutputStream.close();
    	
    	System.out.println("xxms观众统计表03 生成完毕");
    }
    
    public static void POIExcel07() throws Exception {
    	String PATH = "D:\\Study\\Back-end\\";
    	// 1、创建一个工作簿 07
    	Workbook workbook = new XSSFWorkbook();
    	// 2、创建一个工作表
    	Sheet sheet = workbook.createSheet("xxms观众统计表");
    	// 3、创建一个行
    	Row row1 = sheet.createRow(0);
    	// 4、创建一个单元格 (1,1)
    	Cell cell11 = row1.createCell(0);
    	cell11.setCellValue("今日新增观众");
    	// (1,2)
    	Cell cell12 = row1.createCell(1);
    	cell12.setCellValue(666);
    	
    	// 第二行
    	Row row2 = sheet.createRow(1);
    	//(2,1)
    	Cell cell21 = row2.createCell(0);
    	cell21.setCellValue("统计时间");
    	// (2,2)
    	Cell cell22 = row2.createCell(1);
    	String time = new DateTime().toString("yyyy-MM-dd HH:mm:ss");
    	cell22.setCellValue(time);
    	
    	// 生成一张表(IO流) 07版本就是使用xlsx结尾
    	FileOutputStream fileOutputStream = new FileOutputStream(PATH+"xxms观众统计表07.xlsx");
    	
    	workbook.write(fileOutputStream);
    	
    	// 关闭流
    	fileOutputStream.close();
    	
    	System.out.println("xxms观众统计表07 生成完毕");
    }
}

2.2大数据量导入

package com.ruoyi.common.core.controller;


import java.io.FileOutputStream;

import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import org.joda.time.DateTime;

/**
 * 
 * 
 * @author xxms
 */
public class ExcelWriteBigDataTest
{
	
    public static void main(String[] args) throws Exception {
    	POIExcel03BigData();
    	POIExcel07BigData();
	}
    
    public static void POIExcel03BigData() throws Exception {
    	
    	//时间
    	long begin = System.currentTimeMillis();
    	
    	String PATH = "D:\\Study\\Back-end\\";
    	// 1、创建一个工作簿 03
    	Workbook workbook = new HSSFWorkbook();
    	// 2、创建一个工作表
    	Sheet sheet = workbook.createSheet("xxms观众统计表");
    	// 3、写入数据
    	for(int rowNum=0;rowNum< 65536;rowNum++) {
    		Row row = sheet.createRow(rowNum);
    		for(int cellNum =0;cellNum<10;cellNum++) {
    			Cell cell = row.createCell(cellNum);
    			cell.setCellValue(cellNum);
    		}
    	}
    	
    	// 生成一张表(IO流) 03版本就是使用xls结尾
    	FileOutputStream fileOutputStream = new FileOutputStream(PATH+"xxms观众统计表03BigData.xls");
    	
    	workbook.write(fileOutputStream);
    	
    	// 关闭流
    	fileOutputStream.close();
    	
    	long end = System.currentTimeMillis();
    	System.out.println("xxms观众统计表03BigData 生成完毕,时间消耗:"+(double)(end-begin));
    }
    
    public static void POIExcel07BigData() throws Exception {
    	
    	long begin = System.currentTimeMillis();
    	
    	String PATH = "D:\\Study\\Back-end\\";
    	// 1、创建一个工作簿 07
    	Workbook workbook = new XSSFWorkbook();
    	// 2、创建一个工作表
    	Sheet sheet = workbook.createSheet("xxms观众统计表");
    	// 3、写入数据
    	for(int rowNum=0;rowNum< 65536;rowNum++) {
    		Row row = sheet.createRow(rowNum);
    		for(int cellNum =0;cellNum<10;cellNum++) {
    			Cell cell = row.createCell(cellNum);
    			cell.setCellValue(cellNum);
    		}
    	}
    	
    	// 生成一张表(IO流) 07版本就是使用xlsx结尾
    	FileOutputStream fileOutputStream = new FileOutputStream(PATH+"xxms观众统计表07BigData.xlsx");
    	
    	workbook.write(fileOutputStream);
    	
    	// 关闭流
    	fileOutputStream.close();
    	
    	long end = System.currentTimeMillis();
    	System.out.println("xxms观众统计表07BigData 生成完毕,时间消耗:"+(double)(end-begin));
    }
}

时间消耗对比如下:

xxms观众统计表03BigData 生成完毕,时间消耗:847.0
xxms观众统计表07BigData 生成完毕,时间消耗:3048.0

2.3大量数据优化

HSSF仅能保存65535行数据,
XSSF无限制但速度比较慢,
因此可以使用优化后的XSSF,即SXSSF(可以写非常大的数据量,如100万条甚至更多条,写数据速度快,占用更少的内存)
【注】会产生临时文件,需要清理临时文件(fileOutputStream.close();)(默认由100条记录被保存在内存中,如果超过这数量,则最前面的数据被写入临时文件,如果向自定义内存中数据的数量,可以使用new SXSSFWorkbook(数量)
代码如下:

public static void POIExcel07BigDataS() throws Exception {

		long begin = System.currentTimeMillis();

		String PATH = "D:\\Study\\Back-end\\";
		// 1、创建一个工作簿 07
		Workbook workbook = new SXSSFWorkbook();
		// 2、创建一个工作表
		Sheet sheet = workbook.createSheet("xxms观众统计表");
		// 3、写入数据
		for (int rowNum = 0; rowNum < 65536; rowNum++) {
			Row row = sheet.createRow(rowNum);
			for (int cellNum = 0; cellNum < 10; cellNum++) {
				Cell cell = row.createCell(cellNum);
				cell.setCellValue(cellNum);
			}
		}

		// 生成一张表(IO流) 07版本就是使用xlsx结尾
		FileOutputStream fileOutputStream = new FileOutputStream(PATH + "xxms观众统计表07BigDataS.xlsx");

		workbook.write(fileOutputStream);

		// 关闭流
		fileOutputStream.close();

		// 清除临时文件
		((SXSSFWorkbook) workbook).dispose();

		long end = System.currentTimeMillis();
		System.out.println("xxms观众统计表07BigDataS 生成完毕,时间消耗:" + (double) (end - begin));
	}

时间对比如下:

xxms观众统计表07BigData 生成完毕,时间消耗:2697.0
xxms观众统计表07BigDataS 生成完毕,时间消耗:806.0

POI - Excel读

1、编写代码

import java.io.FileInputStream;

import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;

public class ExcelReadTest {
	public static void main(String[] args) throws Exception {
		POIExcel03Read();
		POIExcel07Read();
	}

	public static void POIExcel03Read() throws Exception {
		String PATH = "D:\\Study\\Back-end\\";

		// 获取文件流
		FileInputStream inputStream = new FileInputStream(PATH + "xxms观众统计表03.xls");

		// 1、创建一个工作簿。使用excel能操作的这边他都可以操作
		Workbook workbook = new HSSFWorkbook(inputStream);
		// 2、得到表
		Sheet sheet = workbook.getSheetAt(0);
		// 3、得到行
		Row row = sheet.getRow(0);
		// 4、得到列
		Cell cell = row.getCell(0);

		// 获取字符串类型
		String value = cell.getStringCellValue();

		System.out.println("03版本的值:" + value);
		inputStream.close();
	}

	public static void POIExcel07Read() throws Exception {
		String PATH = "D:\\Study\\Back-end\\";

		// 获取文件流
		FileInputStream inputStream = new FileInputStream(PATH + "xxms观众统计表07.xlsx");

		// 1、创建一个工作簿。使用excel能操作的这边他都可以操作
		Workbook workbook = new XSSFWorkbook(inputStream);
		// 2、得到表
		Sheet sheet = workbook.getSheetAt(0);
		// 3、得到行
		Row row = sheet.getRow(0);
		// 4、得到列
		Cell cell = row.getCell(0);

		// 获取字符串类型
		String value = cell.getStringCellValue();

		System.out.println("07版本的值:" + value);
		inputStream.close();
	}
}

2、读取Excel中不同类型的数据

public static void POIExcelReadTestCellType() throws Exception {
		String PATH = "D:\\Study\\Back-end\\";

		// 获取文件流
		FileInputStream inputStream = new FileInputStream(PATH + "明细表.xlsx");

		// 1、创建一个工作簿。使用excel能操作的这边他都可以操作
		Workbook workbook = new XSSFWorkbook(inputStream);
		// 2、得到表
		Sheet sheet = workbook.getSheetAt(0);
		
		// 获取标题内容
		Row rowTitle = sheet.getRow(0);
		if(rowTitle!=null) {
			// 得到该行有多少列(一定要掌握)
			int cellCount = rowTitle.getPhysicalNumberOfCells();
			for(int cellNum = 0;cellNum<cellCount;cellNum++) {
				Cell cell = rowTitle.getCell(cellNum);
				if(cell!=null) {
					// 获取该单元格存储的数据是什么类型的
					CellType cellType = cell.getCellType();
					String cellValue = cell.getStringCellValue();
					System.out.print(cellValue +"|");
				}
			}
			System.out.println();
		}
		
		// 获取表中的内容
		// int rowCount = sheet.getLastRowNum() + 1; (范围更大)
		int rowCount = sheet.getPhysicalNumberOfRows();
		
		for(int rowNum = 1;rowNum<rowCount;rowNum++) {
			Row rowData = sheet.getRow(rowNum);
			if(rowData!=null) {
				// 得到该行有多少列(一定要掌握)
				int cellCount = rowTitle.getPhysicalNumberOfCells();
				for(int cellNum = 0;cellNum<cellCount;cellNum++) {
					System.out.print("["+(rowNum+1)+"-"+(cellNum+1)+"]");
					Cell cell = rowData.getCell(cellNum);
					if(cell!=null) {
						// 获取该单元格存储的数据是什么类型的
						CellType cellType = cell.getCellType();
						String cellValue= "";
						
						switch(cellType) {
							case STRING: //字符串
								System.out.print("【STRING】");
								cellValue = cell.getStringCellValue();
								break;
							case BOOLEAN: //布尔
								System.out.print("【BOOLEAN】");
								cellValue = String.valueOf(cell.getBooleanCellValue());
								break;
							case BLANK: //空
								System.out.print("【BLANK】");
								cellValue = cell.getStringCellValue();
								break;
							case NUMERIC: //数字(日期、普通数字)
								System.out.print("【NUMERIC】");
								if(DateUtil.isCellDateFormatted(cell)) { // 日期
									System.out.print("【日期】");
									Date date = cell.getDateCellValue();
									cellValue = new DateTime(date).toString("yyyy-MM-dd HH:mm:ss");
								}else {
									//不是日期格式,防止数字过长!
									System.out.print("【转换为字符串输出】");
									//这种用BigDecimal包装再获取plainString,可以防止获取到科学计数值
									BigDecimal bd = new BigDecimal(cell.getNumericCellValue());
				                    cellValue = bd.toPlainString();
									// 方法过期了
									// cell.setCellType(CellType.STRING);
									// cellValue = cell.toString();
								}
								break;
							case FORMULA: // 公式
				                cellValue = cell.getCellFormula();
							case ERROR: // 故障
				                cellValue = "ERROR VALUE";
				                break;
							default:
								cellValue = "UNKNOW VALUE";
								System.out.println("【数据类型错误】");
								break;
						}
						System.out.print(cellValue);
					}
					System.out.println();
				}
				
			}
		}
		inputStream.close();
	}

输出如下:

序号|卡号|持卡人|手机号|消费日期|小票号|商品编号|商品条码|商品名称|商品单位|原价|销售价|销售数量|销售金额|优惠金额|是否上架|
[2-1]【NUMERIC】【转换为字符串输出】1
[2-2]【NUMERIC】【转换为字符串输出】100088
[2-3]【STRING】张三
[2-4]【NUMERIC】【转换为字符串输出】1233333333333
[2-5]【NUMERIC】【日期】2020-04-21 00:00:00
[2-6]【NUMERIC】【转换为字符串输出】2392392093
[2-7]【STRING】PV92038038
[2-8]【STRING】PV98298392
[2-9]【STRING】蒙牛
[2-10]【STRING】瓶
[2-11]【NUMERIC】【转换为字符串输出】200.5
[2-12]【NUMERIC】【转换为字符串输出】1000
[2-13]【NUMERIC】【转换为字符串输出】1
[2-14]【NUMERIC】【转换为字符串输出】900
[2-15]【NUMERIC】【转换为字符串输出】100
[2-16]【BOOLEAN】true

3、计算公式

表格内容如下
在这里插入图片描述
代码如下

public static void POIExcelTestFormula() throws Exception{
		String PATH = "D:\\Study\\Back-end\\";

		// 获取文件流
		FileInputStream inputStream = new FileInputStream(PATH + "公式.xlsx");

		// 1、创建一个工作簿。使用excel能操作的这边他都可以操作
		Workbook workbook = new XSSFWorkbook(inputStream);
		// 2、得到表
		Sheet sheet = workbook.getSheetAt(0);
		
		Row row = sheet.getRow(4);
		Cell cell = row.getCell(0);
		
		//拿到计算公式 eval
		XSSFFormulaEvaluator xssfFormulaEvaluator = new XSSFFormulaEvaluator((XSSFWorkbook)workbook);
		
		//输出单元格的内容
		String cellFormula = cell.getCellFormula();
		System.out.println(cellFormula); //SUM(A2,A3,A4)
		
		//计算
		CellValue evaluate = xssfFormulaEvaluator.evaluate(cell);
		String cellValue = evaluate.formatAsString();
		
		System.out.println(cellValue);//600.0
	}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/639205.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

每日一练 | 华为认证真题练习Day57

1、两台路由器通过PPP链路互连&#xff0c;管理员在两台路由器上配置了OSPF&#xff0c;且运行在同一个区域中&#xff0c;如果它们的Router ID相同&#xff0c;则下面描述正确的&#xff08;&#xff09;。 A. 两台路由器将会建立正常的完全邻居关系 B. 两台路由器将不会互相…

看看苹果如何平衡Vision Pro性能和功耗

众所周知&#xff0c;Quest 2极为严格的控制SoC运行频率&#xff0c;目的就是保证整机的“散热性能”&#xff0c;说白了就是发热不能严重、风扇噪音不能大。这也是VR头戴设备中降低用户体验的两个关键指标。 对于Quest 2很直接的一个优势就是&#xff0c;用户大多时候听不到狂…

Javaweb学习路线(3)——SpringBoot入门、HTTP协议与Tomcat服务器

一、SpringBoot入门 &#xff08;一&#xff09;第一个Springboot案例 1、创建Springboot工程&#xff0c;添加依赖。 2、定义类&#xff0c;添加方法并添加注释 3、运行测试。 pom.xml&#xff08;框架自动生成&#xff09; <?xml version"1.0" encoding&quo…

linux上安装es、Kibana、ik分词

基本概念 ES是什么&#xff1f;我们可以把ES比作一个Mysql数据库&#xff0c;同样用来存储数据&#xff0c;不过比Mysql提供了更多的搜索功能,例如分词搜索&#xff0c;关联度搜索等&#xff0c;而且搜索速度也不是同一级别的&#xff0c; ES能够实现百万数据/秒的查询速度。接…

【Java|golang】1171. 从链表中删去总和值为零的连续节点

给你一个链表的头节点 head&#xff0c;请你编写代码&#xff0c;反复删去链表中由 总和 值为 0 的连续节点组成的序列&#xff0c;直到不存在这样的序列为止。 删除完毕后&#xff0c;请你返回最终结果链表的头节点。 你可以返回任何满足题目要求的答案。 &#xff08;注意…

Linux内核中内存管理相关配置项的详细解析9

接前一篇文章&#xff1a;Linux内核中内存管理相关配置项的详细解析8 十三、Enable recovery from hardware memory errors 对应配置变量为&#xff1a;CONFIG_MEMORY_FAILURE。 此项只有选中和不选中两种状态&#xff0c;默认为选中。 内核源码详细解释为&#xff1a; Enab…

HTML5 input元素新的特性

在HTML5中&#xff0c;<input>元素增加了许多新的属性、方法及控件。本文章分别对这三方面进行介绍。 目录 1. 属性 2. 方法 3. 新控件 1. 属性 <input>元素在HTML5中新增加的属性有&#xff1a;autocomplete 、autofocus、form、formaction、formenctype、f…

人工智能网站KameAI

人工智能网站KameAI 前言 人工智能的崛起与发展随着科技的飞速发展&#xff0c;人工智能(AI)已经逐渐成为我们生活中不可或缺的一部分。它的出现不仅改变了我们与世界的互动方式&#xff0c;还为各行各业带来巨大的便利。今天&#xff0c;我们就来聊一聊一个人工智能网站—Ka…

合并两个排序的链表

题目&#xff1a; 输入两个递增排序的链表&#xff0c;合并着两个链表并使新链表中的结点仍然是按照递增顺序的。例如输入的链表1和链表2如下&#xff0c;合并后的为链表3。链表的结点定义如下&#xff1a; struct ListNode {int value;ListNode *next; }; 复制 解题思路&…

APP性能测试,你需要关注哪些指标?

一、Android客户端性能测试常见指标 1、内存 2、CPU 3、流量 4、电量 5、启动速度 6、滑动速度、界面切换速度 7、与服务器交互的网络速度 二、预期标准指定原则 1、分析竞争对手的产品&#xff0c;所有指标要强于竞品 2、产品经理给出的预期性能指标数据 3、符合业…

Unity3D:Scene 视图导航

推荐&#xff1a;将 NSDT场景编辑器 加入你的3D工具链 3D工具集&#xff1a; NSDT简石数字孪生 Scene 视图导航 场景视图具有一组导航控件&#xff0c;可帮助您高效地四处移动&#xff1a; 场景视图辅助图标移动、旋转和缩放工具居中工具 场景视图辅助图标 场景辅助图标将显…

MySQL性能优化:索引优化

一、索引基础知识 &#xff08;一&#xff09;辅助索引/二级索引 叶子节点除了包含键值以外&#xff0c;每个叶子节点中的索引行中还包含了一个书签( bookmark) &#xff08;每个索引一颗B树&#xff0c;不包含行记录的全部数据&#xff09; &#xff08;二&#xff09; 回表…

docker-harbor私有仓库部署

什么是Harbor Harbor 是 VMware 公司开源的企业级 Docker Registry 项目&#xff0c;其目标是帮助用户迅速搭建一个企业级的 Docker Registry 服务。 Harbor以 Docker 公司开源的 Registry 为基础&#xff0c;提供了图形管理 UI 、基于角色的访问控制(Role Based AccessContr…

HTML5 语义元素(一)页面结构

本篇主要介绍HTML5增加的语义元素中关于页面结构方面的&#xff0c;包含&#xff1a; <article>、<aside>、<figure>、<figcaption>、<footer>、<header>、<main>、<nav>、<section>等元素。 目录 1. 语义元素介绍 1.…

01-SPA单页面的理解,它的优缺点分别是什么?如何实现SPA应用(了解))

文章目录 什么是SPA二、SPA和MPA的区别实现一个SPA1.引入库2.读入数据 总结 什么是SPA (single-page application),是一种网络应用程序或网站的模型&#xff0c;它通过动态重写当前页面来与用户交互&#xff0c;这种方法避免了页面之间切换打断用户体验,在单页应用中&#xff…

文心一言 VS 讯飞星火 VS chatgpt (39)-- 算法导论5.4 3题

三、在生日悖论的分析中&#xff0c;要求各人生日彼此独立是否很重要?或者&#xff0c;是否只要两两成对独立就足够了?证明你的答案。 文心一言&#xff1a; 在生日悖论的分析中&#xff0c;要求各人生日彼此独立是非常重要的。这是因为&#xff0c;如果各人生日不是独立的…

名号响亮的BBA,为什么在电车市场上“消失匿迹”了?

6月初&#xff0c;各大新能源车企公布了5月份的新车交付情况。整体来看&#xff0c;原本就“打得火热”的车市持续升温&#xff0c;多家车企月度销量环比涨幅超过10%&#xff0c;其中比亚迪更是拿出了超24万辆的“惊人表现”领跑市场。作为新势力的理想汽车&#xff0c;也打破单…

AntDB 企业增强特性介绍——同步异步自适应流复制

AntDB 提供了 hot-standby 的能力&#xff0c;功能与 Oracle 11g 的active standby 类似。并且通过流复制的方式&#xff0c;大大地缩短了备份库与主库的事务间隔。 传统流复制分为同步和异步两种模式。同步复制&#xff0c;即主机的事务要等到备机提交成功后才会提交并结束事…

2023-6-12-第三式单例模式

&#x1f37f;*★,*:.☆(&#xffe3;▽&#xffe3;)/$:*.★* &#x1f37f; &#x1f4a5;&#x1f4a5;&#x1f4a5;欢迎来到&#x1f91e;汤姆&#x1f91e;的csdn博文&#x1f4a5;&#x1f4a5;&#x1f4a5; &#x1f49f;&#x1f49f;喜欢的朋友可以关注一下&#xf…