数据库基础

简介: 基本概念 数据库:存放与管理数据的仓库,是逻辑上相关的数据的集合。优点有:减少数据冗余度、具有较高的独立性、便于数据共享。 数据库系统:由数据库及其管理软件组成的系统。 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.幻象读。

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

 

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

 

目录
相关文章
|
2天前
|
存储 SQL 安全
6.数据库技术基础
6.数据库技术基础
|
10天前
|
SQL 关系型数据库 数据库
数据库学习
数据库学习涵盖基础概念、类型(如关系型与NoSQL)、设计、安全和应用。理解数据组织、DBMS功能,掌握SQL语言至关重要。实践中,探索不同数据库系统,确保数据安全,参与实际项目,利用教程资源,能提升数据库管理和应用能力。
17 7
|
3月前
|
存储 NoSQL 关系型数据库
现代数据库技术及其应用
本文介绍了现代数据库技术的发展与应用。从关系型数据库到NoSQL数据库,再到分布式数据库,不同的技术在满足不同需求的同时也带来了新的挑战和机遇。我们将探讨这些数据库技术的特点、优势和适用场景,并提供一些实际应用案例。
|
5月前
|
SQL 关系型数据库 MySQL
数据库基础
数据库基础
36 0
|
10月前
|
数据可视化 安全 关系型数据库
数据库|MySQL数据库基础(一)
数据库|MySQL数据库基础(一)
98 0
|
11月前
|
存储 数据库 索引
数据库的设计
数据库的设计
|
11月前
|
存储 SQL NoSQL
【数据库】了解开源数据库
【数据库】了解开源数据库
|
存储 SQL Oracle
Sqlit(数据库)学习
Sqlit(数据库)学习
106 0
|
SQL NoSQL Oracle
【数据库】实际项目上,用到的数据库,涨涨小知识
说到数据库,本篇文章来简单总结下实际项目上用到的数据库
53 0
|
存储 Oracle NoSQL
了解学习数据库知识
了解学习数据库知识
207 30
了解学习数据库知识