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 外键和子查询,视图的更多相关文章

  1. MySQL外键和高级查询(连接查询、联合查询、子查询、去重查询)

    MySQL的外键 什么是外键,很简单保持数据一致性的一个约束键.如果你有两张表,第一张是学生表,第二张表是一个成绩表,我们来看看保持数据一致性,其实在Django等框架的模型中中也能做关联获取对象. ...

  2. SQL主外键和子查询

    主键 数据库主键是指表中一个列或列的组合,其值能唯一地标识表中的每一行.这样的一列或多列称为表的主键,通过它可强制表的实体完整性.当创建或更改表时可通过定义 PRIMARY KEY约束来创建主键.一个 ...

  3. 数据库开发基础-SQl Server 主键、外键、子查询(嵌套查询)

    主键 数据库主键是指表中一个列或列的组合,其值能唯一地标识表中的每一行.这样的一列或多列称为表的主键,通过它可强制表的实体完整性.当创建或更改表时可通过定义 PRIMARY KEY约束来创建主键.一个 ...

  4. 2016年11月17日--SQL主、外键,子查询

    主键 数据库主键是指表中一个列或列的组合,其值能唯一地标识表中的每一行.这样的一列或多列称为表的主键,通过它可强制表的实体完整性.当创建或更改表时可通过定义 PRIMARY KEY约束来创建主键.一个 ...

  5. SQL主、外键,子查询

    主键 数据库主键是指表中一个列或列的组合,其值能唯一地标识表中的每一行.这样的一列或多列称为表的主键,通过它可强制表的实体完整性.当创建或更改表时可通过定义 PRIMARY KEY约束来创建主键.一个 ...

  6. MySQL 外键 表的查询

    自增补充 这是查看怎么创建的表, \G示旋转90度显示表的内容 表的自增的关键是** AUTO_INCREMENT=3**,在表中添加数据后,这个会自动改变,通过alert可以改变这个默认值 mysq ...

  7. mysql外键与表查询

    目录 自增特性 外键 外键关系 外键创建 外键的约束效果 级联更新级联删除 多对多关系 一对一关系 表查询关键字 select与from where筛选 group by分组 练习 关系练习 查询练习 ...

  8. MYSQL - 外键、约束、多表查询、子查询、视图、事务

    MYSQL - 外键.约束.多表查询.子查询.视图.事务 关系 创建成绩表scores,结构如下 id 学生 科目 成绩 思考:学生列应该存什么信息呢? 答:学生列的数据不是在这里新建的,而应该从学生 ...

  9. MySQL外键约束On Delete、On Update各取值的含义

    主键.外键和索引的区别?   主键 外键 索引 定义: 唯一标识一条记录,不能有重复的,不允许为空 表的外键是另一表的主键, 外键可以有重复的, 可以是空值 主索引(由关键字PRIMARY定义的索引) ...

随机推荐

  1. 路由导航之第一个子模块(HomeModule)

    git clone git@github.com:len007/my-angular2-app.git my-angular2-app 开始 一个URL = 一个页面 = 一个Component. 我 ...

  2. 信用卡欺诈数据的分析-excel篇

    本篇文章为大家提供了数据集分析的思路和步骤,同时也分享了自己的经验. 一.背景 反欺诈是一项识别服务,是对交易诈骗.网络诈骗.电话诈骗.盗卡盗号等行为的一项风险识别.其核心是通过大数据的收集.分析和处 ...

  3. python修炼第五天

    第五天,感觉开始烧脑了.递归逻辑难,模块数量多,但是绝世武功都是十年磨一剑出来的!稳住! 1 递归. 定义-----递归就是在函数的内部调用自己递归深度 998不建议修改递归深度,因为如果998都没有 ...

  4. python学习------面向对象的程序设计

    一 面向对象的程序设计的由来 1940年以前:面向机器 最早的程序设计都是采用机器语言来编写的,直接使用二进制码来表示机器能够识别和执行的指令和数 据.简单来说,就是直接编写 和 的序列来代表程序语言 ...

  5. Mybatis逆向工程自动生成代码(Ubuntu18.04-idea环境)

    最近在学习taotao商城项目,有一节是关于mybatis逆向工程的,参考了这个博文,https://blog.csdn.net/yerenyuan_pku/article/details/71909 ...

  6. Python-接口自动化(九)

    python操作Excel处理测试数据(九) (十)python操作Excel读/写测试数据 1.夹心饼干 setUp:在每一条测试用例执行之前执行 tearDown:在每一条测试用例执行之后执行 上 ...

  7. mysql 关于数据库和数据表的基本操作

    -- 备注: -- .每一条mysql语句后面都需要加上半角分号 -- .可以用``符号(1键旁边的那个键)将字段名称引用起来,如`Name` -- .mysql在windows下不区分大小写,在li ...

  8. JavaEE第六周

    Applet简介 Java Applet简介 最近要使用worldwind java sdk做Applet开发,看了些Applet的资料,为了防止忘记,记录如下: applet是通过<apple ...

  9. python之路-数据类型(方法)

    Int i = 1 print(i.bit_length()) # 转化成二进制的最小位数. ''' 0000 0001 ''' Str class str(basestring): "&q ...

  10. yuv2mp4

    >您使用什么类型的YUV像素格式?最常见的格式是YUV4:2:0平面8位(YUV420p).您可以键入ffmpeg -pix_fmts以获取所有可用格式的列表.>什么是帧率?在我的例子中, ...