课程回顾

  1. 一对一关联 案例1:查询每个员工的名字和主管领导的名字

    select e.ename 员工姓名,m.ename 领导姓名
    from emp e join emp m
    on e.mgr=m.empno;

    案例2: 查询主管领导名字为blake的所有员工名字

    select e.ename 员工姓名,m.ename 领导姓名 from emp e join emp m on e.mgr=m.empno where m.ename='blake'

    案例3:查询有商品的分类信息及上级分类信息 往titemcategory表内部插入以下数据 id 162 name 办公用品 id 229 name 文具 id 913 name 户外用品 -插入数据

     ,,,'户外用品');

     -查询所有有商品的分类id

    SELECT DISTINCT categoryid FROM titem WHERE categoryid IS NOT NULL

     -查询分类详情

    select * from titemcategory where id in (SELECT DISTINCT categoryid FROM titem WHERE categoryid IS NOT NULL)

     -查询上级分类

     select n.*,c.name 上级分类名称 from (select * from titemcategory where id in (SELECT DISTINCT categoryid FROM titem WHERE categoryid IS NOT NULL)) n join titemcategory c on n.parentid=c.id

    -查询有商品的分类信息及上级分类信息 实现步骤:1.通过子查询查到有商品的分类id 2.把当前分类和上级分类通过内连接建立关系 3.然后把分类的id作为筛选条件 -简单写法

    select c.*,m.name 上级分类 from titemcategory c join titemcategory m on c.parentid=m.id where c.id in (SELECT DISTINCT categoryid FROM titem WHERE categoryid IS NOT NULL);
  2. 一对多关联

    部门 员工 分类 商品 用户 地址 userid -一对多的表中 在多的表中添加关系字段

    案例1:查询每种分类下所对应的所有商品

    select *
    from t_item_category c left join t_item i
    on c.id=i.category_id

    案例2:查询部门平均工资 大于 所有员工的平均工资的所有部门下的所有员工

    SELECT * FROM emp
    WHERE deptno IN (SELECT deptno FROM emp
    WHERE deptno IS NOT NULL
    GROUP BY deptno
    HAVING AVG(sal)>(SELECT AVG(sal) FROM emp))

    案例3:上题结果上再多显示出 部门的名字

     select n.*,d.dname from(SELECT * FROM emp WHERE deptno IN (SELECT deptno FROM emp WHERE deptno IS NOT NULL GROUP BY deptno HAVING AVG(sal)>(SELECT AVG(sal) FROM emp)))n join dept d on n.deptno=d.deptno
  3. 多对多关联 -多对多需要单独通过新建的关系表保存数据

    ));
    
    )); ,),(,),(,),(,),(,),(,),(,),(,); 案例1:查询每个老师对应的所有学生信息 . 子查询 . 内连接 SELECT n.name tname,s.name FROM (SELECT * FROM teacher t JOIN ts ts ON t.id=ts.tid)n JOIN student s ON n.sid=s.id

    案例2:查询 小明 对应的所有老师

    SELECT n.name tname,s.name FROM (SELECT * FROM teacher t JOIN t_s ts ON t.id=ts.tid)n JOIN student s ON n.sid=s.id where s.name='小明'

    案例3:刘老师 对应的所有学生信息

    SELECT n.name tname,s.name FROM (SELECT * FROM teacher t JOIN t_s ts ON t.id=ts.tid)n JOIN student s ON n.sid=s.id where n.name='刘老师';

视图

视图概述

-数据库中存在多种对象,表和视图都是数据库中的对象 **表和视图不能重名**
-视图是张虚拟的表,是通过sql的查询语句查询的结果集的表保存成了一个视图
-视图中的数据 会随着真实表中的数据改变而改变
-视图实际上就是代表了一部分sql语句

-创建视图

-格式:create view 视图名 as 子查询;
); 

案例:创建emp表的部门是20 工资小于3000的 视图
    只保存名字 工资 部门id
create view v_emp_20 as (select ename,sal,deptno from emp
     );

案例:创建emp表 每个部门的工资平均值 的视图
create view v_emp_dept_avg as (select deptno,avg(sal) from emp group by deptno)

-如果创建视图的时候使用了别名,那视图以后的操作只认识别名

-视图的使用方式 和 table 一样 -格式:select * from 视图名

 select * from v_emp_10;
  • 修改视图 -格式:create or replace view 原视图名 as 新的子查询

    create or replace view v_emp_10 as
    ( );
  • 视图的分类 -视图分为:简单视图和复杂视图 -简单视图:在创建视图的子查询中 不包含:关联查询、去重、函数、分组的视图称为简单视图 -复杂视图:和简单视图相反

  • 对视图进行dml操作,只针对简单视图可以使用 因为复杂查询通常情况只是为了浏览数据的,不需要也不能进行增删改的操作

视图的字段 遵循原表字段的约束 - 视图的数据污染 如果往视图中插入一条在视图中不现实 但是在原表中显示的数据,称之为数据污染,不建议这样操作 只有insert命令才会出现数据污染,因为update和delete命令只能操作视图中有的数据

  • with check option create view vemp10 as select * from emp where deptno=10 with check option;

  • 视图的作用

    1. 重用子查询 提高开发效率
    2. 限制数据的访问 比如:可以创建一个视图把原表的敏感信息过滤掉即可 
      create view v_emp as select empno,ename,deptno,comm,job from emp
  • 工作中对视图一般只进行DQL,不使用DML

  • 删除视图

    drop view vemp10;

    -案例:创建一个复杂视图:显示部门的平均工资,最高工资,最低工资,工资总和,部门员工人数;

    create view v_emp_deptinfo as
    select deptno,avg(sal),max(sal),min(sal),sum(sal),count(*)
    from emp
    group by deptno;

索引原理

索引概述

  1. 索引是用来提高查询速度的技术
  2. 如果不使用索引mysql会从第一条数据依次往后查询,如果数据量很大,非常耗时
  3. 添加索引可以提交查询性能,但是如果数据量很小,添加索引可能会降低效率
  4. 索引的生成是数据库内部生成,如果查询数据时发现某个字段已经添加过索引会自动使用

  5. 复合索引

    创建索引时如果设置多个索引字段 则称为复合索引

  6. 创建表的时候直接添加索引

    ), age )));
  7. 更改表的索引

    alter table t11 add index index_age(age);
  8. 删除索引

    drop index index_age on t11;

索引总结

1. 索引不是越多越好
2. 数据量小的时候不需要用到索引
3. 经常出现在 where、order by、 distinct的字段添加索引,效果会更好
4. 不要在经常做增删改的表中添加索引

MySQL 约束

唯一约束(UNIQUE)

如果数据库中的数据需要保证唯一性则添加此约束
));

非空约束(NOT NULL)

如果某个字段的值不能为null 需要使用此约束

));
-以下两种都不可以
,'a');
,null,'b');

默认约束(DEFAULT)

如果需要让某个字段插入数据时有默认值时使用此约束
,name ));

主键约束(PRIMARY KEY)

. 非空、唯一
.如何添加主键
-创建表时添加主键
    create table t4(id int primary key,age int );
    create table t5(id int,age int,primary key(id));
-创建表之后添加主键
    alter table t6 add primary key(id);
    alter table t6 modify id int primary key
-删除主键约束
    alter table t3 drop primary key;
-自增约束 auto_increment
.当字段赋值为null的时候,字段自动增长
.如果删除了某一条数据 自增的数值不回减少
.如果插入数据时指定了一个特别大的数,下次自增则从这个数基础上

外键约束(FOREIGN KEY)

  1. 工作中,除非特殊情况,一般不使用外键,使用代码通过逻辑进行限制
  2. 外键约束是保证一个或两个表之间数据的一致性和完整性的
  3. 表的外键通常使用的是另一张表的主键
  4. 外键可以重复、可以是null、但不可以是另一张表不存在的数据
  5. 使用外键约束的条件 -必须保证两张表使用相同的存储引擎 -存储引擎必须是innodb,myisam不支持外键约束 -外键和关联字段必须有相似的数据类型,数字长度必须相同 -外键约束对应的字段必须创建索引,如果不存在索引,mysql会自动创建索引

创建外键约束

. mysql支持外键的列级语法,但是没有效果,是为了保证和sql的规范的一致性
. 表级约束的添加方式
-格式:CONSTRAINT 约束名 FOREIGN KEY(当前表添加约束的字段名) REFERENCES 关联表表名(关联表的字段名)
));
insert into classes values(null,'一班'),(null,'二班');
CREATE TABLE student(
id INT AUTO_INCREMENT PRIMARY KEY,
name ),
class_id INT,
CONSTRAINT fk_class_id FOREIGN KEY(class_id) REFERENCES classes(id)
);
.创建班级(classes)表 id name
.创建学生表(student)id name classid
给classid添加外键约束
.先往班级表中插入数据 然后往学生表插入数据,

测试插入错数据 和删除 被关联的班级数据

CHECK约束

mysql语法支持,但是没有效果
),
age ));

什么是事务

事务是一组原子性的 SQL 查询, 或者说是一个独立的工作单元. 在事务内的语句, 要么全部执行成功, 要么全部执行失败

事务的 ACID 性质

**必须背下以下4点 面试常考**
-原子性:最小的单元,不可分割
-一致性: 保证sql执行的一致 要么都成功,要么都失败,保证执行前后数据一致
-隔离性:多个事务并发时,互不影响
-持久性:commit提交之后,数据保存到数据库中

MySQL事务

.查看事务是否是自动提交
    show variables like '%autocommit%';
.关闭自动提交
    ;

begin 开始事务
commit 提交事务
rollback 回滚事务

事务案例

转账案例:
.创建user表
    ), money int);
    ,),(,);
.转账sql
     ;
     ;

课程回顾:

1.什么是视图 实际上视图就是一段sql语句

2.视图中数据实际上都是原表中的数据,如果修改视图中的数据 原表数据跟着更改

3.避免出现数据污染 可以通过添加 with check option 避免出现数据污染

4.视图通常只进行查询操作

5.视图作用:子查询复用、限制数据的访问

6.索引index 需要掌握 创建命令和删除命令

7.约束:unique、not null、primary key、default foreign key,check

8.事务 背下来四大特性: 原子性、一致性、隔离性、持久性

day01:

数据库相关的sql:show databases create database db1 character set utf8 show create database db1 drop database db1;

表相关: create table show tables; show create table t1; desc t1; rename table t1 to t2; alter table t1 change age age2 int; alter table t1 modify age long first/after id; add age int; drop age; drop table t1;

insert update delete select

day02:

1.主键 自增 not null 注释:comment

2.去重 distinct

3.事务

4.sql分类 ddl 数据定义语言 create alter drop truncate:删除表内所有数据,内部实现原理:先删除表再创建一个新表 执行效率高 dml 数据操作语言 insert update delete select 支持事务 dql 数据查询语言:select tcl 事务控制语言:begin commit rollback dcl 数据控制语言:控制权限

5.数据类型 整数: int bigint 浮点数: double decimal(m,d)

6.字符串: char varchar text

7.日期:date time datetime timestamp

day03:

聚合函数:sum count avg min max

字符串:charlength instr(x,y) locate(x,y) insert(str,begin,length,newStr) lower upper left right substring(str,begin,length) trim() replace(str,old,new); repeat(str,2); reverse

日期相关:now date(now()) time(now()) extract(year from now()) month day time hour second minute dateformat(now(),'%Y-%m-%d %H-%i-%s') strtodate('','')

数学:+ - * / % mod(2,3)
数学函数: floor  round() rand()

练习

1.案例:创建一张表customer2,id number(4),
name varchar2(50),password varchar2(50)
,age number(3),address varchar2(50),修改
customer2表的时候设置主键约束
pk_id_name_cus2修饰id和name列。

2.案例:创建一张book3表,id number(4),
name varchar2(50),author varchar2(50),
pub varchar2(50),numinput number(10)。
修改book3的时候,设置主键约束
pk_id_name_b3修饰id和name列,设置唯一约束uq_author_pub_b3修饰author和pub列

3.案例:删除temp中的唯一约束uk_name_pwd

4.案例:在book表中author和pub列上添加索引index_author和index_pub

5.案例:删除book中在pub和author上的索引

6.案例:创建一个视图emp_view1,查询emp表中所有的数据,查询语句作为视图emp_view1

7.案例:创建一个视图dept_view,查询dept表中所有的数据,查询语句作为视图dept_view

8.案例:创建一个视图emp_view2,查询emp表中所有员工的编号,姓名,职位,工资,上级领导的编号以及工资的等级,该等级的最低工资和最高工资,查询语句作为emp_view2

9.案例:查询emp表中10,20号部门员工的编号,姓名,职位,工资,所属部门的编号,使用查询语句来修改视图emp_view1

10.案例:删除视图emp_view1,emp_view2

MySql学习笔记06的更多相关文章

  1. MySql学习笔记(一)之DQL常用查询

    MySql学习笔记(一)之DQL常用查询 前言:mysql是中小型的数据库软件,SQL语言分为DDL,DCL,DML,DQL四种,在这里重点讲解DQL的单表查询. 正文:在学习mysql单表查询之前, ...

  2. Mysql学习笔记(三)对表数据的增删改查。

    正文内容. 这一部分是最简单的,也是最麻烦的.简单是因为其实只包括增删该插四个部分.大体上看,增加数据.删除数据.修改数据.查询数据都不麻烦啊,我们日常都是常用的.这个谁不会呢?以前在培训机构学mys ...

  3. MySQL学习笔记一

    MySQL 学习笔记 一 一.数据库简单介绍 1. 按照数据库的发展时间顺序,主要出现了以下类型数据库系统: Ø 网状型数据库 Ø 层次型数据库 Ø 关系型数据库 Ø 面向对象数据库 上面4中数据库系 ...

  4. Mysql学习笔记(二)数据类型 补充

    原文:Mysql学习笔记(二)数据类型 补充 PS:简单的补充一下数据类型里的String类型以及列类型... 学习内容: 1.String类型 2.列类型存储需求 String类型: i.char与 ...

  5. Mysql学习笔记(一)数据类型

    原文:Mysql学习笔记(一)数据类型 学习内容: Mysql基本数据类型. 1.数字类型.. i.整型     Mysql数据类型             含义(有符号)     tinyint(m ...

  6. 初识mysql学习笔记

    使用VMVirtualBox导入Ubuntu后,可以通过sudo apt-get install mysql-server命令下载mysql. 在学习过程中,我遇到了连接不上Xshell的问题.最终在 ...

  7. MySQL学习笔记-锁相关话题

    在事务相关话题中,已经提到事务隔离性依靠锁机制实现的.在本篇中围绕着InnoDB与MyISAM锁机制的不同展开,进而描述锁的实现方式,多种锁的概念,以及死锁产生的原因.   Mysql常用存储引擎的锁 ...

  8. MySQL学习笔记-事务相关话题

    事务机制 事务(Transaction)是数据库区别于文件系统的重要特性之一.事务会把数据库从一种一致状态转换为另一个种一致状态.在数据库提交工作时,可以确保其要么所有修改都已经保存了,要么所有修改都 ...

  9. MySQL学习笔记-数据库文件

    数据库文件 MySQL主要文件类型有如下几种 参数文件:my.cnf--MySQL实例启动的时候在哪里可以找到数据库文件,并且指定某些初始化参数,这些参数定义了某种内存结构的大小等设置,还介绍了参数类 ...

随机推荐

  1. vs2010的帮助文档

    系统重装了,发现vs2010的帮助无论如何都是web方式,这种体验很差劲. google了才明白,原来是ms发展过程的一个败笔. 需要升级到vs2010 sp1才会有跟以前一样的帮助系统. 彻底无语了 ...

  2. 【Linux】GCC编译

    GCC简介 GCC基本用法 GCC程序产生过程 GCC编译选项 一.GCC简介 1.1 GCC特点 Gcc(GNU C Compiler)是GNU推出的功能强大.性能优越的多平台编译器,是GNU的 代 ...

  3. python大数据

    http://blog.csdn.net/xnby/article/details/50782913 一句话总结:spark是一个基于内存的大数据计算框架, 上层包括了:Spark SQL类似Hive ...

  4. Microsoft Fluent Design System

    转载自:http://www.ui.cn/detail/131217.html 就在刚刚举办的 Microsoft Build 2017 中,微软对外公布了它们最新的设计语言--"Fluen ...

  5. swftools 将pdf转换swf常见问题说明

    swftools将PDF转成swfSWFTools提供了一系列将各种文件转成swf的工具: font2swf.exe gif2swf.exe jpeg2swf.exe pdf2swf.exe png2 ...

  6. Dynamics CRM 批量新建域用户

    好久没写了,今天大牛教了我偷懒的批量新建域用户的方法 是不是觉得  控制面板 =>管理工具=>用户和计算机=>Users=>新建用户,一个个建,很烦是不是,而且耗时,我上个项目 ...

  7. JavaScript工作机制:V8 引擎内部机制及如何编写优化代码的5个诀窍

    概述 JavaScript引擎是一个执行JavaScript代码的程序或解释器.JavaScript引擎可以被实现为标准解释器,或者实现为以某种形式将JavaScript编译为字节码的即时编译器. 下 ...

  8. Qt 窗口移动实现

    很多人觉得系统自带的标题栏太丑了,想要自绘一个标题栏,去掉了系统自带的标题栏后,就需要自己实现窗口移动,下面的代码就是实现窗口移动. widget.h #ifndef WIDGET_H #define ...

  9. linux命令有用

    uptime 命令用来输出系统任务队列信息 last 列出目前与过去登入系统的用户相关信息 free 用来显示系统内存状态 ps 相應的選項組合為ps -ef.ps aux,可以通過這些組合準確定位系 ...

  10. bootstrap table 主子表 局部数据刷新(刷新子表)

    1.主表中设置data-detail-view="true",启用主子表模式: <table class="table table-striped" wi ...