【数据库】SQL语法
https://blog.csdn.net/weixin_42915286/article/details/85339284
MySQL:
5K QPS
一般抗到2K就差不多了
数据库原理
SQL是什么?
SQL代表结构化查询语言(Structured Query Language)。SQL是用于访问数据库的标准化语言。
SQL包含三个部分:
- 数据定义语言包含定义数据库及其对象的语句,例如表,视图,触发器,存储过程等;
- 数据操作语言包含允许您更新和查询数据的语句。
- 数据控制语言允许授予用户权限访问数据库中特定数据的权限。
关系型数据库 与 非关系型数据库
当前数据库分为 关系型数据库 和 非关系型数据库
(关系型 与 分布式 相对立);
1.关系型数据库
关系型数据库:指采用了关系模型(即表结构:二维表格模型)来组织数据 的 数据库。
(非关系型数据库:指非关系型的,分布式的,且一般不保证遵循ACID原则的数据存储系统。)
关系模型指的就是二维表格模型,而一个关系型数据库就是由二维表及其之间的联系所组成的一个数据组织。
关系模型中常用的概念:
关系:(表名)一张二维表,每个关系都具有一个关系名,也就是表名
元组:(行)二维表中的一行,在数据库中被称为记录
属性:(列)/(字段) 二维表中的一列,在数据库中被称为字段
域:(属性取值范围) 属性的取值范围,也就是数据库中某一列的取值限制
关键字:一组可以唯一标识元组的属性,数据库中常称为主键 Primary Key,由一个或多个列组成
关系模式:(表结构) 指对关系的描述。其格式为:关系名(属性1,属性2, … … ,属性N),在数据库中成为表结构
码:表中可以唯一确定一个元组的某个属性(或者属性组),如果这样的码有不止一个,那么大家都叫候选码,我们从候选码中挑一个出来做老大,它就叫主码。
传递依赖:
关系型数据库的优点:
1.容易理解:二维表结构是非常贴近逻辑世界的一个概念,关系模型相对网状、层次等其他模型来说更容易理解
2.使用方便:通用的SQL语言使得操作关系型数据库非常方便
3.易于维护:丰富的完整性(实体完整性、参照完整性和用户定义的完整性)大大减低了数据冗余和数据不一致的概率;
关系型数据库存在的问题:
1.网站的用户并发性非常高,往往达到每秒上万次读写请求,对于传统关系型数据库来说,硬盘I/O是一个很大的瓶颈;
2.网站每天产生的数据量是巨大的,对于关系型数据库来说,在一张包含海量数据的表中查询,效率是非常低的;
3.在基于web的结构当中,数据库是最难进行横向扩展的,当一个应用系统的用户量和访问量与日俱增的时候,数据库却没有办法像web server和app server那样简单的通过添加更多的硬件和服务节点来扩展性能和负载能力。当需要对数据库系统进行升级和扩展时,往往需要停机维护和数据迁移。
4.性能欠佳:在关系型数据库中,导致性能欠佳的最主要原因是多表的关联查询,以及复杂的数据分析类型的复杂SQL报表查询。为了保证数据库的ACID特性,必须尽量按照其要求的范式进行设计,关系型数据库中的表都是存储一个格式化的数据结构。
数据库事务必须具备ACID特性,ACID分别是Atomicity原子性