数据库小技能:Oracle基础【中篇】

简介: 提高数据库运行效率的方法:从数据库系统级优化、数据库设计级优化和程序实现级优化。

引言

QPS: 请求进入的速度
并发数: 系统中同时存在的请求数
并发数 = QPS * 耗时

I 锁

什么是锁?
锁(lock)机制用于管理对共享资源的并发访问。

1.1 锁定数据行

for update for update nowait 是对操作的数据行进行加,在事务提交前防止其他操作对数据的修改。

锁定了emp表中id=1的那行数据
select * from emp  where emp.id=1 for update nowait
--通过for update锁定后,这些行不能修改了,但是还可以查询。
--for  update wait n (n是时间,单位:秒),即会等待n秒。
  • 使用for update锁定行,对这行执行update,delete,select , for update语句都会阻塞,即等待锁的释放后继续执行。
  • 使用for update nowait锁定行,对这行执行update,delete,select , for update语句,会马上返回一个“ORA-00054:resource busy”错误,不用一直等待锁的释放后继续执行.

1.2 锁类型

  1. DML锁:用于确保一次只能修改某一行,而且别人不能删除你正在处理的表, DML锁包括
  • 事务锁(TX锁),事务发起第一个修改时会得到TX锁,而且会一直持有这个锁,直至事务commit或者rollback
  • DML Enqueue (TM)锁:用于确保在修改表的数据时,表的结构不会改变,当更新了一个表的数据时,你就会得到这张表的一个TM锁
  1. DDL锁:DDL操作过程中会自动为对象加DDL锁,保护这些对象不会被其它会话修改。
  2. latch:轻量级的串行化设备,用于协调对共享数据结构、对象和文件的多用户访问。 这是Oracle的内部锁,用于协调对其共享数据结构的访问,Latch用于保护某些内存结构,如数据库快缓冲区或共享池中的库缓存。
  3. 乐观锁: 给表加一个version字段,保存数据行的版本。查询时,得到version的值,假设为100。通过类型下面语句保存
   update emp set value=500
   where id=1 and version=100
--   如果更新条数等于1,说明保存成功,更新version值加1。
--如果更新条数等于0,说明保存失败,说明有其它用户修改了这条记录。
  1. 悲观锁: 数据库级别的解决办法,从而有效的保证的数据的正确性;通过各种途径操作数据库(java项目,pl/sql developer…),都会得到很好的保护。
悲观锁性能差,不能并发操作,只能排队等待处理。实际上,查询的操作完全可以并发处理的。

可移植性差,依赖于特定数据库,而且并不是所有数据库提供悲观锁。

II 事务

事务是包含一系列步骤的完整操作。https://kunnan.blog.csdn.net/article/details/128387690

2.1 事务ACID特性

  1. 原子性(atomicity):事务的所有步骤,要么都成功,要么都失败。
  2. 一致性(consistency):事务将数据从一种一致状态转变为下一种一致状态。
  3. 隔离性(isolation):一个事务的执行不能被其他事务干挠,在该事务提交之前对其它事务都不可见。
  4. 持久性(durability):事务一旦提交,其结果就是永久性的。

2.2 事务控制语句

commit:提交事务,将事务期间所做修改保存。
rollback:回滚事务,撤销事务期间所做的修改。
savepoint:在事务中创建“标记点”,可以回滚到这些标记点。
rollback to :回滚到标记点,而不回滚标记点之前的修改,rollback to savepoint不会结束事务。
set transaction:设置事务属性,如事务的隔离级别以及事务是只读还是可读写的。

III 关系

关系是笛卡尔积的有限子集, 三元组表示关系R<U,F>,关系作为一张二维表,对他有一个最起码的要求,即每一个分量(元组)必须是不可分的数据项。满足这一条件的关系模式就属于第一范式。
三种类型:

  • 基本表:实际存在的表,它是实际存储数据的逻辑表示。
  • 查询表:查询结果对应的表
  • 视图表:由基本表或其他的视图表导出的表,是虚表,它不对应实际存储的数据。

原文链接:https://blog.csdn.net/z929118967/article/details/128468792

3.1 表

  • 表:由行和列组成,也称为二维表。
  • 记录:表中一行,称为一条记录
  • 字段:构成记录的各数据项,比如姓名、性别。

3.2 基本表的性质

  • 原子性: 基本表中的字段是不可再分解的
  • 原始性:基本表中的记录是原始数据的记录
  • 演绎性: 由基本表与代码表中的数据可以派生出所有的输出数据。
  • 稳定性:基本表的结构是相对稳定的,表中的记录是长期保存的。

3.3 中间表、临时表和视图

  • 中间表: 是存放统计数据的表,它是为数据仓库、输出报表或查询结果而设计的。
  • 临时表是程序员个人设计的,存放临时记录,为个人所用。
基本表和中间表由dba维护,临时表由程序员自己采用程序来自动维护。
  • 视图技术在数据库设计中的作用
  1. 视图是供程序员使用数据库的一个窗口,是一种虚表,视图依赖基本表而存在。它是基本表的数据综合的一种体现,是数据处理的一种方法,更是一种数据保密的手段。
  2. 为了进行复杂处理、提高运算速度和节省存储空间,视图的定义深度一般不得超过三层。如果超过三层视图还是不够用,则应该在视图上定义临时表,在临时表上再定义视图。

3.4 约束

oracle自动为主键和唯一约束创建索引。

主键约束

---添加主键
alter table EMP add constraint pk_emp_id primary key (EMP_ID);

唯一约束

alter table EMP add constraint uq_emp_code unique (EMP_CODE);

外键约束

  alter table EMP
  add constraint fk_dept_id foreign key (DEPT_ID)
  references dept (DEPT_ID);

IV 索引

4.1 索引类型

  • 标准索引(B*树):数据量非常大的情况下,查找依然很快。
  • 唯一索引(Unique Index):比如员工编号,唯一索引查找最快。
  • 位图索引(Bitmap):适合基数小的字段,比如性别,节约空间。
  • 基于函数的索引(FBI)

4.2 创建索引

创建标准索引

create index IDX_DEPT_NAME 
on DEPT (dept_name);

创建唯一索引

create unique index IDX_DEPT_CODE 
on DEPT (dept_code);

创建位图索引

create bitmap index IDX_EMP_SEX 
on EMP (sex);

创建函数索引

create index IDX_EMP_BDATE 
on EMP (TO_CHAR(B_DATE,'YYYY-MM-DD'));

4.3 建议建立索引的字段

  1. 表间关联字段(外键)
  2. 查询的字段
  3. group by的字段
  4. order by的字段
select emp.e_mail,count(*) ct 
from emp
join dept on emp.dept_id=dept.dept_id
where dept.dept_name = 'IT'
group by emp.e_mail
order by emp.e_mail
  • 身份证这类唯一属性,应建唯一索引
  • 性别,只有男、女、未定等少数几种状态值,应创建位图索引,位图索引更节约空间
  • 对字段使用函数,会停用索引,可创建函数索引

4.4 索引的优缺点

  • 优点:某些情况下,数据查找快。
  • 缺点:
  1. 在通过索引查找,返回结果比较多的情况下,由于需要占用非常多的磁盘I/O,这时全表扫描比索引查找更快
  2. 索引占用空间惊人,甚至超过表数据所占空间,不利于管理。
  3. 创建索引后,会降低插入,修改,删除等操作的效率。

V 提高数据库运行效率的方法

从数据库系统级优化、数据库设计级优化和程序实现级优化:

  1. 在数据库物理审计时,降低范式、增加高级冗余、少用触发器和多用存储过程。
  2. 当计算非常复杂,而且记录条数非常巨大时,复杂的计算要先在数据库外以文件系统方式采用编程语言处理完毕之后,最后才入库追加到表中。
  3. 如果表的记录太多,可以以主键的某个值为界限,将该表的记录分割为两个表;如果表的字段太多,则垂直分割表。

5.1 好的E-R图标准

结构清晰,关联简洁、实体个数适中、属性分配合理和没有低级冗余。

5.2 字段的设计

  1. 数据类型尽量用数字类型
  2. 数据类型尽量的小
  3. 尽量不允许null,可以使用not null 和default 来代替null
  4. 少用text和image类型的字段
  5. 自增字段要慎用,不利于数据迁移。

雪花ID:https://blog.csdn.net/z929118967/article/details/128307222

5.3 主键与外键

一般而言,一个实体不能既无主键又无外键。在E-R图中处于叶子部位的实体,可以定义主键也可不定义主键(因为它无子孙),但必须要有外键(因为他有父亲)。主键是实体的高度抽象,主键与外键的配对表示实体之间的连接。

主键的取值方法:主键是供程序员使用的表间连接工具,可以是一个由程序实现的自动递增的序列(无物理意义的数字串),也可以有物理意义的字段名或字段组合。建议组合字段的个数不要太多,多了不但索引占用空间大,而且速度也慢。

雪花ID:https://blog.csdn.net/z929118967/article/details/128307222

5.4 正确处理多对多的关系

如果两个实体之间存在多对多的关系,则应该消除这种关系,消除的办法是在两者之阿增加第三实体
这样原来一个多对多的关系,现在变成两个一对多的关系。要将原来两个实体的属性合理地分配到三个实体中。

5.5 数据冗余

提倡高级冗余(派生性冗余),反对低级冗余(重复性冗余)。

高级冗余举例:消费流水表的字段有原余额、现余额和消费金额。其中原余额是冗余的,但是也要保留。

5.6 SQL优化

  1. 优化时,在既有选择操作和链接操作时,应当先做选择操作,这样参加连接的元组就可以大大减少。(代数优化)
  2. 选择操作算法有全表扫描和索引扫描,应当选用索引扫描。
  3. 表的连接采用index join代价页较小。这是物理优化。
目录
相关文章
|
24天前
|
存储 Oracle 关系型数据库
数据库数据恢复—ORACLE常见故障的数据恢复方案
Oracle数据库常见故障表现: 1、ORACLE数据库无法启动或无法正常工作。 2、ORACLE ASM存储破坏。 3、ORACLE数据文件丢失。 4、ORACLE数据文件部分损坏。 5、ORACLE DUMP文件损坏。
81 11
|
2月前
|
Oracle 关系型数据库 数据库
Oracle数据恢复—Oracle数据库文件有坏快损坏的数据恢复案例
一台Oracle数据库打开报错,报错信息: “system01.dbf需要更多的恢复来保持一致性,数据库无法打开”。管理员联系我们数据恢复中心寻求帮助,并提供了Oracle_Home目录的所有文件。用户方要求恢复zxfg用户下的数据。 由于数据库没有备份,无法通过备份去恢复数据库。
|
2月前
|
存储 Oracle 关系型数据库
oracle数据恢复—Oracle数据库文件大小变为0kb的数据恢复案例
存储掉盘超过上限,lun无法识别。管理员重组存储的位图信息并导出lun,发现linux操作系统上部署的oracle数据库中有上百个数据文件的大小变为0kb。数据库的大小缩水了80%以上。 取出&并分析oracle数据库的控制文件。重组存储位图信息,重新导出控制文件中记录的数据文件,发现这些文件的大小依然为0kb。
|
30天前
|
存储 Oracle 关系型数据库
服务器数据恢复—华为S5300存储Oracle数据库恢复案例
服务器存储数据恢复环境: 华为S5300存储中有12块FC硬盘,其中11块硬盘作为数据盘组建了一组RAID5阵列,剩下的1块硬盘作为热备盘使用。基于RAID的LUN分配给linux操作系统使用,存放的数据主要是Oracle数据库。 服务器存储故障: RAID5阵列中1块硬盘出现故障离线,热备盘自动激活开始同步数据,在同步数据的过程中又一块硬盘离线,RAID5阵列瘫痪,上层LUN无法使用。
|
2月前
|
SQL Oracle 关系型数据库
Oracle数据库优化方法
【10月更文挑战第25天】Oracle数据库优化方法
57 7
|
11天前
|
存储 Oracle 关系型数据库
数据库传奇:MySQL创世之父的两千金My、Maria
《数据库传奇:MySQL创世之父的两千金My、Maria》介绍了MySQL的发展历程及其分支MariaDB。MySQL由Michael Widenius等人于1994年创建,现归Oracle所有,广泛应用于阿里巴巴、腾讯等企业。2009年,Widenius因担心Oracle收购影响MySQL的开源性,创建了MariaDB,提供额外功能和改进。维基百科、Google等已逐步替换为MariaDB,以确保更好的性能和社区支持。掌握MariaDB作为备用方案,对未来发展至关重要。
39 3
|
11天前
|
安全 关系型数据库 MySQL
MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!
《MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!》介绍了MySQL中的三种关键日志:二进制日志(Binary Log)、重做日志(Redo Log)和撤销日志(Undo Log)。这些日志确保了数据库的ACID特性,即原子性、一致性、隔离性和持久性。Redo Log记录数据页的物理修改,保证事务持久性;Undo Log记录事务的逆操作,支持回滚和多版本并发控制(MVCC)。文章还详细对比了InnoDB和MyISAM存储引擎在事务支持、锁定机制、并发性等方面的差异,强调了InnoDB在高并发和事务处理中的优势。通过这些机制,MySQL能够在事务执行、崩溃和恢复过程中保持
41 3
|
11天前
|
SQL 关系型数据库 MySQL
数据库灾难应对:MySQL误删除数据的救赎之道,技巧get起来!之binlog
《数据库灾难应对:MySQL误删除数据的救赎之道,技巧get起来!之binlog》介绍了如何利用MySQL的二进制日志(Binlog)恢复误删除的数据。主要内容包括: 1. **启用二进制日志**:在`my.cnf`中配置`log-bin`并重启MySQL服务。 2. **查看二进制日志文件**:使用`SHOW VARIABLES LIKE &#39;log_%&#39;;`和`SHOW MASTER STATUS;`命令获取当前日志文件及位置。 3. **创建数据备份**:确保在恢复前已有备份,以防意外。 4. **导出二进制日志为SQL语句**:使用`mysqlbinlog`
54 2
|
25天前
|
关系型数据库 MySQL 数据库
Python处理数据库:MySQL与SQLite详解 | python小知识
本文详细介绍了如何使用Python操作MySQL和SQLite数据库,包括安装必要的库、连接数据库、执行增删改查等基本操作,适合初学者快速上手。
174 15
|
18天前
|
SQL 关系型数据库 MySQL
数据库数据恢复—Mysql数据库表记录丢失的数据恢复方案
Mysql数据库故障: Mysql数据库表记录丢失。 Mysql数据库故障表现: 1、Mysql数据库表中无任何数据或只有部分数据。 2、客户端无法查询到完整的信息。

推荐镜像

更多