前言
mysql 5.7版本 以下内容为mysql入门基础教程,在这里我总结一下。
1.创建数据库
msyql安装完成之后,将会在其data目录下自动创建几个必需的数据库,可以使用show databases;语句来查看当前所有存在的数据库,输入语句如下;
可以看到,数据库列表中包含6个数据库,msyql是必需的,他描述用户访问权限用户经常用利用test数据库做测试工作。
创建mysql数据库语法如下:
creae database database_name;
创建测试数据库如下
create database test_db;
之后执行 show databases;语句查看
可以看到刚才创建的数据库test_db。
2.删除数据库
删除数据库是将已经存在的数据库从磁盘空间上清除,清除之后,数据库中所有数据也一同被删除。删除数据库语句和创建数据库的命令很相似,MySQL中删除数据库的基本语法格式为;
drop database database_name;
之后执行show create database test_db;会显示找不到,bucunzi。
3.数据库引擎
mysql提供了多个不同的存储引擎,包括处理事务安全表的引擎和处理非事务处理安全表的引擎。在mysql中不需要在整个服务器中使用同一种引擎,针对具体的要求,可以对每个表使用不同的存储引擎。MySQL5.7支持存储引擎有 innodb mylsam memory merge federated csv blackhole
等。可以使用show engines 语句查看。
Support列的值表示某种引擎是否能使用:yes
表示可以使用。no表示不能使用,default表示该引擎为当前默认存储引擎.
innodb存储引擎
innodb是事物数据库的首选引擎,支持事物安全表(acid),支持行锁定和外键。mysql5.5之后,innodb作为默认存储引擎。
innidb引擎特性
1.innodb给mysql提供了具有提交/回滚和崩溃恢复能力的事物安全(acid)
存储引擎。innodb锁定在行级并且也在生气了中查询,可以自由的将innodb类型的表与其他MySQL的表类型混合起来,甚至在同一个查询中也可以混合。
2.innodb是为了处理巨大数据量的最大设计。他的cpu效率是任何基于磁盘的关系数据库所不能匹配的。
3.innodb存储引擎完全与MySQL服务器整合,innodb存储引擎为在主内存中缓存数据和索引而维持它自己的缓冲池。innodb将他的表和索引存在一个逻辑表空间中,表空间可以包含数个文件。这与myslsam表不同,比如在mylsam表中每个表被存在分离文件中。innodb表可以任何尺寸,及时在文件尺寸被限制2gb的操作系统上。
4.innodb支持外键完整性约束。
表存储中的数据时,每张表存储都按主键顺序存放,若果内有显示在表定义时指定主键innodb会为一行生成一个6b的rowid,并以此为主键。
5.innodb被用众多需要高性能的大型数据库站点上。
innodb不是创建目录,使用innodb时,MySQL将在MySQL数据目录下创建一个名为ibdata1的10mb大小的自动扩展数据文件,以及两个名为id——logfile0和idlogfile1的5m大小的日志。