1、跟用户相关的命令 (了解). DCL语句
    1.1、 创建一个新的用户
        CREATE USER 用户名@地址 IDENTIFIED BY '密码';
        CREATE USER jerry@localhost IDENTIFIED BY '1234';
    1.2、为用户添加权限
        语法:GRANT 权限1, … , 权限n ON 数据库.* TO 用户名@IP
        例子:GRANT CREATE,ALTER,DROP,INSERT,UPDATE,DELETE,SELECT ON day15.* TO jerry@localhost;
    1.3、撤销授权
        REVOKE权限1, … , 权限n ON 数据库.* FORM 用户名
        REVOKE CREATE,ALTER,DROP ON day15.* FROM jerry@localhost;
    1.4、查看用户的权限 SHOW GRANTS FOR 用户名@主机;
        SHOW GRANTS FOR jerry@localhost;
    1.5、修改用户密码UPDATE
        UPDATE USER SET PASSWORD=PASSWORD(‘密码’) WHERE User=’用户名’ FLUSH PRIVILEGES;
        例子: UPDATE USER SET PASSWORD=PASSWORD('1234') WHERE User='jerry' FLUSH PRIVILEGES;

2、备份数据库 (不属于sql语句)
        mysqldump -u root -p 1234 day15 > d:/day15.sql
    恢复数据库
    2.1、需要登录到数据库中
        source d:/day15.sql;
   2. 2、mysql命令恢复,不需要登录
        mysql -u root -p day15 < d:/day15.sql

3、多表
    我们现在使用的数据库叫做关系型数据库.
    3.1、表关系
        一对多/多对一: 在多的一方加入1的一方的外键
        多对多: 使用中间表,分别引用两方的ID
        一对一:
          1> 主键同步 两个表中有关系的记录id一致.
          2> 在1方加入 另一方的外键
          3> 在另一方加入外键.
    3.2、多表数据完整性约束
        外键约束
        增加一个外键约束
        ALTER TABLE `day16`.`emp` ADD CONSTRAINT `fk_emp_dept` FOREIGN KEY (`DEPTNO`) REFERENCES `day16`.`dept`(`DEPTNO`);
        删除一个外键约束
        ALTER TABLE `day16`.`emp` DROP FOREIGN KEY `emp_ibfk_1`;
        外键约束保证了数据的完整性.加入外键约束后, 如果主键被任何一个外键所引用.那么无法删除这条记录.只要在所有引用都删除的情况下,才可以删除这条记录.
          非空约束 not null
          唯一约束 unique
          主键约束 primary key

4、多表查询
    笛卡尔积
        select * from emp,dept;
     这种查询会将两个表的记录 分别逐个连接. 得到的记录数 是两个表记录数相乘的结果.
     这种查询往往是没有意义的. 因为会产生很大一部分无效数据.
     开发中应避免出现笛卡尔积的情况.
  内连接
       *查询所有有部门的员工以及员工的部门信息
       select * from emp,dept where emp.deptno = dept.deptno;
    这种查询就是内连接查询.
    展示内连接的完整写法.
    select * from emp inner join dept on emp.deptno = dept.deptno;

外连接
      左外连接
      *查询所有员工信息(包括没有部门的员工),以及部门信息.
      select * from emp left join dept on emp.deptno= dept.deptno;

右外连接
      *查询所有部门信息(包括没有员工的部门),以及员工信息.

=====================================================================================

5、子查询
      概念: 就是一个查询的条件需要用到另一个查询的结果.使用子查询就是将两个sql语句嵌套一步完成.
    -- 查询出 所有员工中 工资高于名叫 SMITH 的员工信息
    -- 子查询的结果是 1行1列 => 当作一个值
    -- 传统方式 2步
     -- 1> 查询SMITH
          SELECT sal FROM emp WHERE ename='SMITH';
     -- 2> 工资高于名叫 SMITH 的员工信息
          SELECT * FROM emp WHERE sal > 800;
    -- 子查询
          SELECT * FROM emp WHERE sal > (SELECT sal FROM emp WHERE ename='SMITH');

-- 问题: 相比传统查询,子查询会提高查询效率吗? 不会
    -- 查询出 所有员工中 比 20号部门 所有员工工资都高的员工信息
    -- 子查询的结果是 多行1列 => 当作一个集合
    -- 传统
          SELECT MAX(sal) FROM emp WHERE deptno=20;
          SELECT * FROM emp WHERE sal > 3000;
   -- 子查询
      -- SELECT * FROM emp WHERE sal > (SELECT MAX(sal) FROM emp WHERE deptno=20);
      SELECT * FROM emp WHERE sal > ALL (SELECT sal FROM emp WHERE deptno=20);
   -- 查询出 所有员工中 比 20 号部门最低的工资高的员工信息
   -- 子查询的结果是 多行1列
    -- 子查询
        SELECT * FROM emp WHERE sal > (SELECT MIN(sal) FROM emp WHERE deptno=20);
       SELECT * FROM emp WHERE sal > ANY (SELECT sal FROM emp WHERE deptno=20);
-- 查询出 员工信息 以及 员工领导的名字
-- 子查询的结果是 多行多列 => 当作一张表
        SELECT e1.`ENAME` AS 员工名称 , e2.`ENAME` AS 领导名称 FROM emp e1,emp e2   WHERE e1.`MGR` = e2.`EMPNO`;
        SELECT e1.`ENAME` AS 员工名称 , e2.`ENAME` AS 领导名称 FROM emp e1,(SELECT *  FROM emp) e2 WHERE e1.`MGR` = e2.`EMPNO`;

子查询分类:
一行一列,将子查询的结果当做单个值.
多行一列,将子查询结果当做一个集合.
多行多列,将子查询结果当做一张表.

子查询关键字:
all
条件 > all(子查询) --> 大于子查询中最大值
条件 >= all(子查询) --> 大于等于子查询中最大值
条件 < all(子查询) --> 小于子查询中最小值
条件 <= all(子查询) --> 小于等于子查询中最小值
any
条件 > any(子查询) --> 大于子查询中最小值
条件 >= any(子查询) --> 大于等于子查询中最小值
条件 < any(子查询) --> 小于子查询中最大值
条件 <= any(子查询) --> 小于等于子查询中最大值

子查询比较普通查询会不会提高效率?
子查询不会提高效率.

Mysql学习第四天的更多相关文章

  1. MySql学习笔记四

    MySql学习笔记四 5.3.数据类型 数值型 整型 小数 定点数 浮点数 字符型 较短的文本:char, varchar 较长的文本:text, blob(较长的二进制数据) 日期型 原则:所选择类 ...

  2. 转MYSQL学习(四) 查询

    MySQL中select的基本语法形式: select 属性列表 from 表名和视图列表 [where 条件表达式] [group by 属性名[having 条件表达式]] [order by 属 ...

  3. MySQL学习(四) SQL连接查询

    更多情况下,我们查询的数据来源于多张表,所有有必要了解一下MySQL中的连接查询. SQL中将连接查询分成四类:交叉连接,内连接,外连接和自然连接. 数据准备 student表 -- -------- ...

  4. MySQL学习(四)深入理解乐观锁与悲观锁

    转载自:http://www.hollischuang.com/archives/934 在数据库的锁机制中介绍过,数据库管理系统(DBMS)中的并发控制的任务是确保在多个事务同时存取数据库中同一数据 ...

  5. MySQL学习笔记四:字符集

    1.字符集就是字符和其编码的集合,查看数据库支持的字符集 show character set 2.查看服务端启动时默认的字符集 mysql> show variables like 'char ...

  6. mysql学习(四)-字段类型

    mysql数据类型: 数值型: 整形:int 浮点型:float double decimal:定点型 日期: date  '2012-01-02' time '10:01:01' datetime ...

  7. MySQL学习笔记(四)—存储过程

    一.概述      存储过程是数据库定义的一些SQL语句的集合,然后直接调用这些存储过程和函数来执行已经定义好的SQL语句.存储过程可以避免开发人员重复的编写相同的SQL语句,而且存储过程是在MySq ...

  8. MySQL学习笔记(四):存储引擎的选择

    一:几种常用存储引擎汇总表 二:如何选择 一句话:除非需要InnoDB 不具备的特性,并且没有其他办法替代,否则都应该优先考虑InnoDB:或者,不需要InnoDB的特性,并且其他的引擎更加合适当前情 ...

  9. MySQL学习(四)Join 等开发常用的操作 --- 2019年2月

    1.查数据太多不会把内存用光 InnoDB 的数据是保存在主键索引上,然后索引树分割保存在数据页上,数据页存在内存中/磁盘.change buffer 就是先把修改操作记录,然后读数据的时候,内存没有 ...

  10. mysql学习笔记四 —— AB复制

    要点:ab复制 mysql集群架构流程: ABB(主从复制)-->MHA(实现mysql高可用.读写分离.脚本控制vip飘逸)-->haproxy(对slave集群实现分发,负载均衡)-- ...

随机推荐

  1. SprimgMVC学习笔记(五)—— Controller方法返回值

    一.返回ModelAndView controller方法中定义ModelAndView对象并返回,对象中可添加model数据.指定view. /** * 查询商品列表 * @return */ @R ...

  2. windows_study_2

    描述:如何确定像%ProgramFiles%这样格式的目录的具体位置? 解决:运行——cmd——echo %ProgramFiles%——回车——界面就显示出目录位置了.

  3. hdu6397 Character Encoding 隔板法+容斥原理+线性逆元方程

    题目传送门 题意:给出n,m,k,用m个0到n-1的数字凑出k,问方案数,mod一个值. 题目思路: 首先如果去掉数字范围的限制,那么就是隔板法,先复习一下隔板法. ①k个相同的小球放入m个不同的盒子 ...

  4. css雪碧图制作

    使用css背景合并工具cssSprite 工具下载链接: http://download.csdn.net/download/wx247919365/8741243 1.选择文件 2.生成雪碧图 3. ...

  5. nginx配置应用

    启动nginxvim /usr/local/lnmp/nginx/conf/nginx.conf mkdir /wwwcd /wwwvim index.html www.westos.orgmkdir ...

  6. linu samba服务

    关闭防火墙并且重启网络yum install samba  samba-client samba-commmon -ysystemctl start smb smbclient -L //172.25 ...

  7. 2048小游戏(Java)(swing实现)(一)

    自己写的2048小游戏,仅支持鼠标操作 主要是我不知道怎么添加键盘监听 import javax.swing.*; import java.awt.*; import java.awt.event.* ...

  8. 结合element-ui表格自动生成sku规格列表

    最近在写一个根据输入的规格,属性值动态生成sku表格,实现的效果大致如图,这是在vue项目里,结合element-UI表格写的,写好了就整理了一下,把代码贴上来,方便以后使用,不过代码里还是有一些重复 ...

  9. Office 2016 word无法粘贴(Ctrl + V)

    最近下载了一个 Office 2016 专业版 使用,发现 word 无法使用 Ctrl + V 粘贴东西,由于经常需要复制粘贴东西,无法粘贴影响很大 查了很多资料,尝试过很多的方法,终于发现问题的所 ...

  10. SpringBoot中通过实现WebMvcConfigurer完成参数校验

    在Spring5.0和SpringBoot2.0中废弃了WebMvcConfigurerAdapter类. 现有两种解决方案 1 直接实现WebMvcConfigurer (官方推荐)2 直接继承We ...