MySQL 数据库使用技巧
1. MySQL使用了ISAM/MyISAM/InnoDB/HEAP/Berkley DB(BDB)等几种引擎(表类型),通常缺省引擎是MyISAM。
ISAM/MyISAM强调快速读取操作,每个表是一个文件,因此表大小受限于操作系统单个文件的最大大小。
InnoDB存储引擎支持事务、行锁、外键,表和索引存放于表空间,表空间是一个或多个文件或裸空间(raw disk)。
BDB 存储引擎支持事务、页锁、外键
HEAP允许只驻留在内存里的临时表格,速度最快但不安全,用完之后必须删除,通常用来做临时表。
目前只有InnoDB和BDB引擎支持事务处理和外键
从版本3.23.43b开始,InnoDB引擎支持外键约束, 从版本4.0.2-alpha开始支持事务, 截止到版本4.1.12a仍然不支持视图。
多种引擎可以协同工作,但事务中的非事务型表(ISAM/MyISAM/HEAP)无法回滚。
2. MySQL导出数据库, 输出重定向
mysqldump -u <user> -p [--opt][-q | --quick] <db_name> [tables] > <file_path>
[-q | --quick] --不缓冲查询,直接导出至stdout
[--opt] --优化导出(同--quick --add-drop-table --add-locks --extended-insert --lock-tables)
[tables] --多个表以空格分隔 <tb1_name> <tb2_name> ...
还可以同时导出多个数据库
mysqldump [OPTIONS] --databases [OPTIONS] DB1 [DB2 DB3...]
mysqldump [OPTIONS] --all-databases [OPTIONS]
3. MySQL导入数据库备份,输入重定向
mysql -u <user> -p <db_name> < <file_path>
4. 登录命令行处理器, -p 参数表示使用密码
mysql [-h <host_name>] -u <user> -p [<db_name>]
5. 查看所有引擎、支持情况及缺省引擎
show engines;
6. 修改缺省引擎
修改MySQL配置文件my.ini(Windows平台)或/etc/my.cnf(Unix平台)相应键值
可能是以下两种格式之一
default-storage-engine=MyISAM
default-table-type=MyISAM
7. 查看所有支持的字符集
show character set;
8. 修改缺省字符集,通常缺省字符集为latin1(ISO-8859-1)
修改MySQL配置文件my.ini(Windows平台)或/etc/my.cnf(Unix平台)相应键值
default-character-set=utf8
还可以在启动服务时指定参数--language
mysqld --language=latin1 ...
9. 查看当前主机所有数据库
show databases;
mysqlshow -u <user> -p --status --OS command window
10. 查看数据库运行状态
show status;
11. 改变当前数据库,MySQL数据库不须disconnect <db_name>
use <db_name>
12. 创建表时指定表类型(数据库引擎)
注意:如果指定了不受支持的表类型,MySQL将自动改用缺省引擎(对此MySQL已经考虑进行修改)。
create table <tb_name> (...) type={BDB | HEAP | ISAM | InnoDB | MERGE | MRG_MYISAM | MYISAM}
13. 修改数据表的表类型
alter table <tb_name> type = {BDB | HEAP | ISAM | InnoDB | MERGE | MRG_MYISAM | MYISAM}
14. 从 MySQL3.23开始,在创建一个表时,可以使用关键词 TEMPORARY。
它的名字被限止在当前连接中,当连接关闭时,临时表会自动地被删除。
这就意味着,两个不同的连接可以使用同一个临时表名而不会与另一个冲突,
也不会与同名现有的表相冲突(现有表将被隐藏,直到临时表被删除)。
从 MySQL 4.0.2 开始,为了能创建临时表,必须有 CREATE TEMPORARY TABLES 权限。
create temporary table (...)
15. 缺省的,MySQL搜索是大小写不敏感的,如果需要一个列总是被当作大小写敏感的方式,必须声明它为BINARY
create table <tb_name> (c varchar(10) [not null default ''] binary, ...)
16. 查看当前数据库所有表
show tables;
17. 查看表的结构
[describe | desc] <tb_name>;
18. 查看索引
show index from <tb_name>;
19. 查看数据表数据引擎、字符集等详细信息
show table status [from <db_name>]; --指定数据库所有表
show table status [from <db_name>] like '<tb_name>' --表名支持通配符,不区分大小写
show create table <tb_name>; --仅显示建表语句、数据库引擎、字符集
20. 显示当前时间
select [now() | curdate() | curtime() | current_time];
21. IF [NOT] EXISTS的使用,仅支持[create | drop] [database | table]
create database [IF NOT EXISTS] <db_name>
drop database [IF EXISTS] <db_name>
create table [IF NOT EXISTS] <tb_name> ...
drop table [IF EXISTS] <tb_name>
22. 分析SQl语句访问过程
explain select ... ;
23. 恢复和整理磁盘空间以及数据碎片
optimize table <tb_name>; --在MySQL Command Line Client执行
myisamchk [-a | --analyze] [- | --...] <tbfile_path> --在OS Command window执行,文件路径及文件名可以使用通配符
[-a] --通过分析键值的分布改进表联结性能
[-s | -ss] --沉默模式。当错误发生时仅写输出,-ss表示非常沉默
[-r] --恢复模式。可修复几乎所有一切,除非唯一的键不是唯一
[-d] --打印出关于表的一些信息
[-w] --如果表被锁定,等待
[-e] --非常彻底地检查表。这仅在极端情况下是必要的
[-v] --冗长模式。打印更多的信息。通常与-d和-e一起使用。为了更冗长,使用-v多次(-vv, -vvv)
... --其他选项略
常用选项示例:
myisamchk *.MYI | myisamchk -a *.MYI | myisamchk -d -v *.MYI | myisamchk -s *.MYI
OPTIMIZE当前只能用于MyISAM和BDB表,MYISAMCHK只能用于MyISAM表, ISAM表使用isamchk
MYISAMCHK比OPTIMIZE速度更快更可靠
对于InnoDB类型的表整理可以通过导出表然后删除原表重新导入的方式,也可以通过将表类型改变为 MyISAM 然后再改为 InnoDB 的方式解决。
分享到:
相关推荐
MySQL数据库是关系型数据库管理系统,广泛应用于数据存储和管理。本文将探讨三个实用的MySQL使用技巧,帮助提升数据库管理和维护的效率。 首先,删除指定日期内的日志文件是数据库维护的重要环节。在处理大量日志...
这份"MySQL数据库使用帮助文档"是开发者在处理与数据库相关的Web应用程序时的重要参考资料。它包含了大量的信息,旨在帮助用户更好地理解和操作MySQL。 文档中可能涵盖以下几个主要知识点: 1. **MySQL安装与配置*...
“浅析数据库之效能——MYSQL数据库作用与技巧” 概述:本文档旨在对MySQL数据库的效能和技巧进行浅析,涵盖了 MySQL 数据库的基本概念、数据类型、数据表、数据操作、系统管理命令等方面的知识点。 一、MySQL...
MySQL数据库是一种广泛应用于Web开发和企业级数据存储的开源关系型数据库管理系统。在这个"MySQL数据库应用形考实验1-4全答案.zip"压缩包中,包含了四个关于MySQL基础操作的实验训练,涵盖了从数据库和表的创建,到...
MySQL数据库技术是目前广泛使用的关系型数据库管理系统之一,它采用标准的SQL语言作为数据操作和查询的手段,能够高效地管理大量数据。在本教案中,将重点介绍MySQL数据库的安装、配置,以及字符集设置等技术点,并...
MySQL数据库设计技巧是数据库管理员和开发人员在构建高效、可靠且可扩展的数据库系统时必须掌握的核心技能。本文将深入探讨几个关键知识点,帮助你优化MySQL数据库的设计。 1. 正确选择数据类型:理解每种数据类型...
在《MySQL数据库原理及应用(第2版)(微课版)》中,我们通常会深入探讨数据库的基本概念、设计原则以及实际操作技巧。这份教学资料包含了一个Mysql数据库的备份文件,为学习者提供了实践平台,便于理解和掌握...
《MySQL数据库基础实例教程(第2版)》课程作为专业必修课,不仅涵盖了数据库的基础理论知识,还注重实践技能的培养,确保学生能够胜任未来职业岗位的需求。 ### 数据库基础知识 课程的第一部分聚焦于数据库的基础...
### Linux应用集成MySQL数据库访问技巧详解 在当前的数字化时代,数据库成为了众多应用程序的核心组成部分,尤其是在Web应用领域,如电子商务平台和其他需要实时处理大量数据的动态网站。在这些场景下,选择合适的...
### MySQL数据库备份与恢复:深度解析与实践指南 在当今数据驱动的世界中,数据库的稳定性和数据的安全性显得尤为重要。MySQL作为全球最流行的开源关系型数据库管理系统之一,其备份和恢复策略是确保数据安全和系统...
MySQL数据库是全球最受欢迎的开源关系型数据库管理系统之一,它以其高效、可靠和易于学习的特点,广泛应用于各种规模的企业和项目中。本课件"mysql数据库基础全部课件"旨在为初学者提供一个全面且实用的学习资源,...
本书《MySQL数据库应用从入门到精通_第2版》旨在帮助读者从零基础开始,逐步掌握MySQL的使用技巧和高级功能,从而实现数据库管理与开发的精通。 一、MySQL基础知识 在入门阶段,首先会介绍MySQL的安装与配置,包括...
本文档旨在深入浅出 MySQL 数据库开发、优化与管理维护的知识点,涵盖了 MySQL 数据库开发的基本概念、优化技巧和管理维护方法。 数据库开发篇 在本篇中,我们将学习 MySQL 数据库开发的基础知识,包括数据类型、...
总之,《MySQL数据库入门》的配套资源为学习者提供了丰富的学习素材,结合教材使用,可以确保全面、系统地掌握MySQL的基础知识和实际操作技巧。无论是初学者还是有一定基础的开发者,都能从中受益。通过这些资源,...
根据提供的文件信息,我们可以推断出这份文档主要包含MySQL数据库相关的考试练习题目。MySQL是一种广泛使用的开源关系型数据库管理系统(RDBMS),因其性能稳定、易于使用和成本低廉等特点,在互联网应用开发中非常...
以及SQL语法、工具、选项、API应用指南,最大限度地帮助读者更快地学习和掌握MySQL数据库系统的设计和使用。本书覆盖了MySQL 5.0,讨论了新的程序设计接口(如PHP 5里的mysqli)和新的系统管理工具。
SQL 查询优化(提高 MySQL 数据库查询效率的几个技巧) 在 MySQL 数据库中,查询优化是一个非常重要的方面。在实际应用中,高效的查询可以提高整个系统的性能和响应速度。下面我们将介绍几个提高 MySQL 数据库查询...
本文总结了一些 MySQL 数据库优化技巧,包括选择合适的字段属性、使用连接(JOIN)代替子查询、使用联合(UNION)代替手动创建的临时表、事务、锁定表、外键等。 一、选择合适的字段属性 在创建 MySQL 数据库时,...
### MySQL数据库安装图解知识点详解 #### 一、MySQL数据库简介 MySQL是一种广泛使用的开源关系型数据库管理系统(RDBMS),因其性能卓越、稳定性强、易于使用等特点而受到广大开发者的青睐。它支持多种操作系统,如...