SQL初级知识点
一,表
- 表中的列叫做字段,行叫记录也叫元组。
- 主键:唯一的标识表中的某一条记录
- 外键:一个表的主键作为另一个表的外键,表示两个表之间的关系。一般将外键写在记录的一方,比如部门号和员工号,应该将部门号作为员工的外键。多对一写在多的一面。
- 外键的值一定要在该外键的表中存在
二,约束
- 对一个表中的属性操作的限制叫做约束
- 主键约束:不允许重复元素,避免数据冗余
- 外键约束:通过外键约束从语法上保证了本事务所关联的其他事务一定存在。
- 事物与事物之间的关系是通过外键来体现的
- check约束:保证事物的取值在合法范围内
- default约束:保证事物一定有一个值
- 唯一约束:unique保证事物的取值不允许重复,但是允许其中有一列,且只能有一列为空。
- unique唯一性不能重复,default默认值,check约束范围
- 主键和unique的区别:unique只允许一列可以为空,主键不能为空。
三,关系
- 一对一:即可以把表A的主键充当表B的外键,也可以把表B的主键充当A的外键
- 一对多:把表A的主键充当表B的外键,或者说把A的主键添加到B表来充当B表的外键,在多的一方添加外键
- 多对多:例如班级是一张表,教师是一张表,班级和教师的关系也是一张表。
四,查询代码篇
五,数据库中单引号与双引号的区别
一般单引号是字符串,双引号是字段的名字
六,聚合函数【多行函数】
- 不返回为null的数据
- 单行函数和多行函数不能同时使用
- group by 【分组查询】使用group by之后,select中只能出现分组后的整体信息,不能出现组内的详细信息。
- having【对分组后的信息进行过滤】,having不能使用别名,先过滤时还没有别名,所以是错的,having后面必须是分组的整体信息,条件参数顺序不能改变where一定要在having前面
- having与where的异同:相同点:having与where都是对数据过滤,都只保持有效数据。不同点:where对原始记录过滤,having对分组后的数据过滤,where必须在having前面,不能颠倒,否则报错。
七,连接查询
- 将两个表或者两个以上的表以一定的连接条件连接起来,从中检索出满足条件的数据
- 内连接:(1)select……from A,B的用法,(2)select……from A,B where……的用法,(3)select……from A join B on……的用法
- 外连接:(1)左外连接:left join关键字从表table1返回所有的行,即右表table2中没有匹配。如果表中没有匹配则结果为null
(2)右外连接:right join 关键字从右表table2返回所有的行,即使左表table1中没有匹配,则结果为null
(3)完全连接:full outer join 关键字只要左表table1和右表table2其中一个表中存在匹配,则返回行。full outer join关键字结合了left join和right join的结果
(4)自连接:一张表自己和自己连接起来查询数据
(5)交叉连接:
(6)联合:表和表之间的数据以纵向的方式连接在一起
八,视图的格式
- create view视图的名字
- as-select的前面不能添加begin
- select语句-select后面不能添加end
九,视图的优缺点
- 优点:可以隐藏一些表的原始数据,相当于保护原始数据,简化查询,增加数据的保密性
- 缺点:增加了数据库的维护成本,视图只是为了简化查询,但是并不能加快查询的速度,如果原始表数据丢失,视图就要进行修改
- 注意的问题:创建视图的select语句必须为所以的计算列指定别名,视图不是物理表,是临时虚拟表,临时表。
十,事务
(1)为什么需要事务?
- 事务可以保证避免数据处于一种不合理的中间状态
- 利用事务可以实现多个用户对共享资源的同时访问
- 事务必须得保证多个用户对共享资源同时访问数据库给用户的反应是合理的
(2)事务和线程的关系?
- 事务也是通过锁来解决很多问题的
- 线程同步就是通过锁来解决的 sychronized
(3)事务和第三方插件的关系
- 直接使用事务库技术难度很大,很多人借助第三方插件来实现,因此一般人不需要细细的研究数据库中事务的语法细节,第三方插件想要完成预期的功能,一般必须的借助数据库中的事务机制来实现
(4)事务的三种运行模式
- 自动提交事务:每条单独的语句都是一个事务,如果成功执行则自动提交,如果失败则自动回滚
- 显式事务:每个事务均以BEGIN TRANSACTION语句显式开始,以COMMIT或ROLLBACK语句显式结束
- 隐藏事务:在前一个事务完成时新事务隐式启动,每个事务仍以COMMIT或ROLLBACK语句显式结束。
重点:数据库是如何解决存储问题的,以及check,default,unique约束
SQL初级知识点的更多相关文章
- sql注入知识点整理(基础版)
sql注入知识点整理(基础版) 基本步骤 判断是否报错 判断闭合符号 判断注入类型 构建payload 手工注入或者编写脚本 基本注入类型 报错型注入 floor公式(结果多出一个1):and (se ...
- SQL函数知识点
SQL函数知识点 SQL题目(一) 1.查询部门编号为10的员工信息 select*from emp where empno=10; 2.查询年薪大于3万的人员的姓名与部门编号 select enam ...
- sql操作知识点个人笔记(SQLServer篇)
实际工作中,总会遇到一些常用的或不常用的sql,这些sql可能并没多少技术含量,但对我们本身而言,一个最大的问题就是很容易忘记.对我个人而言,以前常用的,过阵子之后再用到,发现不记得了.由此得出结论, ...
- SQL必备知识点
经典SQL语句大全 基础 1.说明:创建数据库.说明:删除数据库drop database dbname3.说明:备份sql server--- 创建 备份数据的 device.说明:创建新表crea ...
- SQL初级语句
一)SQL是什么? 结构化查询语言(Structured Query Language)简称SQL, 是一种特殊目的的编程语言,是一种数据库查询和程序设计语言,用于存取数据以及查询.更新和管理关系数据 ...
- SQL初级语法 [查询: SELECT]
SQL查询: SELECT 普通查询: SELECT "栏位名" FROM "表格名" DISTINCT 查询:(去掉重复) SELECT DISTINCT & ...
- SQL初级第三课(下)
我们续用第三课(上)的表 辅助表 Student Course Score Teacher Sno ...
- SQL初级第二课
随着我们数据库越来越复杂 我们要掌握的姿势也要也来越多.... 首先建立个表 create table shop(code int primary key identity (1,1),name va ...
- SQL初级
SQL是一个微软开发的数据库,因为联系到很多内部服务程序和文件所以安装和删除的时候有些人会遇上些麻烦,如果安装失败了那就得完全删除后重装,然而他自己自带的删除系统并不是那么给力,所以悲剧就诞生了,不行 ...
- 161017、SQL必备知识点
经典SQL语句大全 基础 1.说明:创建数据库 CREATE DATABASE database-name 2.说明:删除数据库 drop database dbname 3.说明:备份sql ser ...
随机推荐
- Cleanest XMaster绿色解压最新版下载9.6密钥激活码
cad安装报错换了好几个版本都不行,用这个卸载了一下,确实有用 Cleanest XMaster绿色版cad卸载工具分享下载 地址一(百度网盘) 地址二(直接下载) 9.6.05密钥:[AtrXShX ...
- locust中的监听器
locust的master相关的几个监听器: 心跳监听器: 一个while循环,不断判断所有client当前的心跳状况,如果有一个client失去了心跳,就打印了一个警告日志,如果所有client都失 ...
- windows下的故障自愈程序,可以实现进程,kafka按时间段判断状态,日志分级
self-healing 1.使用python3.11写的一个故障自愈程序. 2.本程序在window2019 server运行测试通过 3.通过监控java程序里的详细启动包名来判断进程是否存在 4 ...
- 【git】2.1 获取git仓库
资料来源 (1) https://git-scm.com/book/zh/v2/Git-%E5%9F%BA%E7%A1%80-%E8%8E%B7%E5%8F%96-Git-%E4%BB%93%E5%B ...
- ESXI密码正确无法登录
场景描述: 今天新安装了一个VMware ESXi 6.5的系统,密码仍然用的习惯采用的密码.但在使用中,无论是使用vSphere Client连接,还是在vCenter Server中添加这台ESX ...
- pip3 install
python3 -m venv tutorial-env source tutorial-env/bin/activatepip3 install *deactivate
- css 选择器再学一遍记录一下*1
1 <!DOCTYPE html> 2 <html> 3 <HEAD> 4 5 <style> 6 *{font-size: 12px; padding ...
- dialog弹窗里生成二维码 (reading qppendChild)
在dialog弹窗里生成二维码第一次点击时 dialogFormVisible.value=false,二维码生成时会找不到对象可以用nextTick()函数 将二维码生成代码放到nextTick() ...
- iOS开发 WKWebView实现JS交互
需求:利用webView加载H5页面,并实现点击H5页面的按钮触发事件,事件是调用OC的方法.简单说就是JS调用OC的方法,这里我们选择的是WKWebView,至于为什么不用UIWebView,自行百 ...
- PAT-basic-1021 个位数统计 java
一.题目 给定一个 k 位整数 N=dk−110k−1+⋯+d1101+d0 (0≤di≤9, i=0,⋯,k−1, dk−1>0),请编写程序统计每种不同的个位数字出现的次数.例如: ...