数据库基础
来源:互联网 发布:最全的网络投资产品 编辑:程序博客网 时间:2024/04/30 10:10
基本概念
数据库:存放与管理数据的仓库,是逻辑上相关的数据的集合。优点有:减少数据冗余度、具有较高的独立性、便于数据共享。
数据库系统:由数据库及其管理软件组成的系统。
SQL:Structured 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.丢失更新。多个事务同时更新同一行如事务A、B同时修改小明的英语和语文成绩。
2.脏读。一个事物读取了另一个事务尚未提交的更新。
3.不可重复读。
4.幻象读。
涉及多个数据库的事务称为分布式事务
锁是一种机制,用来防止事务的并发问题。常见的有共享锁、更新锁、排它锁等。
- 数据库基础
- 数据库基础
- 数据库基础
- 数据库基础
- 数据库基础
- 数据库基础
- 数据库基础
- 数据库基础
- 数据库基础
- 数据库基础
- 数据库基础
- 数据库基础
- 数据库基础
- 数据库基础
- 数据库基础
- 数据库基础
- 数据库基础
- 数据库基础
- linux下安装loadrunner步骤以及出错解决方法(外加linux下ip地址欺骗)
- MySQL 数据类型 详解
- android源码开发基础知识了解
- Myeclipse10下搭建SSH框架(图解)Struts2.1+Spring3.0+Hibernate3.3
- MySQL并发处理
- 数据库基础
- windows 下字节对齐 sizeof
- Struts 1.x常见错误的全面汇总
- SQLServer 获取所有数据库名、表名、储存过程以及参数列表
- Yii中常用路径(转)
- Ubuntu 14.04 server开放root ssh登录权限
- 十一周 项目三 点类
- solr功能
- 如何选择机器学习算法