mysql 备份恢复后索引_mysql数据库的基本操作:索引、视图,导入和导出,备份和恢复...

1、索引:

索引是一种与表有关的结构,它的作用相当于书的目录,可以根据目录中的页码快速找到所需的内容。

当表中有大量记录时,若要对表进行查询,没有索引的情况是全表搜索:将所有记录一一取出,和查询条件进行一一对比,然后返回满足条件的记录。这样做会消耗大量数据库系统时间,并造成大量磁盘 I/O 操作。

而如果在表中已建立索引,在索引中找到符合查询条件的索引值,通过索引值就可以快速找到表中的数据,可以大大加快查询速度。

对一张表中的某个列建立索引,有以下两种语句格式:

ALTER TABLE 表名字 ADD INDEX 索引名 (列名);

CREATE INDEX 索引名 ON 表名字 (列名);

例如:

ALTER TABLE employee ADD INDEX idx_id (id); #在employee表的id列上建立名为idx_id的索引

CREATE INDEX idx_name ON employee (name); #在employee表的name列上建立名为idx_name的索引

索引的效果是加快查询速度,当表中数据不够多的时候是感受不出它的效果的。这里我们使用命令 SHOW INDEX FROM 表名字; 查看刚才新建的索引:

7491f381a4131a97021b20b176de49aa.png

在使用 SELECT 语句查询的时候,语句中 WHERE 里面的条件,会自动判断有没有可用的索引。

比如有一个用户表,它拥有用户名(username)和个人签名(note)两个字段。其中用户名具有唯一性,并且格式具有较强的限制,我们给用户名加上一个唯一索引;个性签名格式多变,而且允许不同用户使用重复的签名,不加任何索引。

这时候,如果你要查找某一用户,使用语句 select * from user where username=? 和 select * from user where note=? 性能是有很大差距的,对建立了索引的用户名进行条件查询会比没有索引的个性签名条件查询快几倍,在数据量大的时候,这个差距只会更大。

一些字段不适合创建索引,比如性别,这个字段存在大量的重复记录无法享受索引带来的速度加成,甚至会拖累数据库,导致数据冗余和额外的 CPU 开销。

2、视图:

视图是从一个或多个表中导出来的表,是一种虚拟存在的表。它就像一个窗口,通过这个窗口可以看到系统专门提供的数据,这样,用户可以不用看到整个数据库中的数据,而只关心对自己有用的数据。

注意理解视图是虚拟的表:

数据库中只存放了视图的定义,而没有存放视图中的数据,这些数据存放在原来的表中;

使用视图查询数据时,数据库系统会从原来的表中取出对应的数据;

视图中的数据依赖于原来表中的数据,一旦表中数据发生改变,显示在视图中的数据也会发生改变;

在使用视图的时候,可以把它当作一张表。

创建视图的语句格式为:

CREATE VIEW 视图名(列a,列b,列c) AS SELECT 列1,列2,列3 FROM 表名字;

可见创建视图的语句,后半句是一个 SELECT 查询语句,所以视图也可以建立在多张表上,只需在 SELECT 语句中使用子查询或连接查询,这些在之前的实验已经进行过。

现在我们创建一个简单的视图,名为 v_emp,包含v_name,v_age,v_phone三个列:

例如:CREATE VIEW v_emp (v_name,v_age,v_phone) AS SELECT name,age,phone FROM employee;

4a0c22fb490196ac81eb918d5f93f57c.png

3、导入:

此处讲解的是导入一个纯数据文件,该文件中将包含与数据表字段相对应的多条数据,这样可以快速导入大量数据,除此之外,还有用 SQL 语句的导入方式,语法为:source *.sql 这是实验中经常用到的。两者之间的不同是:数据文件导入方式只包含数据,导入规则由数据库系统完成;SQL 文件导入相当于执行该文件中包含的 SQL 语句,可以实现多种操作,包括删除,更新,新增,甚至对数据库的重建。

数据文件导入,可以把一个文件里的数据保存进一张表。导入语句格式为:

LOAD DATA INFILE '文件路径和文件名' INTO TABLE 表名字;

由于导入导出大量数据都属于敏感操作,根据 mysql 的安全策略,导入导出的文件都必须在指定的路径下进行,在 mysql 终端中查看路径变量:

789a75ba28afa4e110b1d6b552623011.png

注意到 secure_file_priv 变量指定安全路径为 /var/lib/mysql-files/ ,要导入数据文件,需要将该文件移动到安全路径下。

b1fc9dd40f5ebbae374a90531e378855.png

查看文件里的内容为:

7a2b9f49db6b263c64c20231d3798266.png

导入之前的表数据:

9ce2429185c970ad2bd8ae252e6cf379.png

导入之后的表数据:

0cab7f4d586ca67c50064ada52b25276.png

4、导出:

导出与导入是相反的过程,是把数据库某个表中的数据保存到一个文件之中。导出语句基本格式为:

SELECT 列1,列2 INTO OUTFILE '文件路径和文件名' FROM 表名字;

注意:语句中 “文件路径” 之下不能已经有同名文件。

现在我们把整个 employee 表的数据导出到 /var/lib/mysql-files/ 目录下,导出文件命名为 out.txt 具体语句为:

SELECT * INTO OUTFILE '/var/lib/mysql-files/out.txt' FROM employee;

03be23ca5e1d092fe96efe2480b1ceaf.png

查看导出的文件:

2f1141546934ac0772b9252d3d826ac0.png

4、备份:

数据库中的数据十分重要,出于安全性考虑,在数据库的使用中,应该注意使用备份功能。

备份与导出的区别:导出的文件只是保存数据库中的数据;而备份,则是把数据库的结构,包括数据、约束、索引、视图等全部另存为一个文件。

mysqldump 是 MySQL 用于备份数据库的实用程序。它主要产生一个 SQL 脚本文件,其中包含从头重新创建数据库所必需的命令 CREATE TABLE INSERT 等。

使用 mysqldump 备份的语句:

mysqldump -u root 数据库名>备份文件名; #备份整个数据库

mysqldump -u root 数据库名 表名字>备份文件名; #备份整个表

mysqldump 是一个备份工具,因此该命令是在终端中执行的,而不是在 mysql 交互环境下。

631ed505781ce1078c4b0ddbecaca869.png

5、恢复:

用备份文件恢复数据库,其实我们早就使用过了。在本次实验的开始,我们使用过这样一条命令:

source /tmp/SQL6/MySQL-06.sql

也可以新建一个数据库:

mysql -u root   #因为在上一步已经退出了MySQL,现在需要重新登录

CREATEDATABASEtest;  #新建一个名为test的数据库

4dbb9da367dea4ce62baeae3b47606f8.png

mysql -u root #因为在上一步已经退出了MySQL,现在需要重新登录

use test #连接数据库test

SHOW TABLES; #查看test数据库的表

cc16fff918b552757016b446947006e0.png

查看表中数据:

51d36c5dc60f592c91374d9070e31478.png

练习:

使用子查询或连接,建立多张表的视图,再用 SELECT 语句展示出视图的内容。

55f405ec5d6bfd74003aaa3ee2469f70.png

380a8f2b7bb85b0418577d1ceef182ae.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,这是一个比较复杂的问题,需要一步步来完成。首先,我们需要根据教务系统的需求进行数据库设计。假设教务系统需要存储学生、教师、课程、成绩等信息,我们可以按照如下的设计来进行。 1. 概念结构设计 在概念结构设计阶段,我们需要确定实体、属性、关系等概念,以及它们之间的联系。根据教务系统的需求,我们可以确定以下实体和属性: - 学生(Student):学号、姓名、性别、年级、专业、班级等; - 教师(Teacher):工号、姓名、性别、职称、所属学院等; - 课程(Course):课程编号、课程名称、学分、授课教师等; - 成绩(Grade):学号、课程编号、成绩等。 2. 逻辑结构设计 在逻辑结构设计阶段,我们需要根据概念结构设计的结果,转换为数据库中的表结构。根据上面的实体和属性,我们可以设计出以下表结构: - 学生表(student): | 字段名 | 类型 | 描述 | | -------- | -------- | -------- | | sno | char(10) | 学号 | | sname | char(20) | 姓名 | | ssex | char(2) | 性别 | | sgrade | char(4) | 年级 | | smajor | char(20) | 专业 | | sclass | char(10) | 班级 | | spassword| char(20) | 密码 | - 教师表(teacher): | 字段名 | 类型 | 描述 | | -------- | -------- | -------- | | tno | char(10) | 工号 | | tname | char(20) | 姓名 | | tsex | char(2) | 性别 | | ttitle | char(20) | 职称 | | tcollege | char(20) | 所属学院 | | tpassword| char(20) | 密码 | - 课程表(course): | 字段名 | 类型 | 描述 | | -------- | -------- | -------- | | cno | char(10) | 课程编号 | | cname | char(20) | 课程名称 | | ccredit | char(2) | 学分 | | tno | char(10) | 授课教师 | - 成绩表(grade): | 字段名 | 类型 | 描述 | | -------- | -------- | -------- | | sno | char(10) | 学号 | | cno | char(10) | 课程编号 | | grade | char(3) | 成绩 | 3. 物理结构设计 在物理结构设计阶段,我们需要将逻辑结构设计转换为数据库中实际的存储结构。这里我们选择使用MySQL数据库,可以按照以下步骤进行物理结构设计: - 创建数据库: ``` CREATE DATABASE edu_system; ``` - 创建表: ``` CREATE TABLE student ( sno CHAR(10) PRIMARY KEY, sname CHAR(20) NOT NULL, ssex CHAR(2) NOT NULL, sgrade CHAR(4) NOT NULL, smajor CHAR(20) NOT NULL, sclass CHAR(10) NOT NULL, spassword CHAR(20) NOT NULL ); CREATE TABLE teacher ( tno CHAR(10) PRIMARY KEY, tname CHAR(20) NOT NULL, tsex CHAR(2) NOT NULL, ttitle CHAR(20) NOT NULL, tcollege CHAR(20) NOT NULL, tpassword CHAR(20) NOT NULL ); CREATE TABLE course ( cno CHAR(10) PRIMARY KEY, cname CHAR(20) NOT NULL, ccredit CHAR(2) NOT NULL, tno CHAR(10) NOT NULL, FOREIGN KEY (tno) REFERENCES teacher(tno) ); CREATE TABLE grade ( sno CHAR(10) NOT NULL, cno CHAR(10) NOT NULL, grade CHAR(3) NOT NULL, PRIMARY KEY (sno, cno), FOREIGN KEY (sno) REFERENCES student(sno), FOREIGN KEY (cno) REFERENCES course(cno) ); ``` - 添加数据: ``` INSERT INTO student VALUES ('1001', '张三', '男', '2018', '计算机科学与技术', '1801', '123456'); INSERT INTO student VALUES ('1002', '李四', '女', '2018', '软件工程', '1802', '123456'); INSERT INTO student VALUES ('1003', '王五', '男', '2018', '信息安全', '1803', '123456'); INSERT INTO teacher VALUES ('2001', '张老师', '男', '副教授', '计算机科学与技术', '123456'); INSERT INTO teacher VALUES ('2002', '李老师', '女', '讲师', '软件工程', '123456'); INSERT INTO teacher VALUES ('2003', '王老师', '男', '教授', '信息安全', '123456'); INSERT INTO course VALUES ('C001', '数据库原理', '3', '2001'); INSERT INTO course VALUES ('C002', '操作系统', '4', '2002'); INSERT INTO course VALUES ('C003', '网络安全', '2', '2003'); INSERT INTO grade VALUES ('1001', 'C001', '85'); INSERT INTO grade VALUES ('1001', 'C002', '90'); INSERT INTO grade VALUES ('1002', 'C001', '78'); INSERT INTO grade VALUES ('1002', 'C003', '92'); INSERT INTO grade VALUES ('1003', 'C002', '80'); ``` 4. 视图 视图可以简化复杂的查询操作,我们可以根据需要创建以下视图: - 学生信息视图: ``` CREATE VIEW student_info AS SELECT sno, sname, ssex, sgrade, smajor, sclass FROM student; ``` - 教师信息视图: ``` CREATE VIEW teacher_info AS SELECT tno, tname, tsex, ttitle, tcollege FROM teacher; ``` - 课程信息视图: ``` CREATE VIEW course_info AS SELECT cno, cname, ccredit, tname FROM course, teacher WHERE course.tno = teacher.tno; ``` - 成绩信息视图: ``` CREATE VIEW grade_info AS SELECT sno, sname, cno, cname, grade FROM student, course, grade WHERE student.sno = grade.sno AND course.cno = grade.cno; ``` 5. 索引 索引可以加速数据库的查询操作,我们可以根据需要为表中的字段创建索引。比如,为成绩表中的学号和课程编号字段创建联合索引: ``` CREATE INDEX idx_grade_sno_cno ON grade(sno, cno); ``` 6. 存储过程 存储过程可以简化复杂的数据库操作,我们可以根据需要创建以下存储过程: - 查询学生的成绩: ``` CREATE PROCEDURE show_student_grade( IN stu_no CHAR(10) ) BEGIN SELECT student.sno, student.sname, course.cno, course.cname, grade.grade FROM student, course, grade WHERE student.sno = grade.sno AND course.cno = grade.cno AND student.sno = stu_no; END; ``` 7. 存储函数 存储函数可以简化复杂的数据计算操作,我们可以根据需要创建以下存储函数: - 计算学生的平均成绩: ``` CREATE FUNCTION calc_student_avg_grade( stu_no CHAR(10) ) RETURNS DECIMAL(5,2) BEGIN DECLARE grade_sum DECIMAL(5,2); DECLARE grade_count INT; SELECT SUM(grade) INTO grade_sum, COUNT(*) INTO grade_count FROM grade WHERE sno = stu_no; RETURN grade_sum / grade_count; END; ``` 8. 触发器 触发器可以在数据库发生某些操作时自动触发一些操作,我们可以根据需要创建以下触发器: - 插入成绩时更新学生的平均成绩: ``` CREATE TRIGGER update_student_avg_grade AFTER INSERT ON grade FOR EACH ROW BEGIN UPDATE student SET avg_grade = calc_student_avg_grade(NEW.sno) WHERE sno = NEW.sno; END; ``` 9. 事件 事件可以定期执行一些数据库操作,我们可以根据需要创建以下事件: - 每周定期备份数据库: ``` CREATE EVENT backup_database ON SCHEDULE EVERY 1 WEEK STARTS CURRENT_TIMESTAMP DO BEGIN BACKUP DATABASE edu_system TO '/path/to/backup/file'; END; ``` 10. 事务 事务可以保证数据库操作的一致性和完整性,我们可以在需要进行多个操作的时候使用事务来保证操作的一致性和完整性。 11. 数据库用户及权限分配 在生产环境中,我们需要为不同的用户分配不同的权限,以保证数据安全。我们可以根据需要创建以下用户和权限: - 创建管理员用户: ``` CREATE USER 'admin'@'localhost' IDENTIFIED BY 'password'; GRANT ALL PRIVILEGES ON edu_system.* TO 'admin'@'localhost'; ``` - 创建普通用户: ``` CREATE USER 'user'@'localhost' IDENTIFIED BY 'password'; GRANT SELECT ON edu_system.* TO 'user'@'localhost'; ``` 12. 恢复备份 在生产环境中,我们需要定期备份数据库,并且需要在数据库出现故障时进行恢复。我们可以使用MySQL提供的备份恢复工具来完成这些操作。 - 备份数据库: ``` mysqldump -u username -p edu_system > /path/to/backup/file ``` - 恢复数据库: ``` mysql -u username -p edu_system < /path/to/backup/file ``` 13. 导出导入 如果需要将数据库中的数据导出到其他系统中,或者从其他系统中导入数据到数据库中,我们可以使用MySQL提供的导出导入工具来完成这些操作。 - 导出数据: ``` mysqldump -u username -p edu_system > /path/to/export/file ``` - 导入数据: ``` mysql -u username -p edu_system < /path/to/export/file ``` 以上就是一个简单的教务系统的MySQL数据库设计以及相关操作的详细介绍。当然,根据实际需求,我们可能需要进行更加复杂的设计和操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值