linux学习day08----mysql03

1.子查询:
		以select语句作为结果进行再次select
2.分组Top1
		格式1:select * from student where age in (select max(age) from student group by sex);
		格式2:select * from  student as s where age=(select max(age) from student where sex=s.sex)
3.分组Top3(下面的代码)

在这里插入图片描述

4.mysql三大范式
		(1)原子性 字段不可在分割
		(2)唯一性 字段必须依赖于主键
		(3)冗余性 避免数据量过大
5.连表联查
		union:多个结果集进行合并(纵)
				格式:select 字段 from 表名 union 表名;
				注意:查询是多张表的字段数量保持一致
					 直接使用union时,相同的数据指显示一行
					 使用union all时,相同的数据都会显示
					 查询结果的列名以第一次sql语句的结果列为准
		 join:
		 		left join:左表为准,匹配右表的数据,左表中的数据匹配不到右表的数据就显示null,右边的数据和左表匹配就不会显示
		 				  格式: select 字段 from 表名 left join 表名 on 连接条件;
		 		right join:右表为准,匹配左表的数据,右表中的数据匹配不到左表的数据就显示null,左边的数据和右表不匹配就不会显示
		 					格式:select 字段 from 表名 right join 表名 on 连接条件;
		 		inner join:两表的交集
		 					格式:select 字段 from 表名 inner join 表名 on 连接条件;
逻辑判断:case when 判断条件 then 值 [when 判断条件 then]* [else 值] end
从其他表中加载数据:
				格式1: create table 表名 as 查询语句
				例如:create table student1 as select * from student;
				格式2:insert into 表名 查询语句
				例如:insert into test select * from student;
视图:是一张虚拟表,数据都是存储在基础表中
	 创建视图:
	 	  格式:create view 表名 as 查询语句;
	 	  例如:create view tmp as select * from student_info where age=25;
	 查看视图结构:
	 		格式:desc 表名
	 		例如:desc tmp;
	 		格式:show create view/table 表名;
	 		例如:show create table temp;
	 删除视图:
	 		格式:drop view 表名
	 		例如:drop view tmp;
	 视图和基础表的关系是一对一:在视图中进行增删查改是,会在基础表上发生改变
	 视图和基础表的关系是一对多:视图中不能进行insert和delete
	 from--where--group by--having--select--order by
	 from:需要从那个数据表检索数据
	 where:过滤表中的数据条件
	 group by:如何将上面过滤出的数据分组
	 having:对上面已经分组的数据进行过滤的条件
	 select:查看结果集中的那个列,或列的计算结果
	 order by:按照什么样的顺序来查看返回的数据
6.索引:主键默认拥有一个索引
	   索引不是越多越好,因为索引也需要存储空间去存放,索引越多占的资源就越多
	   添加索引:
	   		格式:alter table 表名 add index 索引名称(索引列);
	   		例如:alter table student add index index_name(name)
		删除索引:
			格式:alter table 表名 drop index 索引名称;
			例如:alter table student drop index index_name;
7.事务:一个操作下可以分为多个操作,事物决定了这多个小操作都实行完成,才认为这个操作执行结束
		执行事务之前关闭自动提交:set autocommit=0;
		事务的操作:
			 begin:开始一个事务
			 rollback:事务出现问题进行回滚
			 commint:事务没有问题进行提交
		例如:
			begin;
			update person set money=5000-2000;
			update bank set money=0+2000;
			select * from person;
			select * from bank;
			commit;
		注意:事务中所有的操作都是临时或虚拟的,在进行commit才会把这些操作在原始数据上进行执行
8.shell操作mysql
		格式:
			#!/bin/bash
			MYSQL="mysql -h192.168.152.110 -uroot -p123456 --default-character-set=utf8"
			sql="select * from shujia.student"
			result="$($MYSQL -e "$sql")"
			echo -e "$result"
		

	
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值