postgresql 与 mysql 区别与联系_mysql和postgresql链接参数的不同-程序员宅基地

技术标签: postgresql  mysql  数据库  # postgresql数据库  

postgresql 与 mysql 区别与联系

1、事务

【psotgresql】
读已提交(Read committed)是PostgreSQL中的默认隔离级别

在这里插入图片描述
PostgreSQL 9.1 之前只有两种隔离级别 读已提交和串行化,串行化相当于现在版本的不可重复读

在PostgreSQL中,你可以请求四种标准事务隔离级别中的任意一种,但是内部只实现了三种不同的隔离级别,即PostgreSQL 的读未提交模式的行为和读已提交相同。这是因为把标准隔离级别映射到PostgreSQL的多版本并发控制架构的唯一合理的方法。
该表格也显示PostgreSQL 的可重复读实现不允许幻读

【mysql】
可重复读(Repeatable read)是MySQL的默认事务隔离级别,其他大多数数据库为读已提交。

2、索引

【psotgresql】
PostgreSQL提供了多种索引类型:B-tree、Hash、GiST、SP-GiST、GIN和BRIN。每一种索引类型使用了一种不同的算法来适应不同类型的查询。默认情况下, CREATE INDEX命令创建适合于大部分情况的B-tree索引
【mysql】
B-tree、hash、R-tree full-text
B树 哈希 R树 全文

3、锁

【psotgresql】

死锁是指两个(或多个)事务相互持有对方想要的锁。例如,如果事务1在表A上获得一个排他锁,同时试图获取一个在表B上的排他锁,而事务2已经持有表B的排他锁,同时却正在请求表A上的一个排他锁,那么两个事务就都不能进行下去。PostgreSQL能够自动检测到死锁情况并且会通过中断其中一个事务从而允许其它事务完成来解决这个问题(具体哪个事务会被中断是很难预测的,而且也不应该依靠这样的预测)。

防止死锁的最好方法通常是保证所有使用一个数据库的应用都以一致的顺序在多个对象上获得锁。在上面的例子里,如果两个事务以同样的顺序更新那些行,那么就不会发生死锁。我们也应该保证一个事务中在一个对象上获得的第一个锁是该对象需要的最严格的锁模式。如果我们无法提前验证这些,那么可以通过重试因死锁而中断的事务来即时处理死锁。

【mysql】

4、mvcc

oid
一行的对象标识符(对象ID)。该列只有在表使用WITH OIDS创建时或者default_with_oids配置变量被设置时才存在。该列的类型为oid(与列名一致),该类型详见第 8.18 节。
tableoid
包含这一行的表的OID。该列是特别为从继承层次(见第 5.9 节)中选择的查询而准备,因为如果没有它将很难知道一行来自于哪个表。tableoid可以与pg_class的oid列进行连接来获得表的名称。
xmin
插入该行版本的事务身份(事务ID)。一个行版本是一个行的一个特别版本,对一个逻辑行的每一次更新都将创建一个新的行版本。
cmin
插入事务中的命令标识符(从0开始)。
xmax
删除事务的身份(事务ID),对于未删除的行版本为0。对于一个可见的行版本,该列值也可能为非零。这通常表示删除事务还没有提交,或者一个删除尝试被回滚。
cmax
删除事务中的命令标识符,或者为0。
ctid
行版本在其表中的物理位置。注意尽管ctid可以被用来非常快速地定位行版本,但是一个行的ctid会在被更新或者被VACUUM FULL移动时改变。因此,ctid不能作为一个长期行标识符。OID或者最好是一个用户定义的序列号才应该被用来标识逻辑行。

扩招博客
【1】mysql 及 posgresql之优劣势大比拼
【2】PostgreSQL的元组、页面结构及索引查找原理
【3】PostgreSQL并发处理方式——MVCC
【4】PostgreSQL 的 MVCC 机制解析
【5】正确的理解MySQL的MVCC及实现原理

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/sinat_28809019/article/details/121489368

智能推荐

法语电话面试程序员面试问题和汇总-程序员宅基地

文章浏览阅读885次,点赞24次,收藏18次。法语电话面试程序员面试问题和汇总

全金属vivaldi天线设计----学习笔记_(1)vivaldi天线(ava)设计-程序员宅基地

文章浏览阅读1.1k次,点赞3次,收藏19次。全金属 Vivaldi 天线单元为宽频带单元,其在自由空间中孤立单元的特性与构成阵列的阵元的特性是不同的。_(1)vivaldi天线(ava)设计

springboot-开机自启功能实现-CommandLineRunner和ApplicationRunner_springboot 开机自启动-程序员宅基地

文章浏览阅读212次。区别:1.两个接口的实现方法一样,参数不一样,其他没什么区别。两个参数都可以接收java命令设置的参数及值2.ApplicationRunner接口的实现方法比CommandLineRunner接口的实现方法前执行(也可通过设置@Order决定谁先执行)作用:满足springBoot框架需要预加载数据需求,执行操作的时间是在容器启动末尾时间执行操作。_springboot 开机自启动

vsCode 快捷键-程序员宅基地

文章浏览阅读45次。记住常用的快捷键,对开发来说,简直是行云流水,心里无比顺畅。按 Press功能 FunctionCtrl + Shift + P,F1显示命令面板 Show Command PaletteCtrl + P快速打开 Quick OpenCtrl + Shift + N新窗口/实例 New window/instanceCtr...

Devin:全球首个AI程序员!自主学习,写代码,查bug!_devin ai-程序员宅基地

文章浏览阅读2k次,点赞30次,收藏22次。Devin:全球首个AI程序员!自主学习,写代码,查bug!_devin ai

Google Chrome 浏览器 119.0.6045.106 版本提示 STATUS_INVALID_IMAGE_HASH 崩溃_119.0.6045.106_chrome_installer-程序员宅基地

文章浏览阅读703次。我在网上找了几种,下面这个方式符合,能解决我的问题,就是在快捷方式的属性那里,找到目标给它添加。应用,然后确定之后打开浏览器,就能打开了,看到这个提示就说明配置成功。今天更新 Google Chrome 浏览器到。版本,然后访问页面不是空白,就是页面崩溃了。关闭 Chrome 沙箱。_119.0.6045.106_chrome_installer

随便推点

devops资料大全-程序员宅基地

文章浏览阅读652次。备份备份软件Amanda -客户端-服务器模型备份工具Bacula - 另一个客户端-服务器模型备份工具Backupninja -轻量级,可扩展的元数据备份系统Backuppc -客户端-服务器模型备份工具和文件共享方案。Burp -网络备份和还原程序Duplicity -使用rsync算法加密的带宽-效率备份Lsyncd -监控一个本地目录树的变..._devops 大全

Mysql 的字符编码机制、中文乱码问题及解决方案_mysql varbinary字段乱码-程序员宅基地

文章浏览阅读6.9k次,点赞3次,收藏9次。相信很多朋友都会对字符编码敬而远之,但一发生乱码问题却头大不已,本文结合前人的经验及Mysql手册中的解释,用具体的操作和例子,旨在了解mysql的字符编码机制以及乱码问题的解决。【问题现象】网页xxx.php用EditPlus另存为UTF8格式,MySQL在my.ini(linux系统中配置文件为my.cnf)里设置[ client ] 和 [ mysqld ] 都设置为_mysql varbinary字段乱码

java将json对象,数组传递给js函数_jinja 数组传给js-程序员宅基地

文章浏览阅读958次。本文将展示两个示例。第一个示例,通过java将json对象传递给js函数第二个示例, 将数组传递给js函数,js需要将其中个别位置的字节数组组合后再转回为10进制。例如,将数组第5和6位,转变为数字, 0xa1, 0x9F, 也就是线组成a19f,然后转换41375。package com.yq.jsdemo;import com.alibaba.fastjson.JSONObject;import lombok.extern.slf4j.Slf4j;import javax.scrip_jinja 数组传给js

postman 验证登录测试接口-程序员宅基地

文章浏览阅读1.7k次。在开发前端的项目的时候,要用到postman来进行接口测试,除了要正常的用户登录注册外,api接口测试时也有相应的验证,因为后台写到接口是在公司的服务器上,不能随便的进行访问,只有进行tonkin登录,并获取相应的tonkin值,在接口请求的时候带上这段验证的值,才有权限获取数据,1. 根据后台提供的postman登录接口,输入地址, 注意: 要根据后台提供登录接口是GET还是..._开发后端postman测试接口的时候注册接口可以用,登录接口显示密码错误

datatable js 按列筛选_datatable 自定义筛选-程序员宅基地

文章浏览阅读998次。1.按时间段查询效果图可以从查询时间那里按时间查询,也可以在搜索框那里按照时间查询,只能查询你输入的日期(是单个日期),注意,输入格式要和你表格中的时间的格式一致,否则查询不到数据jscreateTable();//把datatable 渲染到页面,从ajax获取到数据 如果是静态页面,数据是自己写到页面上的 用 var table = $('#dtQtNaireDrafts').DataTabl..._datatable.ext

C语言 文件操作4--文件结构体FILE的理解以及缓冲区再讲-程序员宅基地

文章浏览阅读79次。//文件结构体FILE的理解以及缓冲区再讲#include<stdio.h>#include<stdlib.h>//要点:文件结构//struct _iobuf {// char *_ptr; ------当前缓冲区内容指针// int _cnt; ------缓冲区还有多少字符// char *_base;..._4-2 c语言中,在成功打开一个文件后,可以使用 来获取文件缓冲区的file结构信息。

推荐文章

热门文章

相关标签