mysql 外键和子查询,视图
1.mysql 外键约束
建表时生成外键 foreing key ('sid') references' student'('id');
建表后添加外键 alter table' course student' add foreign key('sid') references'student'('id')
删除外键 alter table ' course student ' drop foreign key ' course_student_ibfk_1;
外键用于与另一张表的关联,是能确定另一张表记录的字段,用于保持数据的一致性
主键 外键索引:
定义 唯一标识一条记录,不能有重复的,不允许为null 表的外键是另一个表的主键,外键可以有重复的。可以是null 没有重复值 ,可以为null(索引无效)作用 用来保证数据的完整性 用来和其他表建立联系用的,提高查询排序的速度
个数 主键只能有一个 一个表可以有多个外键 一个表可以有多个唯一索引
2.自关联
含义 自己join自己 ,用一张表搞定多张表可以达到效果
注意 当表自关联的时候,需要使用as 起别名,防止关联的时候引发重名的问题
select * from areas as p inner join areas as c on c.pid = p.aid where p.atitle = '河南省'
三表关联
select * from areas as p left join areas as c on c.pid = p.aid left join areas as a on a.pid = c.aid where p.atitle = '河南省'
3.子查询
子查询允许把一个查询嵌套在另一个查询当中
标量子查询
是指子查询返回的是单一的标量,如一个数字或一个字符串,也是子查询最简单的返回形式,可以使用 => <> = <= <> 这些操作符对子查询的标量结果进行比较,通常子查询的位置在比较式的右侧
列子查询
指子查询返回的结果集是N 行一列 ,该结果通常来自对表的某个字段查询返回
可以使用 in ,不能直接使用 = > < >= <= <> 这些比较标量结果的操作符
行子查询
指 子查询返回的结果集是N 列一行,通常用来多列的比较
4.视图
视图就是一条select语句执行后返回的结果集,所以创建视图主要工作落在创建sql 查询语句上
特性:视图是对若干张基本表的引用,一张虚表查询语句执行的结果,不存储具体的数据(基本表发生该表,视图跟着改变);可以跟基本表一样,进行增删改查操作(ps:增删改操作有条件限制)
作用 : 方便操作,特别是查询操作,减少复杂的sql语句,增强可读性,更加安全数据库授权命令不能限定到特定行和特定列,但是通过合理创建视图,可以把权限限定到行列级别
使用场合 : 权限控制的时候,不希望用户访问表中某些含敏感信息的列,比如 salary...关键信息来源多个复杂关联表,可以创建视图提取我们需要的信息,简化操作。
建立视图
建议名称以 v_ 开头,用来和普通表区分
使用show tables 可以显示视图
create view 视图名称 as select 语句
使用视图
select * from 视图名称
删除视图
drop view 视图名称
修改视图
create or replace view 视图名称 as sql语句
mysql 外键和子查询,视图的更多相关文章
- MySQL外键和高级查询(连接查询、联合查询、子查询、去重查询)
MySQL的外键 什么是外键,很简单保持数据一致性的一个约束键.如果你有两张表,第一张是学生表,第二张表是一个成绩表,我们来看看保持数据一致性,其实在Django等框架的模型中中也能做关联获取对象. ...
- SQL主外键和子查询
主键 数据库主键是指表中一个列或列的组合,其值能唯一地标识表中的每一行.这样的一列或多列称为表的主键,通过它可强制表的实体完整性.当创建或更改表时可通过定义 PRIMARY KEY约束来创建主键.一个 ...
- 数据库开发基础-SQl Server 主键、外键、子查询(嵌套查询)
主键 数据库主键是指表中一个列或列的组合,其值能唯一地标识表中的每一行.这样的一列或多列称为表的主键,通过它可强制表的实体完整性.当创建或更改表时可通过定义 PRIMARY KEY约束来创建主键.一个 ...
- 2016年11月17日--SQL主、外键,子查询
主键 数据库主键是指表中一个列或列的组合,其值能唯一地标识表中的每一行.这样的一列或多列称为表的主键,通过它可强制表的实体完整性.当创建或更改表时可通过定义 PRIMARY KEY约束来创建主键.一个 ...
- SQL主、外键,子查询
主键 数据库主键是指表中一个列或列的组合,其值能唯一地标识表中的每一行.这样的一列或多列称为表的主键,通过它可强制表的实体完整性.当创建或更改表时可通过定义 PRIMARY KEY约束来创建主键.一个 ...
- MySQL 外键 表的查询
自增补充 这是查看怎么创建的表, \G示旋转90度显示表的内容 表的自增的关键是** AUTO_INCREMENT=3**,在表中添加数据后,这个会自动改变,通过alert可以改变这个默认值 mysq ...
- mysql外键与表查询
目录 自增特性 外键 外键关系 外键创建 外键的约束效果 级联更新级联删除 多对多关系 一对一关系 表查询关键字 select与from where筛选 group by分组 练习 关系练习 查询练习 ...
- MYSQL - 外键、约束、多表查询、子查询、视图、事务
MYSQL - 外键.约束.多表查询.子查询.视图.事务 关系 创建成绩表scores,结构如下 id 学生 科目 成绩 思考:学生列应该存什么信息呢? 答:学生列的数据不是在这里新建的,而应该从学生 ...
- MySQL外键约束On Delete、On Update各取值的含义
主键.外键和索引的区别? 主键 外键 索引 定义: 唯一标识一条记录,不能有重复的,不允许为空 表的外键是另一表的主键, 外键可以有重复的, 可以是空值 主索引(由关键字PRIMARY定义的索引) ...
随机推荐
- Servlet CDI Example Analysis
上下文和依赖注入(CDI)使您的对象能够自动为它们提供依赖项,而不是创建它们或将它们作为参数接收.CDI还为您管理这些依赖项的生命周期. 例如,来看下面这个servlet: @WebServlet(& ...
- 详解Linux下swig 3.0.12的手动安装过程
详解Linux下swig 3.0.12的手动安装过程 首先 从http://www.linuxfromscratch.org/blfs/view/cvs/general/swig.html上下载swi ...
- Python实现简单的四则运算
GitHub 项目地址 https://github.com/745421831/-/tree/master PSP PSP2.1 Personal Software Process Stages 预 ...
- 关于scrapy
Scrapy安装 1,Pip install wheel 2,pip install 复制路径+文件名Twisted-18.7.0-cp36-cp36m-win_amd64.whl 3,Pip ins ...
- bzoj1668
题解: 简单dp 注意最后往后面多取几个 求个最小值 代码: #include<bits/stdc++.h> using namespace std; ; int n,m,f[N],a[N ...
- http协议与https协议的前世今生
一.Http与Https的区别: HTTP 的URL 以http:// 开头,而HTTPS 的URL 以https:// 开头 HTTP 是不安全的,而 HTTPS 是安全的 HTTP 标准端口是80 ...
- Vue的自定义组件之间的数据传递
一,父级传向子级 1,在子级的属性中添加props:['myname',......],参数可以传多个,看具体而定: 2,在父级data中定义好需要传递的变量数据,例如name:"rose& ...
- presto 函数中使用子查询
我们已知 在sql中子查询可以配合 in 或者 exists 来使用,但是如何把子查询的结果传给函数呢? 场景: 我们有一个 省份表 数据如下: id province 1 广东 2 ...
- 文件操作fopen
这块所谓的"文件操作"就是把文件的内容读进程序,然后根据具体的格式进行解析,或者是显示,或者是修改. 也就是把一个文件加载到程序里面,然后对其进行修改. 文件操作就三步(固定的三步 ...
- Linux VPS自动定时备份网站文件和MYSQL数据库到FTP空间(LNMP)
如果我们网站更新不是很频繁,我们可以定期手动进行备份网站文件和MYSQL数据库导出.如果我们网站数据更新频繁,且数据尤为重要,建议要采用定期自动 备份,至少需要多备份数据,无论我们选择何种优秀的VPS ...