mysql高级

mysql支持三种类型的连接查询,分别为:

内连接,左连接,右连接


内连接:   where /     inner join         /   join        

(1)select s.name,c.name from mingxingstudents as s ,classes as c where s.cls_id=c.id;

(2)select s.name,c.name from mingxingstudents as s inner join classes as c on s.cls_id=c.id;

(3)select s.name,c.name from mingxingstudents as s join classes as c on s.cls_id = c.id;

(4)select s.name,c.name from mingxingstudents as s cross join classes as c on s.cls_id = c.id;


左右连接查询

左连接查询(左边的表是主表,全部显示,右边的是从表)

select s.name,c.name from mingxingstudents as s left outer join classes as c on s.cls_id = c.id;

(上面这个查询语句中的outer可以省略select s.name,c.name from mingxingstudents as s left join classes as c on s.cls_id = c.id;

)

右连接查询(刚好与左连接相反)

select s.name,c.name from mingxingstudents as s right outer join classes as c on s.cls_id = c.id;

交叉查询(容易产生笛卡儿积现象)

select * from mingxingstudents cross join classes;

自关联查询的基本操作

(自连接,自身关联自身,自连接必然用到子查询)

select p.name as省,c.name as 市 from province as p inner join province as c on c.pid = p.id where p.name ="河北省"

子查询

在一个 select 语句中,嵌入了另外一个 select 语句, 那么被嵌入的 select 语句称之为子查询语句

主查询:主要查询的对象,第一条 select 语句

主查询和子查询的关系:子查询是嵌入到主查询中;子查询是辅助主查询的,要么充当条件,要么充当数据源;子查询是可以独立存在的语句,是一条完整的 select 语句

子查询分类:

(1)标量子查询: 子查询返回的结果是一个数据(一行一列)  select avg(height) from mingxingstudents;

(2)列级子查询: 返回的结果是一列(一列多行)select classes.name from classes inner join mingxingstudents on classes.id = mingxingstudents.cls_id;

(3)行级子查询: 返回的结果是一行(一行多列)select max(age),max(height) from mingxingstudents;

查询班级中年龄最小并且身高也最小的人:

select  * from mingxingstudents where (age,height) = (select min(age),min(height)from mingxingstudents);

(4)表级子查询: 返回的结果是多行多列(一般不用,查询效率相对费时间。可以使用连接查询实现的)

select t.sname,t.cname from (select s.name as sname,c.name as cname from mingxingstudents as s inner join classes as c on s.cls_id = c.id) as t;

子查询中出现的关键字

any与some,any与in等价

select classes.name from classes where id = any(select cls_id from mingxingstudents);

select classes.name from classes where id in(select cls_id from mingxingstudents);

where 列 = all(列子查询):等于里面所有

where 列 <> all(列子查询):不等于其中所有

select classes.name from classes where id = all(select cls_id from mingxingstudents);

select classes.name from classes where id <> all(select cls_id from mingxingstudents);

in范围

select classes.name from classes where id not in(select cls_id from mingxingstudents);


select * from goods where price >(select avg(price) from goods) order by price desc;

select price from goods where cate = '超级本' order by price;

select * from goods where price >= any(select price from goods where cate ='超级本') order by price desc;



将一个表进行分表处理

判断不存在创建一个空表create table if not exists goods_cates(id int unsigned primary key auto_increment,cate_name varchar(40));

将查询到的数据插入到表中insert into goods_cates(cate_name) select cate from goods group by cate;

将原表中的字段设置成对应的新表里的id

update goods as g inner join goods_cates as c on g.cate = c.cate_name set g.cate = c.id;

再创建一个新表并插入数据

create table goods_brands(id int unsigned primary key auto_increment not null,brand_name varchar(40))select brand_name from goods group by brand_name;

再次更新原表(将brand_name = 设置为brand_id)

update goods as g inner join goods_brands as b on g.brand_name = b.brand_name set g.brand_name = b.id;



修改表结构:(修改了两个部分,cate的类型被修改成int,brand_name 修改成了brand_id,类型为int)

alter table goods change cate cate_id int unsigned,change brand_name brand_id int unsigned;



多张表的连接查询

(两个左连接的方式)select * from goods as g left join goods_cates as c on g.cate_id = c.id left join goods_brands as b on g.brand_id = b.id;

(两个右连接的方式)select * from goods as g right join goods_cates as c on g.cate_id =c.id right join goods_brands as b on g.brand_id = b.id;

(两个内连接)select * from goods as g inner join goods_cates as c on g.cate_id =c.id inner join goods_brands as b on g.brand_id = b.id;


外键约束的创建和删除

alter table goods add foreign key (brand_id) references goods_brands(id);

alter table goods add foreign key (cate_id) references goods_brands(id);

删除外键:alter table goods drop  foreign key goods_ibfk_1;

删除key:alter table goods drop key catte_id;


备份和还原

备份一个表:(注意:退出mysql后使用)

mysqldump -uroot -p python students > D:\ps.sql

备份一个数据库:

mysqldump -uroot -p python > D:\ss.sql

备份多个数据库


视图


视图的创建:create view v_mstu as select * from mingxingstudents;

视图的查询:select * from v_mstu

删除视图:drop view v_mstu

索引

一种特殊的文件(InnoDB数据表上的索引是表空间的一个组成部分),它们包含着对数据表所有记录的引用指针。

查看索引:show index from 表名;

创建索引:create index 索引名 on 表名

删除索引:drop index 索引名 on 表名


开启运行时间:set profiling=1

显示查看所需时间: show profiling;

当数据表中创建主键和外键的时候,就会自动的创建索引。

建立太多的索引将会影响更新和插入的速度,因为它需要同样更新每个索引文件。对于一个经常需要更新和插入的表格,就没有必要为一个很少使用的where字句单独建立索引了,对于比较小的表,排序的开销不会很大,也没有必要建立另外的索引。建立索引会占用磁盘空间。


数据库的交互

connect对象:host,port,database,user,password,charset

对象的方法:

close

commit,

rollback,

cursor()返回cursor对象,执行sql语句并获得结果

execute()执行语句

fetchone()

fetchall()

调用connection对象的cursor()方法:cursor=conn.cursor()

对象的属性:

rowcount只读属性,表示最近一次execute()执行后受影响的行数

connection获得当前连接对象

你可能感兴趣的:(mysql高级)