MySQL 数据库操作

stu 表:学生信息表

image

score 表:分数表

image

1. 写出一条sql语句,查出所有学生信息

select * from stu;

2. 写出一条sql语句,查出表中从第2条到第4条学生的信息

select * from stu limit 1,3;

select * from stu where id between 902 and 904;

3. 写出一条sql语句,查出年龄最小的那个学生的信息

select * from stu order by birth desc limit 1;

4. 写出一条sql语句,查出“计算机系”和“英语系”的所有学生信息

select * from stu where department=”计算机系” or department=”英语系”;

5. 写出一条sql语句,查出每一个系总共有多少学生

select count(*) from stu group by department;

6. 写出一条sql语句,查出每一个系的最高分是多少,包括对应的系名信息

select department,max(sc.grade) from stu left join score as sc on stu_id = sc.stu_id group by stu.department;

7. 写出一条sql语句,查出每一个系的最高分的那个学生的信息

select * from  (select a.name,a.id,a.department,b.grade from stu as a join score as b on a.id=b.stu_id) a join (select department,max(grade) grade from stu left join score as sc on stu.id = sc.stu_id group by stu.department) b on a.department=b.department and a.grade=b.grade

MySQL 数据库操作

数据库中有表 members(id、username、post_number、pass、email) 和表 posts(id、members_id、title、content、add_time)

1. 取出表 members 中发帖数量 (post_number) 前10位的名字

select username,post_number from members order by posts_number desc limit 10;

2. 名字为 join 的最新10个发帖的标题

select title from posts where id=(select id from members where username=”join”) order by add_time desc limit 10;

select username.title from members as m join posts as p on m.id=p.members_id where m.username=”join” order by p.add_time desc limit 10;

MySQL 数据库中的字段类型 varchar 和 char 的主要区别

MySQL 数据库中的字段类型 varchar 和 char 的主要区别是什么?哪种字段的查询效率高?

varchar 为存储变长字符串,存储单位为字节,不同的编码方式存储的字符长度不一样,并且会单独用一个字符来存储字符长度。

char 为存储定长字符串,存储单位为字符,最多不超过256个字符。

char 的查询效率高,因为 varchar 会单独存储长度,在查询时先查找长度,然后进行数据的提取,比 char 定长类型多了一个步骤,所以效率第一点。

什么是数据库索引,主键索引、唯一索引的区别,索引的缺点是什么

索引的意义

索引用来快速寻找那些具有特定值的记录。

主键索引和唯一索引的区别

1. 主键索引是一种唯一性索引,且必须指定为“PRIMARY KEY” ,每个表只能有一个主键。

2. 唯一索引索引列的值只能出现一次,即必须唯一。

索引的缺点

1. 创建索引和维护索引徐尧耗费时间,这种时间随着数据量的增加而增加。

2. 索引需要占用物理空间,除了数据表占用数据空间之外,每一个索引还要占用一定的物理空间,如果要建立聚簇索引,则需要的空间会更大。

3. 当对数据表中的数据进行增加、删除、修改的时候,索引也要进行动态的维护,这样就降低了数据的维护速度。