性能测试基础---SQL基础
·数据库相关:
·范式:NF。关系型数据库的设计规则。
范式总计有6种:
1NF\2NF\3NF\BCNF\4NF\5NF
·范式的实现是从低到高的,比如说首先要实现的就是1NF,才能继续实现2NF,依次类推。
·范式的实现,一般来说采取的就是拆表的方法。
·范式越高,实现的成本也就越高。因此在实际生产中,一般来说,只需要达到3NF即可。
·1NF:没有重复的列。
·2NF:没有重复的行。
·3NF:没有可传递的依赖关系(主从关系)。
做法就是拆表。
·键:在关系型数据库中,有以下几个特殊的键:
·超键:是指在数据库中能够唯一标识记录的属性or属性集。
PS:一般来说,超键都是由数据库本身来生成和管理的。
·候选键:是指在一个表(集合、关系)中,能够唯一标识记录的属性or属性集。
一个表中可以有多个。
·主键:是指在一个表(集合、关系)中,被定义为主键的属性or属性集(候选键)。
一个表中只能有一个。
·外键:如果表B中的属性(列)M的取值是完全依赖(来源)于表A中的属性(列)N的取值,且属性N是表A的候选键,则称属性M为表B的外键。
PS:在数据库层面,本身只会去实现超键。对于候选键、主键和外键,都是由用户(DBA)来定义并且告知数据库的。一旦定义,则数据库就会对数据进行检测,确保符合定义的要求。
从理论上,表中的任何字段都可以定义为候选键、主键或者外键(符合语法要求)。
但是,我们平时在使用数据库时,一定要保证定义符合业务要求、符合现实数据的规范。
·约束:数据库是通过约束来实现数据存储的实体完整性和参照完整性的。
一般来说,约束有以下几种:
·唯一约束:unique,一旦属性被定义为unique,则表示要唯一。
·主键约束:primary key,主键本身就表示具有唯一和非空约束,并且会自动添加唯一索引。
·外键约束:foreign key,定义为外键,符合外键的定义。
PS:外键和其所引用的键,要求类型和长度保持一致。
·非空约束:not null,表示要求数据非空。
·检查约束:check,是根据业务数据本身的业务特点,额外添加的数据约束条件。
enum(枚举).
·视图和索引:
·视图:view。
create view 视图名 as select语句。
作用,是简化查询。查询数据还是取决于原始的select 语句。
并不能提升查询速度。
除了物化视图以外。
物化视图其实就是一张新的实表。
·索引:index。
就是目录。
可以提高查询的效率(速度).
·explain,用来查看执行计划的。
可以初步判断sql语句的性能。
性能测试基础---SQL基础的更多相关文章
- [SQL] SQL 基础知识梳理(一)- 数据库与 SQL
SQL 基础知识梳理(一)- 数据库与 SQL [博主]反骨仔 [原文地址]http://www.cnblogs.com/liqingwen/p/5902856.html 目录 What's 数据库 ...
- [SQL] SQL 基础知识梳理(二) - 查询基础
SQL 基础知识梳理(二) - 查询基础 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5904824.html 序 这是<SQL 基础知识梳理( ...
- [SQL] SQL 基础知识梳理(三) - 聚合和排序
SQL 基础知识梳理(三) - 聚合和排序 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5926689.html 序 这是<SQL 基础知识梳理 ...
- [SQL] SQL 基础知识梳理(四) - 数据更新
SQL 基础知识梳理(四) - 数据更新 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5929786.html 序 这是<SQL 基础知识梳理( ...
- [SQL] SQL 基础知识梳理(五) - 复杂查询
SQL 基础知识梳理(五) - 复杂查询 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5939796.html 序 这是<SQL 基础知识梳理( ...
- 黑马程序员+SQL基础(上)
黑马程序员+SQL基础 ---------------<a href="http://edu.csdn.net"target="blank">ASP ...
- 15个初学者必看的基础SQL查询语句
本文由码农网 – 小峰原创翻译,转载请看清文末的转载要求,欢迎参与我们的付费投稿计划! 本文将分享15个初学者必看的基础SQL查询语句,都很基础,但是你不一定都会,所以好好看看吧. 1.创建表和数据插 ...
- mysql使用基础 sql语句(一)
csdn博文地址:mysql使用基础 sql语句(一) 点击进入 命令行输入mysql -u root -p,回车再输入密码,进入mysql. 终端命令以分号作为一条语句的结束,可分为多行输入,只需 ...
- Oracle SQL 基础学习
oracel sql 基础学习 CREATE TABLE USERINFO ( ID ,) PRIMARY KEY, USERNAME ), USERPWD ), EMAIL ), REDATE DA ...
随机推荐
- 2019-2020-1 20181218《Linux内核原理与分析》第一周作业
目录 问题和参考 有趣/有用的Linux命令 小作业和解答 一些图片 相关学习 本文是学习Linux基础入门(新版)后的总结. 问题和参考 虚拟机莫名崩溃,一天重启了几十次电脑,重装两次系统,心累.想 ...
- Spring boot2X集成zuul与consul实现负载均衡和反向代理
zuul 是netflix开源的一个API Gateway 服务器 所有从设备或网站来的请求都会经过Zuul到达后端的Netflix应用程序. 作为一个边界性质的应用程序,Zuul提供了动态路由.监控 ...
- Java通过poi读取excel中文件
maven依赖 <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi</a ...
- spark 调优(官方文档)
1.序列化 对象在进行网络传输或进行持久化时需要进行序列化,如果采用序列化慢或者消耗大量字节的序列化格式,则会拖慢计算. spark 提供了两种序列化类库 1). Java serialization ...
- nginx mysqlnd驱动引擎提升mysql性能
nginx mysqlnd驱动引擎提升mysql性能 前期要安装 mysql mysqli pdo_mysql libiconv 1 先去PHP官网下个 php-5.6.29.tar.gz wget ...
- 【转】JavaScript 高性能数组去重
原文地址:https://www.cnblogs.com/wisewrong/p/9642264.html 一.测试模版 数组去重是一个老生常谈的问题,网上流传着有各种各样的解法 为了测试这些解法的性 ...
- Spring Cloud OkHttp设计原理
Spring Cloud 框架最底层核心的组件就是服务调用方式,一般Spring Cloud框架采用的是HTTP的调用框架,本文将在 Spring Cloud应用场景下,介绍组件OkHttp3的设计原 ...
- golang ---查看进程(Windows)
package main import ( "fmt" "os" "os/exec" "strconv" "s ...
- SQL Server的唯一键和唯一索引会将空值(NULL)也算作重复值
我们先在SQL Server数据库中,建立一张Students表: CREATE TABLE [dbo].[Students]( ,) NOT NULL, ) NULL, ) NULL, [Age] ...
- .net Dapper 实践系列(6) ---事务删除(Layui+Ajax+Dapper+MySQL)
目录 写在前面 实现步骤 写在最后 写在前面 上一小节,总结了事务多表更新的两种方法.一个是只更新原来的数据,一个是先删除原来的数据再往里面添加新的数据.而这一小节,说的是事务的多表删除. 实现步骤 ...