当前位置: 首页 > news >正文

MySQL事务、索引、数据恢复和备份

MySQL事务、索引、数据恢复和备份

1.MySQL的事务处理

事务就是将一组SQL语句放在同一批次内去执行

如果一个SQL语句出错,则该批次内的所有SQL都将被取消执行

MySQL的事务实现方法 :

SET AUTOCOMMIT

使用SET语句来改变自动提交模式

SET AUTOCOMMIT  = 0;    # 关闭自动提交模式
SET AUTOCOMMIT  = 1;    # 开启自动提交模式

MySQL中默认是自动提交

使用事务时应先关闭自动提交

MySQL事务处理步骤:

在这里插入图片描述

2.数据库索引

作用:

提高查询速度

确保数据的唯一性

可以加速表和表之间的连接,实现表与表之间的参照完整性

使用分组和排序子句进行数据检索时,可以显著减少分组和排序的时间

全文检索字段进行搜索优化

分类

主键索引(PRIMARY KEY)

唯一索引(UNIQUE)

常规索引(INDEX)

全文索引(FULLTEXT)

主键索引

某一个属性或属性的组合能唯一标识一条记录

如:学生表(学号,姓名,班级,性别等) ,学号就是唯一标识的,可作为主键

特点

最常见的索引类型

确保数据记录的唯一性

确定特定数据记录在数据库中的位置

 CREATE TABLE  `Grade` (`GradeID`  INT(11)   AUTO_INCREMENT    PRIMARY KEY,#省略代码……#主键索引也可在字段字义之后,如#  PRIMARY KEY(`GradeID`)    
)
常规索引

作用:快速定位特定数据

注意

index和key关键字都可设置常规索引

应加在查找条件的字段

不宜添加太多常规索引,影响数据的插入、删除和修改操作

CREATE TABLE  `result` (//省略一些代码INDEX/KEY   `ind`  (`studentNo`, `subjectNo`)
)
ALTER TABLE  `result`  ADD  INDEX  `ind` (`studentNo`, `subjectNo`);
全文索引

作用:快速定位特定数据

注意

只能用于MyISAM类型的数据表

只能用于 CHAR 、 VARCHAR、TEXT数据列类型

适合大型数据集

 CREATE TABLE  `student` (#省略一些SQL语句FULLTEXT (`StudentName`) 
)ENGINE=MYISAM;
ALTER TABLE employee ADD FULLTEXT (`first_name`);
管理索引

创建索引

创建表时添加

建表后追加

ALERT TABLE 表名 ADD  索引类型(数据列名)

删除索引

DROP  INDEX 索引名 ON    表名
ALTER TABLE 表名   DROP  INDEX  索引名
ALTER TABLE 表名   DROP  PRIMARY KEY

查看索引

SHOW  INDEX(或KEYS) FROM 表名

索引准则

索引不是越多越好

不要对经常变动的数据加索引

小数据量的表建议不要加索引

索引一般应加在查找条件的字段

3.MySQL的备份

数据库备份必要性

保证重要数据不丢失

数据转移

MySQL数据库备份方法

mysqldump备份工具

数据库管理工具,如SQLyog

直接拷贝数据库文件和相关配置文件

mysqldump数据库备份

作用;

转储数据库

搜集数据库进行备份

将数据转移到另一个SQL服务器(不一定是MySQL服务器)

mysqldump  -h 主机名 –u 用户名 –p   [options]   数据库名  
[ table1 table2 table3 ]   > path/filename.sql
 # 备份myschool数据库如: > mysqldump -u root -p  myschool > d:/myschool.sqlEnterPassword: *****

mysqldump常用选项

符号名称描述
–add-drop-table导出sql脚本会加上 DROP TABLE IF EXISTS 语句默认是打开的,可以用 --skip-add-drop-table 来取消
–add-locks该选项会在INSERT 语句中捆绑一个LOCK TABLE 和UNLOCK TABLE 语句好处:防止记录被再次导入时,其他用户对表进行的操作,默认是打开的
-t 或–no-create-info忽略不写重新创建每个转储表的CREATE TABLE语句
-c或 --complete-insert在每个INERT语句的列上加上字段名在数据库导入另一个数据库时非常有用
-d 或 --no-data不写表的任何行信息。对于只想转储表的结构很有用
–where “where-condition”, -w “where-condition”只转储给定的WHERE条件选择的记录
–opt该选项是速记;等同于指定 --add-drop-tables --add-locking --create-option --disable-keys–extended-insert --lock-tables --quick --set-charset

4.MySQL数据库的恢复

方法一

用 SOURCE 语法

/path/是一个绝对路径,并且必须是mysql 运行用户有权限读取的文件

SOURCE 在MySQL命令行里执行

SOURCE     /path/db_name.sql;

方法二

用 mysql 客户端

mysql –u root –p  dbname  <  /path/db_name.sql;

利用SQL语句导出、导入数据

SELECT   *   INTO   OUTFILE   'file_name'  FROM   tbl_name

输出的文件不能先存在,否则报错

LOAD   DATA   INFILE   'file_name '   INTO   TABLE   tbl_name[FIELDS]
http://www.lryc.cn/news/446644.html

相关文章:

  • 什么是chatgpt?国内有哪些类gpt模型?
  • ISP基本框架及算法介绍 ISP(Image Signal Processor)
  • Stable Diffusion 的 ControlNet 主要用途
  • 矩阵分析 学习笔记4 内积与Gram矩阵
  • iOS 消息机制详解
  • 深入理解Spring Data JPA与接口编程
  • Wireshark学习使用记录
  • OpenCV特征检测(9)检测图像中直线的函数HoughLines()的使用
  • 力扣 中等 445.两数相加 II
  • 华为云徐峰:AI赋能应用现代化,加速软件生产力跃升
  • C发送邮件技巧:如何批量发送个性化邮件?
  • 基于python+spark的外卖餐饮数据分析系统设计与实现(含论文)-Spark毕业设计选题推荐
  • 权限维持——Linux
  • 申请SSL证书闭坑方法
  • linux 下域名解析错误
  • 基于单片机的角度、水位、温度、辅助热源、电机仿真
  • 泛函分析精解【1】
  • 大数据毕业设计选题推荐-租房数据分析系统-Hive-Hadoop-Spark
  • 有关shell指令练习2
  • Exception与Error:Java中的异常处理
  • HashMap哈希表练习
  • 字节豆包C++一面-面经总结
  • 极狐GitLab 17.4 重点功能解读【三】
  • 【unity进阶知识4】封装unity协程工具,避免 GC(垃圾回收)
  • Source insight安装使用笔记
  • golang学习笔记29——golang 中如何将 GitHub 最新提交的版本设置为 v1.0.0
  • Netty源码解析-锁机制
  • 【C/C++】initializer_list
  • 不要再混淆啦!一文带你学会原型链继承、构造函数继承、寄生组合继承、ES6继承
  • 828华为云征文|华为云Flexus X实例Windows Server 2019安装护卫神防火墙——为企业运维安全发挥重要作用!!!