数据库基础

简介: 基本概念 数据库:存放与管理数据的仓库,是逻辑上相关的数据的集合。优点有:减少数据冗余度、具有较高的独立性、便于数据共享。 数据库系统:由数据库及其管理软件组成的系统。 SQL:Structured Query Language,结构化查询语言,用来访问关系型数据库。 表:等同于二维数组,每一列是数据属性,每一行是数据内容。 字段:表中的列也叫字段。字段有自己的名字与属性。 索

基本概念

数据库:存放与管理数据的仓库,是逻辑上相关的数据的集合。优点有:减少数据冗余度、具有较高的独立性、便于数据共享。

数据库系统:由数据库及其管理软件组成的系统。

SQLStructured Query Language,结构化查询语言,用来访问关系型数据库。

表:等同于二维数组,每一列是数据属性,每一行是数据内容。

字段:表中的列也叫字段。字段有自己的名字与属性。

索引:是单独的数据库结构,用来加速数据检索。

视图:将查询的结果以虚拟表的形式存储,用于保护数据安全性。

存储过程:能够完成特定功能的SQL语句的集合,类似于高级语言中的函数。

属性

字段也叫属性,哎,就是这么乱。
简单属性:不能再分的基本属性。
复合属性:相对于简单属性,比如说列名叫“电话及地址”,那么这列就是复合属性。

单值属性:一个实体只有一个值的属性,比如姓名。
多值属性:一个实体可以有多个值的属性,比如电话号码,邮箱等。

派生属性:由其他属性可以计算得到的。比如有了“出生年月”,那么“年龄”就是派生属性了。

规范化

范式:Normal Form

1NF:表的每一字段都是不可分割的基本数据项。

2NF:首先要满足1NF,然后要求数据库表中的每个非主关键字段都完全依赖于主关键字段。

3NF:首先要满足2NF,然后要求不存在非关键字段对任一候选关键字段的传递函数依赖。

一般说来,数据库只需满足第三范式(3NF)就行了。

 

索引

是单独的数据库结构,用来加速数据检索。

缺点:1.占用额外存储空间;2.对表中数据修改时,索引也要动态维护,效率降低。

聚集索引:根据数据行的键值排序和存储。

非聚集索引:不修改原表中数据项的位置。

 

存储过程与触发器

数据库中的存储过程类似于高级语言中的函数,是能够完成特定功能的语句的集合。优点:代码重用、可传参数。

create procedure fun1  //根据学生编号查询学生信息

@x int

as

select * from Student where stu_id=@x

调用方法为:  execute fun1

 

触发器是一种特殊类型的存储过程,当指定表中的数据发生变化时触发器自动生效,通常被用来约束数据完整性。

触发器不能设置参数、不能通过名称调用。触发器被作为事务来处理。

Create trigger t_student //对表Student添加数据时,都会有提示信息-‘准备插入数据’

on Student

after insert 

as

print ‘准备插入数据’

游标

游标是取用一组数据并能够一次与一个单独的数据进行交互的方法。

通常select语句对整行产生作用,游标可以对某行的某列起作用。

//声明游标

declare my_cursor cursor for

select * from Student

where id=’1’

 

//打开游标

open my_cursor

go

 

事务、锁及其并发问题

事务是逻辑上相关的一些语句的集合。为了保障数据的一致性,这些语句要么全成功执行,要么执行失败进行回滚。

特性:原子性、一致性、隔离性、持久性。

begin transaction my_t //声明事务开始

update Student set name =’小明’

where id=1

commit transaction  my_t  ////提交事务

事务的并发问题有4种:

1.丢失更新。多个事务同时更新同一行如事务AB同时修改小明的英语和语文成绩。

2.脏读。一个事物读取了另一个事务尚未提交的更新。

3.不可重复读。

4.幻象读。

涉及多个数据库的事务称为分布式事务

 

锁是一种机制,用来防止事务的并发问题。常见的有共享锁、更新锁、排它锁等。

 

目录
相关文章
|
30天前
|
存储 数据库
为什么需要数据库
为什么需要数据库。
16 4
|
4月前
|
SQL Java 数据库
从0到1了解数据库—实现一个自己的数据库
从0到1了解数据库—实现一个自己的数据库
32 0
|
2月前
|
SQL 关系型数据库 MySQL
盘点数据库中的一些坑(一)
盘点数据库中的一些坑(一)
25 0
|
1月前
|
Go 数据库
数据库的实现
数据库的实现
11 0
|
9月前
|
SQL 存储 NoSQL
数据库详解
数据库详解
52 0
|
4月前
|
SQL NoSQL 关系型数据库
数据库
数据库
36 1
|
8月前
|
SQL Java 数据库连接
H2数据库相关知识
H2数据库是一个嵌入式关系数据库管理系统(RDBMS),它以纯Java编写,支持SQL和JDBC标准。H2数据库具有高性能、轻量级、易于使用和部署的特点。它可以作为内存数据库或持久化数据库使用,并且支持多种模式,包括嵌入式模式、服务器模式和混合模式。H2数据库还提供了一些高级功能,如触发器、存储过程和内置函数,使开发者能够更灵活地操作数据。
|
9月前
|
SQL 数据库
数据库—耿建玲视频总结(一)
基本上每一个材料开始都有其介绍发展史的,了解一下发展史可以培养我们一部分的兴趣,然后就是SQL server的安装介绍,这个在之前我们已经亲身实践了安装的过程,并且还为这安装问题苦恼过好久呢
|
9月前
|
SQL 安全 数据库
【数据库视频】总结
【数据库视频】总结
|
存储 SQL Oracle
数据库——对数据库的认识
–数据库(Database)是按照数据结构来组织、存储和管理数据的仓库。
117 0