·数据库相关:

·范式: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基础的更多相关文章

  1. [SQL] SQL 基础知识梳理(一)- 数据库与 SQL

    SQL 基础知识梳理(一)- 数据库与 SQL [博主]反骨仔 [原文地址]http://www.cnblogs.com/liqingwen/p/5902856.html 目录 What's 数据库 ...

  2. [SQL] SQL 基础知识梳理(二) - 查询基础

    SQL 基础知识梳理(二) - 查询基础 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5904824.html 序 这是<SQL 基础知识梳理( ...

  3. [SQL] SQL 基础知识梳理(三) - 聚合和排序

    SQL 基础知识梳理(三) - 聚合和排序 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5926689.html 序 这是<SQL 基础知识梳理 ...

  4. [SQL] SQL 基础知识梳理(四) - 数据更新

    SQL 基础知识梳理(四) - 数据更新 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5929786.html 序 这是<SQL 基础知识梳理( ...

  5. [SQL] SQL 基础知识梳理(五) - 复杂查询

    SQL 基础知识梳理(五) - 复杂查询 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5939796.html 序 这是<SQL 基础知识梳理( ...

  6. 黑马程序员+SQL基础(上)

    黑马程序员+SQL基础 ---------------<a href="http://edu.csdn.net"target="blank">ASP ...

  7. 15个初学者必看的基础SQL查询语句

    本文由码农网 – 小峰原创翻译,转载请看清文末的转载要求,欢迎参与我们的付费投稿计划! 本文将分享15个初学者必看的基础SQL查询语句,都很基础,但是你不一定都会,所以好好看看吧. 1.创建表和数据插 ...

  8. mysql使用基础 sql语句(一)

    csdn博文地址:mysql使用基础 sql语句(一)  点击进入 命令行输入mysql -u root -p,回车再输入密码,进入mysql. 终端命令以分号作为一条语句的结束,可分为多行输入,只需 ...

  9. Oracle SQL 基础学习

    oracel sql 基础学习 CREATE TABLE USERINFO ( ID ,) PRIMARY KEY, USERNAME ), USERPWD ), EMAIL ), REDATE DA ...

随机推荐

  1. 第01组 Alpha冲刺(5/6)

    队名:007 组长博客: https://www.cnblogs.com/Linrrui/p/11901035.html 作业博客: https://edu.cnblogs.com/campus/fz ...

  2. C++判断计算式是大端存储模式,还是小端存储模式

    小端存储:数据的低字节存储在地址空间的低字节位,数据的高字节存储在地址空间的高字节位. 大端存储:数据的低字节存储在地址空间的高字节位,数据的高字节存储在地址空间的低字节位. 判断计算机是小端还是大端 ...

  3. 重置jenkins用户名密码

    忘记用户名密码(如图)不管是忘记用户名密码还是误删jenkins目录下的users文件都可以使用下面的方式找回密码,我的版本是Jenkins 2.134 1.     进入jenkins安装目录,我的 ...

  4. IntelliJ IDEA编辑器的使用技巧

    目录 1. 使用技巧 1. 跳转小工具 2. 无处不在的跳转 3. 精准搜索 4. 列操作: 5. live template 6. postfix 7. ALT+ENTER智能提示,代码优化 8. ...

  5. C#开源录音组件、录像组件、录屏组件及demo源码

    在多媒体系统中,一般都会涉及到录音.录像.录屏问题,采集得到的数据可以用来传输.播放.或存储.所以,对于像课件录制系统.语音视频录制系统.录屏系统等,多媒体数据的采集就是最基础的功能之一. MCapt ...

  6. pom.xml文件引入tools.jar

    最近做hbase开发时,引入相关jar包后,出现了以下错误 Missing artifact jdk.tools:jdk.tools:jar:1.8 绝对地址引用 <dependency> ...

  7. 【源码阅读】SpringBoot-v2.2.0启动过程以及细节

    启动流程 图如下: 以上流程图源文件(可导入https://www.processon.com):https://github.com/Mysakura/DataFiles 相关Event(org.s ...

  8. K-Means 聚类分析学习笔记

    在之前分享的链家二手房数据分析的练习中用到了 K-Means 聚类分析方法,所以就顺道一起复习一下 K-Means 的基础知识好了. K-Means 聚类分析可将样本分为若干个集群,它的核心思想就是使 ...

  9. Docker 制作定制asp.netcore 的容器

    上文Windows docker k8s asp.net core的k8swebap镜像只是一个asp.net core程序,在实际生产中我们希望容器中还有一些其他程序,比如ssh 和telegraf ...

  10. Docker在linux系统下的安装

    系统要求 本安装教程仅限于CentOS7,其他系统不适用.centos-extras仓库必须是启用状态,这个仓库默认状态是启用,如果不是启用状态,请修改. 卸载旧版本的Docker Docker的旧版 ...