MySQL的存储引擎整理,windows下远程连接Mysql

01.MyISAM

CentOS7默认数据库是mariadb,配置等用着不习惯,因此决定改成mysql,但是CentOS7的yum源中默认好像是没有mysql的。为了解决这个问题,我们要先下载mysql的repo源。

  1. 使用“Ctrl + R”组合键快速打开cmd窗口,并输入“cmd”命令,打开cmd窗口。

    图片 1

  2. 使用“mysql -uroot -proot”命令可以连接到本地的mysql服务。

    图片 2

  3. 使用“use mysql”命令,选择要使用的数据库,修改远程连接的基本信息,保存在mysql数据库中,因此使用mysql数据库。

    图片 3

  4. 使用“GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'root' WITH GRANT OPTION;”命令可以更改远程连接的设置。

    图片 4

  5. 使用“flush privileges;”命令刷新刚才修改的权限,使其生效。

    图片 5

  6. 使用“select host,user from user;”查看修改是否成功。

    图片 6

     

     

    解决远程连接时防火墙阻止访问:

    xp/2003添加防火墙例外端口
    打开防火墙,选择例外选项卡,添加端口
    名称:mysqlport
    端口号:3306
    选中TCP

MySQL 5.0 以前的默认存储引擎。MyISAM 不支持事务、也不支持外键,其优势是访问的速度快,对事务完整性没有要求或者以SELECT、INSERT 为主的应用基本上都可以使用这个引擎来创建表。

1.下载mysql的repo源

win7及以上添加防火墙例外端口:控制面板-防火墙设置-高级设置  
入站规则设置  
第一步 选择 入站规则 然后 新建规则,选择 端口,然后下一步   
第二步 选择TCP 选择特定端口
然后输入端口,如有多个端口需要用逗号隔开了 例如: 3306  
第三步 选择允许连接  
第四步 选择配置文件   
第五步 输入规则名称 mysqlport  


出站规则设置  
第一步 选择出站规则 然后 新建规则,选择 端口,然后下一步   
第二步 选择TCP 选择特定端口
然后输入端口,如有多个端口需要用逗号隔开了 例如: 3306  
第三步 选择允许连接  
第四步 选择配置文件   
第五步 输入规则名称
mysqlport(或者无特殊要求下直接关闭防火墙)

 

转载请注明出处:<http://www.cnblogs.com/fnlingnzb-learner/p/5848405.html>

每个MyISAM 在磁盘上存储成3 个文件,其文件名都和表名相同,但扩展名分别是:

$ wget http://repo.mysql.com/mysql-community-release-el7-5.noarch.rpm

 .frm(存储表定义);

2.安装mysql-community-release-el7-5.noarch.rpm包

 .MYD(MYData,存储数据);

$ sudo rpm -ivh mysql-community-release-el7-5.noarch.rpm

 .MYI (MYIndex,存储索引)。

安装这个包后,会获得两个mysql的yum repo源:/etc/yum.repos.d/mysql-community.repo,/etc/yum.repos.d/mysql-community-source.repo。

数据文件和索引文件可以放置在不同的目录,平均分布IO,获得更快的速度。  要指定索引文件和数据文件的路径,需要在创建表的时候通过DATA DIRECTORY 和INDEX DIRECTORY 语句指定,也就是说不同MyISAM 表的索引文件和数据文件可以放置到不同的路径下。文件路径需要是绝对路径,并且具有访问权限。

3.安装mysql

MyISAM 类型的表可能会损坏,原因可能是多种多样的,损坏后的表可能不能访问,会提示需要修复或者访问后返回错误的结果。MyISAM 类型的表提供修复的工具,可以用CHECKTABLE 语句来检查MyISAM 表的健康,并用REPAIR TABLE 语句修复一个损坏的MyISAM 表。表损坏可能导致数据库异常重新启动,需要尽快修复并尽可能地确认损坏的原因。

$ sudo yum install mysql-server

MyISAM 的表又支持3 种不同的存储格式,分别是:

根据提示安装就可以了,不过安装完成后没有密码,需要重置密码

 静态(固定长度)表;

4.重置mysql密码

 动态表;

$ mysql -u root

 压缩表。

登录时有可能报这样的错:ERROR 2002 (HY000): Can‘t connect to local MySQL server through socket ‘/var/lib/mysql/mysql.sock‘ (2),原因是/var/lib/mysql的访问权限问题。下面的命令把/var/lib/mysql的拥有者改为当前用户:

其中,静态表是默认的存储格式。静态表中的字段都是非变长字段,这样每个记录都是固定长度的,这种存储方式的优点是存储非常迅速,容易缓存,出现故障容易恢复;缺点是占用的空间通常比动态表多。静态表的数据在存储的时候会按照列的宽度定义补足空格,但是在应用访问的时候并不会得到这些空格,这些空格在返回给应用之前已经去掉。

$ sudo chown -R root:root /var/lib/mysql

动态表中包含变长字段,记录不是固定长度的,这样存储的优点是占用的空间相对较少,但是频繁地更新删除记录会产生碎片,需要定期执行OPTIMIZE TABLE 语句或myisamchk -r 命令来改善性能,并且出现故障的时候恢复相对比较困难。

重启mysql服务

压缩表由myisampack 工具创建,占据非常小的磁盘空间。因为每个记录是被单独压缩的,所以只有非常小的访问开支。

$ service mysqld restart

 

接下来登录重置密码:

 

$ mysql -u root  //直接回车进入mysql控制台
mysql > use mysql;
mysql > update user set password=password('123456') where user='root';
mysql > exit;

02.**InnoDB**

 

MySQL 5.0开始的默认引擎,InnoDB 存储引擎提供了具有提交、回滚和崩溃恢复能力的事务安全。但是对比MyISAM的存储引擎,InnoDB 写的处理效率差一些并且会占用更多的磁盘空间以保留数据和索引。

AUTO_INCREMENT

InnoDB 表的自动增长列可以手工插入,但是插入的值如果是空或者0,则实际插入的将是自动增长后的值。

可以通过“ALTER TABLE *** AUTO_INCREMENT = n;”语句强制设置自动增长列的初识值,默认从1 开始,但是该强制的默认值是保留在内存中的,如果该值在使用之前数据库重新启动,那么这个强制的默认值就会丢失,就需要在数据库启动以后重新设置。

可以使用LAST_INSERT_ID()查询当前线程最后插入记录使用的值。如果一次插入了多条记录,那么返回的是第一条记录使用的自动增长值。

对于InnoDB 表,自动增长列必须是索引。如果是组合索引,也必须是组合索引的第一列,但是对于MyISAM 表,自动增长列可以是组合索引的其他列,这样插入记录后,自动增长列是按照组合索引的前面几列进行排序后递增的。

例如,创建一个新的MyISAM 类型的表autoincre_demo,自动增长列d1 作为组合索引的第二列,对该表插入一些记录后,可以发现自动增长列是按照组合索引的第一列d2 进行排序后递增的:

图片 7

本文由澳门新葡亰平台官网发布于数据库,转载请注明出处:MySQL的存储引擎整理,windows下远程连接Mysql

TAG标签:
Ctrl+D 将本页面保存为书签,全面了解最新资讯,方便快捷。