MySQL是一个关係型资料库管理系统,由瑞典MySQL AB 公司开发,目前属于 Oracle 旗下产品。MySQL 是最流行的关係型资料库管理系统之一,在 WEB 套用方面,MySQL是最好的 RDBMS (Relational Database Management System,关係资料库管理系统) 套用软体。
MySQL是一种关係资料库管理系统,关係资料库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。
MySQL所使用的 SQL 语言是用于访问资料库的最常用标準化语言。MySQL 软体採用了双授权政策,分为社区版和商业版,由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,一般中小型网站的开发都选择 MySQL 作为网站资料库。
由于其社区版的性能卓越,搭配 PHP 和 Apache 可组成良好的开发环境。
基本介绍
- 外文名MySQL
- 类型关係型资料库管理系统
- 所属Oracle
- 开发公司瑞典MySQL AB 公司
套用环境
与其他的大型资料库例如 Oracle、DB2、SQL Server等相比,MySQL 自有它的不足之处,这丝毫也没有减少它受欢迎的程度。对于一般的个人使用者和中小型企业来说,MySQL提供的功能已经绰绰有余,而且由于 MySQL是开放源码软体,可以大大降低总体拥有成本。
Linux作为作业系统,Apache 或Nginx作为 Web 伺服器,MySQL 作为资料库,PHP/Perl/Python作为伺服器端脚本解释器。由于这四个软体都是免费或开放源码软体(FLOSS),使用这种方式不用花一分钱(除开人工成本)就可以建立起一个稳定、免费的网站系统,被业界称为“LAMP“或“LNMP”组合。
系统特性
1.使用 C和 C++编写,并使用了多种编译器进行测试,保证了原始码的可移植性。
2.支持 AIX、FreeBSD、HP-UX、Linux、Mac OS、NovellNetware、OpenBSD、OS/2 Wrap、Solaris、Windows等多种作业系统。
3.为多种程式语言提供了 API。这些程式语言包括 C、C++、Python、Java、Perl、PHP、Eiffel、Ruby,.NET和 Tcl 等。
4.支持多执行绪,充分利用 CPU 资源。
5.最佳化的 SQL查询算法,有效地提高查询速度。
6.既能够作为一个单独的应用程式套用在客户端伺服器网路环境中,也能够作为一个库而嵌入到其他的软体中。
7.提供多语言支持,常见的编码如中文的 GB 2312、BIG5,日文的 Shift_JIS等都可以用作数据表名和数据列名。
8.提供 TCP/IP、ODBC 和 JDBC等多种资料库连线途径。
9.提供用于管理、检查、最佳化资料库操作的管理工具。
10.支持大型的资料库。可以处理拥有上千万条记录的大型资料库。
11.支持多种存储引擎。
12.MySQL 是开源的,所以你不需要支付额外的费用。
13.MySQL 使用标準的 SQL数据语言形式。
14.MySQL 对 PHP 有很好的支持,PHP是比较流行的 Web 开发语言。
15.MySQL是可以定製的,採用了 GPL协定,你可以修改源码来开发自己的 MySQL 系统。
16.线上 DDL/更改功能,数据架构支持动态应用程式和开发人员灵活性(5.6新增)
17.複製全局事务标识,可支持自我修複式集群(5.6新增)
18.複製无崩溃从机,可提高可用性(5.6新增)
19.複製多执行绪从机,可提高性能(5.6新增)
20.3倍更快的性能(5.7新增)
21.新的最佳化器(5.7新增)
22.原生JSON支持(5.7新增)
23.多源複製(5.7新增)
24.GIS的空间扩展(5.7新增)
存储引擎
MyISAMMySQL 5.0 之前的默认资料库引擎,最为常用。拥有较高的插入,查询速度,但不支持事务
InnoDB事务型资料库的首选引擎,支持ACID事务,支持行级锁定, MySQL 5.5 起成为默认资料库引擎
BDB源 自 Berkeley DB,事务型资料库的另一种选择,支持Commit 和Rollback 等其他事务特性
Memory所有数据置于记忆体的存储引擎,拥有极高的插入,更新和查询效率。会占用和数据量成正比的记忆体空间。并且其内容会在 MySQL 重新启动时丢失
Merge将一定数量的 MyISAM 表联合而成一个整体,在超大规模数据存储时很有用
Archive非常适合存储大量的独立的,作为历史记录的数据。因为它们不经常被读取。Archive 拥有高效的插入速度,但其对查询的支持相对较差
Federated将不同的 MySQL 伺服器联合起来,逻辑上组成一个完整的资料库。非常适合分散式套用
Cluster/NDB高冗余的存储引擎,用多台数据机器联合提供服务以提高整体性能和安全性。适合数据量大,安全和性能要求高的套用
CSV 逻辑上由逗号分割数据的存储引擎。它会在资料库子目录里为每个数据表创建一个 .csv 档案。这是一种普通文本档案,每个数据行占用一个文本行。CSV 存储引擎不支持索引。
BlackHole黑洞引擎,写入的任何数据都会消失,一般用于记录 binlog 做複製的中继
EXAMPLE 存储引擎是一个不做任何事情的存根引擎。它的目的是作为 MySQL 原始码中的一个例子,用来演示如何开始编写一个新存储引擎。同样,它的主要兴趣是对开发者。EXAMPLE 存储引擎不支持编索引。
,MySQL 的存储引擎接口定义良好。有兴趣的开发者可以通过阅读文档编写自己的存储引擎。
套用架构
单点(Single),适合小规模套用
複製(Replication),适合中小规模套用
集群(Cluster),适合大规模套用
索引功能
索引是一种特殊的档案(InnoDB 数据表上的索引是表空间的一个组成部分),它们包含着对数据表里所有记录的引用指针。索引不是万能的,索引可以加快数据检索操作,但会使数据修改操作变慢。每修改数据记录,索引就必须刷新一次。为了在某种程度上弥补这一缺陷,许多 SQL 命令都有一个 DELAY_KEY_WRITE 项。这个选项的作用是暂时制止 MySQL 在该命令每插入一条新记录和每修改一条现有之后立刻对索引进行刷新,对索引的刷新将等到全部记录插入/修改完毕之后再进行。在需要把许多新记录插入某个数据表的场合,DELAY_KEY_WRITE 选项的作用将非常明显。,索引还会在硬碟上占用相当大的空间。应该只为最经常查询和最经常排序的数据列建立索引。注意,如果某个数据列包含许多重複的内容,为它建立索引就没有太大的实际效果。
从理论上讲,完全可以为数据表里的每个栏位分别建一个索引,但 MySQL 把同一个数据表里的索引总数限制为16个。
1.InnoDB 数据表的索引
与 InnoDB数据表相比,在 InnoDB 数据表上,索引对 InnoDB 数据表的重要性要大得多。在 InnoDB 数据表上,索引不仅会在搜寻数据记录时发挥作用,还是数据行级锁定机制的基础。“数据行级锁定”的意思是指在事务操作的执行过程中锁定正在被处理的个别记录,不让其他用户进行访问。这种锁定将影响到(但不限于)SELECT、LOCKINSHAREMODE、SELECT、FORUPDATE 命令以及 INSERT、UPDATE 和 DELETE 命令。出于效率方面的考虑,InnoDB 数据表的数据行级锁定实际发生在它们的索引上,而不是数据表自身上。显然,数据行级锁定机制只有在有关的数据表有一个合适的索引可供锁定的时候才能发挥效力。
2.限制
如果 WHERE 子句的查询条件里有不等号(WHERE coloum !=),MySQL 将无法使用索引。类似地,如果 WHERE 子句的查询条件里使用了函式(WHERE DAY(column)=),MySQL 也将无法使用索引。在 JOIN 操作中(需要从多个数据表提取数据时),MySQL 只有在主键和外键的数据类型相才能使用索引。
如果 WHERE 子句的查询条件里使用比较操作符 LIKE 和 REGEXP,MySQL 只有在搜寻模板的第一个字元不是通配符的情况下才能使用索引。比如说,如果查询条件是 LIKE 'abc%‘,MySQL 将使用索引;如果查询条件是 LIKE '%abc’,MySQL 将不使用索引。
在 ORDER BY 操作中,MySQL 只有在排序条件不是一个查询条件表达式的情况下才使用索引。(虽然如此,在涉及多个数据表查询里,即使有索引可用,那些索引在加快 ORDER BY 方面也没什幺作用)。如果某个数据列里包含许多重複的值,就算为它建立了索引也不会有很好的效果。比如说,如果某个数据列里包含的净是些诸如 “0/1” 或 “Y/N” 等值,就没有必要为它创建一个索引。
索引类别
1.普通索引
普通索引(由关键字 KEY 或 INDEX 定义的索引)的任务是加快对数据的访问速度。,应该只为那些最经常出现查询条件(WHERE column =)或排序条件(ORDER BY column)中的数据列创建索引。只要有可能,就应该选择一个数据最整齐、最紧凑的数据列(如一个整数类型的数据列)来创建索引。
2.索引
普通索引允许被索引的数据列包含重複的值。比如说,因为人有可能同名,所以同一个姓名在同一个“员工个人资料”数据表里可能出现两次或更多次。
如果能确定某个数据列将只包含彼此各不相同的值,在为这个数据列创建索引的时候就应该用关键字UNIQUE 把它定义为一个索引。这幺做的好处一是简化了 MySQL 对这个索引的管理工作,这个索引也而变得更有效率;二是 MySQL 会在有新记录插入数据表时,自动检查新记录的这个栏位的值是否已经在某个记录的这个栏位里出现过了;如果是,MySQL 将拒绝插入那条新记录。也就是说,索引可以保证数据记录的独特性。事实上,在许多场合,人们创建索引的目的往往不是为了提高访问速度,而只是为了避免数据出现重複。
3.主索引
在前面已经反覆多次强调过必须为主键栏位创建一个索引,这个索引就是所谓的“主索引”。主索引区别是前者在定义时使用的关键字是 PRIMARY 而不是 UNIQUE。
4.外键索引
如果为某个外键栏位定义了一个外键约束条件,MySQL 就会定义一个内部索引来帮助自己以最有效率的方式去管理和使用外键约束条件。
5.複合索引
索引可以覆盖多个数据列,如像 INDEX (columnA, columnB) 索引。这种索引的特点是 MySQL 可以有选择地使用一个这样的索引。如果查询操作只需要用到 columnA 数据列上的一个索引,就可以使用複合索引 INDEX(columnA, columnB)。不过,这种用法仅适用于在複合索引中排列在前的数据列组合。比如说,INDEX (A,B,C) 可以当做 A 或 (A,B) 的索引来使用,但不能当做 B、C 或 (B,C) 的索引来使用。
索引长度
在为 CHAR 和 VARCHAR 类型的数据列定义索引时,可以把索引的长度限制为一个给定的字元个数(这个数字必须小于这个栏位所允许的最大字元个数)。这幺做的好处是可以生成一个尺寸比较小、检索速度却比较快的索引档案。在绝大多数套用里,资料库中的字元串数据大都以各种各样的名字为主,把索引的长度设定为10~15 个字元已经足以把搜寻範围缩小到很少的几条数据记录了。在为 BLOB 和 TEXT 类型的数据列创建索引时,必须对索引的长度做出限制;MySQL 所允许的最大索引全文索引文本栏位上的普通索引只能加快对出现栏位内容最前面的字元串(也就是栏位内容开头的字元)进行检索操作。如果栏位里存放的是由几个、甚至是多个单词构成的较大段文字,普通索引就没什幺作用了。这种检索往往以的形式出现,这对 MySQL 来说很複杂,如果需要处理的数据量很大,回响时间就会很长。
这类场合正是全文索引(full-textindex)可以大显身手的地方。在生成这种类型的索引时,MySQL 将把在文本中出现的所有单词创建为一份清单,查询操作将根据这份清单去检索有关的数据记录。全文索引即可以随数据表一同创建,也可以等日后有必要时再使用下面这条命令添加
ALTER TABLE tablename ADD FULLTEXT(column1,column2)有了全文索引,就可以用 SELECT 查询命令去检索那些包含着一个或多个给定单词的数据记录了。下面是这类查询命令的基本语法
SELECT FROM tablename
WHERE MATCH (column1,column2) AGAINST('word1','word2','word3')
上面这条命令将把 column1 和 column2 栏位里有 word1、word2 和 word3 的数据记录全部查询出来。
注解InnoDB 数据表不支持全文索引。
查询和索引
只有当资料库里已经有了足够多的测试数据时,它的性能测试结果才有实际参考价值。如果在测试资料库里只有几百条数据记录,它们往往在执行完第一条查询命令之后就被全部载入到记忆体里,这将使后续的查询命令都执行得非常快--不管有没有使用索引。只有当资料库里的记录超过了 1000 条、数据总量也超过了 MySQL 伺服器上的记忆体总量时,资料库的性能测试结果才有意义。
在不确定应该在哪些数据列上创建索引的时候,人们从 EXPLAIN SELECT 命令那里往往可以获得一些帮助。这其实只是简单地给一条普通的 SELECT 命令加一个 EXPLAIN 关键字作为前缀而已。有了这个关键字,MySQL 将不是去执行那条 SELECT 命令,而是去对它进行分析。MySQL 将以表格的形式把查询的执行过程和用到的索引等信息列出来。
在 EXPLAIN 命令的输出结果里,第1列是从资料库读取的数据表的名字,它们按被读取的先后顺序排列。type列指定了本数据表与其它数据表之间的关联关係(JOIN)。在各种类型的关联关係当中,效率最高的是 system,然后依次是 const、eq_ref、ref、range、index 和 All(All 的意思是对应于上一级数据表里的每一条记录,这个数据表里的所有记录都必须被读取一遍——这种情况往往可以用一索引来避免)。
possible_keys 数据列给出了 MySQL 在搜寻数据记录时可选用的各个索引。key 数据列是 MySQL 实际选用的索引,这个索引按位元组计算的长度在 key_len 数据列里给出。比如说,对于一个 INTEGER 数据列的索引,这个位元组长度将是4。如果用到了複合索引,在 key_len 数据列里还可以看到 MySQL 具体使用了它的哪些部分。作为一般规律,key_len 数据列里的值越小越好。
ref 数据列给出了关联关係中另一个数据表里的数据列的名字。row 数据列是 MySQL 在执行这个查询时预计会从这个数据表里读出的数据行的个数。row 数据列里的所有数字的乘积可以大致了解这个查询需要处理多少组合。
,extra 数据列提供了与 JOIN 操作有关的更多信息,比如说,如果 MySQL 在执行这个查询时必须创建一个临时数据表,就会在 extra 列看到 usingtemporary 字样。
安装教程
打开下载的mysql安装档案mysql-5.0.27-win32.zip,双击解压缩,运行“setup.exe”
mysql安装精灵启动,按“Next”继续,
选择安装类型,有“Typical(默认)”、“Complete(完全)”、“Custom(用户自定义)”三个选项,我们选择“Custom”,有更多的选项,也方便熟悉安装过程:
在“Developer Components(开发者部分)”上左键单击,选择“This feature, and all subfeatures, will be installed on local hard drive.”,即“此部分,及下属子部分内容,全部安装在本地硬碟上”。在上面的“MySQL Server(mysql伺服器)”、“Client Programs(mysql客户端程式)”、“Documentation(文档)”也如此操作,以保证安装所有档案。点选“Change...”,手 动指定安装目录。
填上安装目录,我的是“F:\Server\MySQL\MySQL Server 5.0”,也建议不要放在与作业系统同一分区,这样可以防止系统备份还原的时候,数据被清空。按“OK”继续。
返回刚才的界面,按“Next”继续
确认一下先前的设定,如果有误,按“Back”返回重做。按“Install”开始安装。
正在安装中,请稍候,直到出现下面的界面
这里是询问你是否要注册一个账号,或是使用已有的账号直接登入,一般不需要了,点选“Skip Sign-Up”,按“Next”略过此步骤。
软体安装完成后,出现上面的界面,这里有一个很好的功能,mysql配置嚮导,不用像以前一样,自己手动乱七八糟的配置my.ini了,将 “Configure the Mysql Server now”前面的勾打上,点“Finish”结束软体的安装并启动mysql配置嚮导。
mysql配置嚮导启动界面,按“Next”继续
选择配置方式,“Detailed Configuration(手动精确配置)”、“Standard Configuration(标準配置)”,我们选择“Detailed Configuration”,方便熟悉配置过程。
选择伺服器类型,“Developer Machine(开发测试类,mysql占用很少资源)”、“Server Machine(伺服器类型,mysql占用较多资源)”、“DedicatedMySQL Server Machine(专门的资料库伺服器,mysql占用所有可用资源)”,大家根据自己的类型选择了,一般选“Server Machine”,不会太少,也不会占满。
选择mysql资料库的大致用途,“Multifunctional Database(通用多功能型,好)”、“Transactional Database Only(伺服器类型,专注于事务处理,一般)”、“Non-Transactional Database Only(非事务处理型,较简单,主要做一些监控、记数用,对MyISAM数据类型的支持仅限于non-transactional),随自己的用途而选 择了,我这里选择“Transactional Database Only”,按“Next”继续。
对InnoDB Tablespace进行配置,就是为InnoDB 资料库档案选择一个存储空间,如果修改了,要记住位置,重装的时候要选择一样的地方,否则可能会造成资料库损坏,,对资料库做个备份就没问题了,这里 不详述。我这里没有修改,使用用默认位置,直接按“Next”继续
选择您的网站的一般mysql访问量,连线的数目,“Decision Support(DSS)/OLAP(20个左右)”、“Online Transaction Processing(OLTP)(500个左右)”、“Manual Setting(手动设定,自己输一个数)”,我这里选“Online Transaction Processing(OLTP)”,自己的伺服器,应该够用了,按“Next”继续
是否启用TCP/IP连线,设定连线埠,如果不启用,就只能在自己的机器上访问mysql数 据库了,我这里启用,把前面的勾打上,Port Number3306,在这个页面上,您还可以选择“启用标準模式”(Enable Strict Mode),这样MySQL就不会允许细小的语法错误。如果您还是个新手,我建议您取消标準模式以减少麻烦。但熟悉MySQL以后,儘量使用标準模式,因 为它可以降低有害数据进入资料库的可能性。按“Next”继续
西文编码,第二个是多位元组的通用utf8编码,都不是我们通用的编码,这里选择第三个,然 后在Character Set那里选择或填入“gbk”,也可以用“gb2312”,区别就是gbk的字型档容量大,包括了gb2312的所有汉字,并且加上了繁体字、和其它 乱七八糟的字——使用mysql的时候,在执行数据操作命令之前运行一次“SET NAMES GBK;”(运行一次就行了,GBK可以替换为其它值,视这里的设定而定),就可以正常的使用汉字(或其它文字)了,否则不能正常显示汉字。按 “Next”继续。
选择是否将mysql安装为windows服务,还可以指定Service Name(服务标识名称),是否将mysql的bin目录加入到Windows PATH(加入后,就可以直接使用bin下的档案,而不用指出目录名,比如连线,“mysql.exe -uusername -ppassword;”就可以了,不用指出mysql.exe的完整地址,很方便),我这里全部打上了勾,Service Name不变。按“Next”继续。
这一步询问是否要修改默认root用户(超级管理)的密码(默认为空),“New root password”如果要修改,就在此填入新密码(如果是重装,并且之前已经设定了密码,在这里更改密码可能会出错,请留空,并将“Modify Security Settings”前面的勾去掉,安装配置完成后另行修改密码),“Confirm(再输一遍)”内再填一次,防止输错。 “Enable root access from remote machines(是否允许root用户在其它的机器上登入,如果要安全,就不要勾上,如果要方便,就勾上它)”。“Create An Anonymous Account(新建一个匿名用户,匿名用户可以连线资料库,不能运算元据,包括查询)”,一般就不用勾了,设定完毕,按“Next”继续。
确认设定无误,如果有误,按“Back”返回检查。按“Execute”使设定生效。
设定完毕,按“Finish”结束mysql的安装与配置——这里有一个比较常见的错误, 就是不能“Start service”,一般出现以前有安装mysql的伺服器上,解决的办法,先保证以前安装的mysql伺服器彻底卸载掉了;不行的话,检查是否按上面一 步所说,之前的密码是否有修改,照上面的操作;如果依然不行,将mysql安装目录下的data资料夹备份,然后删除,在安装完成后,将安装生成的 data资料夹删除,备份的data资料夹移回来,再重启mysql服务就可以了,这种情况下,可能需要将资料库检查一下,然后修复一次,防止数据出错。
安装问题
使用说明
1.如果是用 MySQL + Apache,使用的又是 FreeBSD 网路作业系统的话,安装时候你应按注意到FreeBSD的版本问题,在 FreeBSD 的 3.0 以下版本来说,MySQL Source 内含的 MIT-pthread 运行是正常的,但在这版本以上,你必须使用 native threads,也就是加入一个 with-named-thread-libs=-lc_r 的选项。
2.如果在 COMPILE 过程中出了问题,请先检查你的 gcc版本是否在 2.81 版本以上,gmake 版本是否在3.75以上。
3.如果不是版本的问题,那可能是你的记忆体不足,请使用 ./configure--with-low-memory 来加入。
4.如果要重新做你的 configure,那幺你可以键入 rm config.cache 和 make clean 来清除记录。
5.把 MySQL 安装在 /usr/local 目录下,这是预设值,您也可以按照你的需要设定你所安装的目录。
服务无法启动
1、,查看MySQL的服务是否存在。如果不存在需要先安装服务。安装服务的方法是进入MySQL Server的安装目录,找到bin目录,然后找到档案mysqld.exe,使用命令行运行 mysqld --install MySQL57 安装服务(如果不成功尝试使用管理员方式运行,MySQL57是服务的名字,默认是MySQL)。
2、如果上述方法安装服务失败,则可採用下述方法安装(成功则跳过此步)。搜寻程式“regedit.exe”,即注册表编辑器,打开后找到 “计算机”——"HKEY_LOCAL_MACHINE"——“SYSTEM”——“CurrentControlSet”——“Services”,然后在该目录下新建项MySQL57(服务的名字)即可成功建立项目。
3、找到新建的项,然后可以看到其中有ImagePath这一项,这其实是执行档的路径。因为MySQL服务是需要靠mysqld这个命令来启动的,所以检查下ImagePath的路径是否正确。路径错误导致启动服务时报错—“无法找到档案”。
4、修改ImagePath的内容为正确的路径值,正确的值是"D:\MySQL\MySQL Server 5.7\bin\mysqld" --defaults-file="D:\MySQL\MySQL Server 5.7\my.ini" MySQL 是这种形式的,对照一下,如果路径不对,修改过来。
5、重启计算机,启动服务,并可以成功运行MySQL服务。
报错解决
1.Starting MySQL.Manager of pid-file quit without updating fi[失败]
关于这个错误原因有很多,最大的可能是没有创建测试资料库,可以用/usr/local/mysql/scripts/mysql_install_db –user=mysql命令进行创建;一个原因可能是许可权设定问题,需要赋予mysql的data许可权,可以用chmod -R 命令。
2.FATAL ERROR: Could not find /home/mysql/bin/my_print_defaults If you are using a binary release,you must run this script from
within the directory the archive extracted into. If you compiled
MySQL yourself you must run ‘make install’ first.
这个错误,是没有指明mysql的data路径导致的,可以很简单的进行解决
vim /etc/my.cnf
在[mysqld] 后面加上路径
basedir = /usr/local/mysql
datadir =/opt/data;
3.-bash: mysql: command not found
用mysql命令进行登入mysql报错,原因是没有设定环境变数,需要设定,或者进入到bin目录进行登入cd /usr/local/mysql/bin
mysql -u root
4.ERROR 1130: Host ’192.168.1.3′ is not allowed to connect to this MySQL server
用mysql远程工具连结资料库报错,这个错误原因是没有开放远程连结功能,可以在mysql里面输入如下命令进行解决GRANT ALL PRIVILEGES ON . TO ’root‘@’%' IDENTIFIED BY ’password’ WITH GRANT OPTION
初学基础
连线 MySQL
格式mysql -h 主机地址 -u 用户名 -p 用户密码
1.例1连线到本机上的MYSQL。
在打开 DOS 视窗,然后进入目录 mysqlbin,再键入命令mysql -uroot -p,回车后提示你输密码,如果刚安装好MYSQL,超级用户root 是没有密码的,故直接回车即可进入到 MySQL 中了,MySQL 的提示符是mysql>
2.例2连线到远程主机上的MYSQL。假设远程主机的IP为110.110.110.110,用户名为root,密码为abcd123。则键入以下命令
mysql -h110.110.110.110 -uroot -pabcd123
(注u与root可以不用加空格,其它也一样)
3.退出 MySQL 命令exit (回车)
注意想要成功连线到远程主机,需要在远程主机打开MySQL远程访问许可权
方法如下
在远程主机中以管理员身份进入
输入如下命令
mysql>GRANT ALL PRIVILEGES ON . TO 'agui'@%'IDENTIFIEDBY '123' WITH GRANT OPTION;
FLUSH PRIVILEGES;
//赋予任何主机访问数据的许可权
mysql>FLUSH PRIVILEGES
//修改生效
agui为我们使用的用户名
密码为 123
即在远程主机上作好设定,我们即可通过mysql -h110.110.110.110 -uagui -p123连线进远程主机
修改密码
格式mysqladmin -u用户名 -p旧密码 password 新密码
1.例1给root加个密码ab12。在DOS下进入目录mysqlbin,然后键入以下命令
mysqladmin -uroot -password ab12
注因为开始时root没有密码,所以-p旧密码一项就可以省略了。
2.例2再将root的密码改为djg345。
mysqladmin -uroot -pab12 password djg345
增加新用户
(注意和上面不同,下面的因为是 MySQL 环境中的命令,所以后面都带一个分号作为命令结束符)
格式grant select on 资料库. to 用户名@登录主机 identified by “密码”
例1、增加一个用户 test1 密码为 abc,让他可以在任何主机上登录,并对所有资料库有查询、插入、修改、删除的许可权。用以 root 用户连入 MySQL,然后键入以下命令
grant select,insert,update,delete on . to test1@“%” Identified by “abc”;
但例1增加的用户是十分危险的,你想如某个人知道test1的密码,那幺他就可以在internet上的任何一台电脑上登录你的mysql资料库并对你的数据可以为所欲为了,解决办法见例2。
例2、增加一个用户 test2 密码为 abc,让他只可以在 localhost 上登录,并可以对资料库 mydb 进行查询、插入、修改、删除的操作(localhost指本地主机,即MYSQL资料库所在的那台主机),这样用户即使用知道test2的密码,他也无法从internet上直接访问资料库,只能通过MYSQL主机上的web页来访问了。
grant select, insert, update, delete on mydb. to test2@localhost identified by “abc”;
如果你不想 test2 有密码,可以再打一个命令将密码消掉。
grant select, insert, update, delete on mydb. to test2@localhost identified by “”;
下面来看看 MySQL 中有关资料库方面的操作。注意必须登录到 MySQL 中,以下操作都是在 MySQL 的提示符下进行的,而且每个命令以分号结束。
操作技巧
1.如果你打命令时,回车后发现忘记加分号,你无须重打一遍命令,只要打个分号回车就可以了。也就是说你可以把一个完整的命令分成几行来打,完后用分号作结束标誌就 OK。
2.你可以使用游标上下键调出以前的命令。但以前我用过的一个 MySQL 旧版本不支持。我用的是mysql-3.23.27-beta-win。
显示命令
1.显示资料库列表。
show databases;
刚开始时才两个资料库mysql 和 test。mysql 库很重要它里面有 MySQL 的系统信息,我们改密码和新增用户,实际上就是用这个库进行操作。
2.显示库中的数据表
use mysql; //打开库,学过 FOXBASE 的一定不会陌生吧
show tables;
3.显示数据表的结构
describe 表名;
4.建库
create database 库名;
5.建表
use 库名;
create table 表名 (栏位设定列表);
6.删库和删表
drop database 库名;
drop table 表名;
7.将表中记录清空
delete from 表名;
8.显示錶中的记录
select from 表名;
9.显示一个执行的语句所产生的错误、警告和通知
show warnings;
10.只显示一个执行语句所产生的错误
show errors;
实例
drop database if exists school; //如果存在SCHOOL则删除
create database school; //建立库SCHOOL
use school; //打开库SCHOOL
create table teacher //建立表TEACHER
(
id int(3) auto_increment not null primary key,
name char(10) not null,
address varchar(50) default ‘深圳',
year date
); //建表结束
//以下为插入栏位
insert into teacher values('','glchengang',’XX公司‘,'1976-10-10');
insert into teacher values('','jack',’XX公司‘,'1975-12-23');
注在建表中
1.将ID设为长度为3的数字栏位int(3)并让它每个记录自动加一auto_increment并不能为空not null而且让他成为主栏位primary key。
2.将NAME设为长度为10的字元栏位。
3.将ADDRESS设为长度50的字元栏位,而且预设值为深圳。varchar和char有什幺区别呢,只有等以后的文章再说了。
4.将YEAR设为日期栏位。
如果你在mysql提示符键入上面的命令也可以,但不方便调试。你可以将以上命令原样写入一个文本档案中假设为school.sql,然后複製到c:\下,并在DOS状态进入目录\mysql\bin,然后键入以下命令
mysql -uroot -p密码 < c:\school.sql
如果成功,空出一行无任何显示;如有错误,会有提示。(以上命令已经调试,你只要将//的注释去掉即可使用)。
文本转资料库
1.文本数据应符合的格式栏位数据之间用tab键隔开,null值用\n来代替.
例
3.rose 深圳二中 1976-10-10
4.mike 深圳一中 1975-12-23
2.数据传入命令 load data local infile “档案名称” into table 表名;
注意你最好将档案複製到\mysql\bin目录下,并且要先用use命令打开表所在的资料库
或者登录资料库前将路径转移(cd)到要导入文本所在路径。
备份资料库
(命令在DOS的\mysql\bin目录下执行)
mysqldump --opt school>school.bbb
注释将资料库school备份到school.bbb档案,school.bbb是一个文本档案,档案名称任取,打开看看你会有新发现。
自动备份 mysql 资料库的方法
1、先是建立批处理档案,将以下代码储存为.bat档案,档案名称最好为英文。注意下面的路径,以笔者自己的资料库为例,资料库安装在D糟下mysql\mysql下,备份位置在F:\beifen,后面的代码是日期。
@echo off
color 0D
MODE con: COLS=71 LINES=25
title mysql资料库自动备份脚本(任务计画)--脚本作者http://www。。com
set sou_dir="D:\mysql\Mysql\data"
set obj_dir=F:\beifen\%date:~0,10%
net stop mysql
md %obj_dir%
xcopy /e /y %sou_dir% %obj_dir%
net start mysql
@echo off&setlocal enabledelayedexpansion
call:D,30
echo. 30天前的日期为%D%
echo. 删除30天以前备份......
if exist F:\beifen\%D% rd /s /q F:\beifen\%D%
echo 自动备份完成,程式将自动退出......
还原导入
还原/导入资料库,导入过程,进入 mysql 资料库控制台,如 mysql -u root -p
mysql>use 资料库
然后使用 source 命令,后面参数为脚本档案(如这里用到的.sql)
mysql>source d:\dbname.sql
如果提示找不到档案,输完 source 后,可以用滑鼠把档案直接拖进命令行视窗
启动跟蹤
mysqld --debug
关闭伺服器
mysqladmin -u root shutdown
启动服务
mysqld --console
安全设定
一、内部安全性-保证数据目录访问的安全
1.1资料库档案。
1.2日誌档案。
二、外部安全性-保证网路访问的安全
2.1 MySQL 授权表的结构和内容
2.2 伺服器控制客户访问
2.3 避免授权表风险
2.4 不用 GRANT设定用户
管理工具
可以使用命令行工具管理 MySQL 资料库(命令 mysql 和 mysqladmin),也可以从 MySQL 的网站下载图形管理工具 MySQL Administrator, MySQL Query Browser 和 MySQL Workbench。
phpMyAdmin是由 php 写成的 MySQ L资料库系统管理程程式,让管理者可用 Web 界面管理 MySQL 资料库。
phpMyBackupPro也是由 PHP 写成的,可以透过 Web 界面创建和管理资料库。它可以创建伪 cronjobs,可以用来自动在某个时间或周期备份 MySQL 资料库。
,还有其他的 GUI 管理工具,例如 mysql-front 以及 ems mysql manager, navicat等等。
解决方法
MySQL 中文排序错误的解决方法
方法1
在 MySQL 资料库中,进行中文排序和查找的时候,对汉字的排序和查找结果是错误的。这种情况在 MySQL 的很多版本中都存在。如果这个问题不解决,那幺 MySQL 将无法实际处理中文。
出现这个问题的原因是MySQL 在查询字元串时是大小写不敏感的,在编绎 MySQL 时一般以 ISO-8859 字元集作为默认的字元集,在比较过程中中文编码字元大小写转换造成了这种现象,一种解决方法是对于包含中文的栏位加上 "binary" 属性,使之作为二进制比较,例如将 "name char(10)" 改成 "name char(10)binary"。
方法2
如果你使用源码编译 MySQL,可以编译 MySQL 时使用 --with--charset=gbk 参数,这样 MySQL 就会直接支持中文查找和排序了。
授权问题
授权协定
MySQL 遵守的不只是 GPL 协定,而是双授权模式(dual license)即你在遵守 GPL 协定的开源项目使用 MySQL,需要遵守 GPL 协定方能使用。如果你在非开源项目使用(即软体不打算开放原始码),且该软体用来销售,则需要向 MySQL 支付相应 license 费用。
手册bug
在 5.5.31 版本时人们发现 Oracle 取消了其中的 GPL 协定,造成了一定的不安。有开发者在 MySQL 程式臭虫网站上举报这项授权错误问题,随即 MySQL 工程服务总监 Yngve Svendsen 在网站上坦言,这的确是一个档案臭虫,因为 man 手册程式重新编译时套用了错误的授权内容。不过仍然有人认为,Oracle 取消开源授权改採商业授权的“这一天迟早是要到来的”,并寻求其他代替方案。
安装
一、安装Mysql5.5为例。
1、运行 mysql 安装档案;
2、按 Next,然后选择安装方式,有 "Typical(默认)"、"Complete(完全)"、"Custom(用户自定义)",选择第二个选项 "Custom",下一步, MySQL Server (mysql伺服器), Developer Components (开发者部分), Debug Symbols (调试符号), Server data files (伺服器数据档案) 默认;
3、改变安装路径;原路径是"C:\Program Files\MySQL\MySQL Server 5.5\",也可以修改为"E:\Program Files\MySQL Server 5.5\"。下一步,安装,会弹出视窗,点下一步,再点下一步,选择"Launch the MySql instance Configuration Wizard",意思是启动MySQL实例配置嚮导,再点击Finish,再点下一步,Detailed Configuration(详细配置)和Standard Configuration(标準配置),选择详细配置,下一步;
4、选择伺服器类型,"Developer Machine(开发测试类,mysql占用很少资源)"、"Server Machine(伺服器类型,mysql占用较多资源)"、"DedicatedMySQL Server Machine(专门的资料库伺服器,mysql占用所有可用资源)",根据自己的类型选择,测试软体选"Developer Machine",伺服器选"Server Machine",下一步;
5、选择创建 MySQL表时使用的表处理器,"Multifunctional Database"(通用多功能型,好,使用InnoDB和 MyISAM 储存引擎)、"Transactional Database Only"(伺服器类型,专注于事务处理,主要使用 InnoDB 只偶尔使用 MyISAM,一般)、"Non-Transactional DatabaseOnly"(非事务处理型,较简单,完全禁用 InnoDB 储存引擎,将所有伺服器资源指派给 MyISAM 储存引擎),随自己的用途而选择。
2、按 Next,然后选择安装方式,有 "Typical(默认)"、"Complete(完全)"、"Custom(用户自定义)",选择第二个选项 "Custom",下一步, MySQL Server (mysql伺服器), Developer Components (开发者部分), Debug Symbols (调试符号), Server data files (伺服器数据档案) 默认;
3、改变安装路径;原路径是"C:\Program Files\MySQL\MySQL Server 5.5\",也可以修改为"E:\Program Files\MySQL Server 5.5\"。下一步,安装,会弹出视窗,点下一步,再点下一步,选择"Launch the MySql instance Configuration Wizard",意思是启动MySQL实例配置嚮导,再点击Finish,再点下一步,Detailed Configuration(详细配置)和Standard Configuration(标準配置),选择详细配置,下一步;
4、选择伺服器类型,"Developer Machine(开发测试类,mysql占用很少资源)"、"Server Machine(伺服器类型,mysql占用较多资源)"、"DedicatedMySQL Server Machine(专门的资料库伺服器,mysql占用所有可用资源)",根据自己的类型选择,测试软体选"Developer Machine",伺服器选"Server Machine",下一步;
5、选择创建 MySQL表时使用的表处理器,"Multifunctional Database"(通用多功能型,好,使用InnoDB和 MyISAM 储存引擎)、"Transactional Database Only"(伺服器类型,专注于事务处理,主要使用 InnoDB 只偶尔使用 MyISAM,一般)、"Non-Transactional DatabaseOnly"(非事务处理型,较简单,完全禁用 InnoDB 储存引擎,将所有伺服器资源指派给 MyISAM 储存引擎),随自己的用途而选择。
替代方案
随着 MySQL 被 Oracle 收购,MySQL 的用户和开发者开始质疑开源资料库的命运,与此他们开始寻找替代品。
有文章写到了放弃 MySQL 的五大理由
- MySQL 不如其它关係型资料库管理系统那样成熟;
- MySQL 是开源的...但只有近似而已;
- MySQL 的性能无法与竞争对手相提并论;
- MySQL 是 Oracle 所有的,而不是社区驱动的;
- 越来越多的强劲对手。
MariaDB
从 MySQL 转向 MariaDB的代表厂家谷歌(2013年9月)、RedHat(2013年6月)、维基百科(2013年4月)
MySQL 在 2008 年被Sun以10亿美金所收购,MySQL 创始人 Michael Widenius 则不满 Sun 开发团队脚步过慢,愤而离职成立开源资料库联盟,从现有 MySQL 程式代码中,开发出另一个延伸分支版本,也就是名为玛莉亚资料库的企业级开源资料库。
玛莉亚资料库如同 MySQL 的影子版本,玛莉亚资料库是 MySQL 的一个分支版本(branch),而不是衍生版本(folk),提供的功能可和 MySQL 完全兼容。
PostgreSQL
从 MySQL 转向 PostgreSQL的代表厂家苹果(2011年)
PostgreSQL是一个自由的对象-关係资料库伺服器(资料库管理系统)。PostgreSQL支持大部分 SQL标準并且提供了许多其它现代特性複杂查询、外键、触发器、视图、事务完整性、MVCC。同样,PostgreSQL 可以用许多方法扩展,比如, 通过增加新的数据类型、函式、操作符、聚集函式、索引方法、过程语言。并且,因为许可证的灵活,任何人都可以以任何目的免费使用、修改、和分发 PostgreSQL,不管是私用、商用、还是学术研究使用。
PostgreSQL 也受 NoSQL 思想的启发,希望能够在今后可以给使用者更多可定製可调节的功能(不是说这个成熟的关係性资料库系统要向 NoSQL 转变)。
NoSQL
NoSQL(NoSQL = Not Only SQL),意即“不仅仅是 SQL”,是一项全新的资料库革命性运动。NoSQL指的是非关係型的资料库。随着网际网路 web2.0网站的兴起,传统的关係资料库在应付 web2.0 网站,特别是超大规模和高并发的 SNS 类型的 web2.0 纯动态网站已经显得力不从心,暴露了很多难以克服的问题,而非关係型的资料库则由于其本身的特点得到了非常迅速的发展。
其代表的开源软体如Membase、MongoDB、Hypertable、Apache Cassandra、CouchDB等。
Oracle免费版
Oracle自 Oracle 10g 后推出对应的免费版。
远程访问
1将 localhost 改成 "%"
修改 "mysql" 资料库里的 "user" 表里的 "host" 项,将"localhost"改成"%"
mysql>use mysql;
mysql>update user set host = '%' where user = 'root';
mysql>select host, user from user;
mysql>FLUSH PRIVILEGES;
2使用 myuser/mypassword 从任何主机连线到 mysql 伺服器:
GRANT ALL PRIVILEGES ON . TO 'myuser'@'%' IDENTIFIED BY 'mypassword' WITH GRANT OPTION;
使用myuser/mypassword从ip为192.168.225.166的主机连线到mysql伺服器:
GRANT ALL PRIVILEGES ON . TO 'myuser'@'192.168.225.166' IDENTIFIED BY 'mypassword' WITH GRANT OPTION;
3泛授权
mysql -h localhost -u root
mysql>GRANT ALL PRIVILEGES ON . TO 'root'@'%' WITH GRANT OPTION; //赋予任何主机上以root身份访问数据的许可权
mysql>FLUSH PRIVILEGES;
1. 性能MySQL 8.0 的速度要比 MySQL 5.7 快 2 倍。MySQL 8.0 在以下方面带来了更好的性能读/写工作负载、IO 密集型工作负载、以及高竞争("hot spot"热点竞争问题)工作负载。
2. NoSQLMySQL 从 5.7 版本开始提供 NoSQL 存储功能,在 8.0 版本中这部分功能也得到了更大的改进。该项功能消除了对独立的 NoSQL 文档资料库的需求,而 MySQL 文档存储也为 schema-less 模式的 JSON 文档提供了多文档事务支持和完整的 ACID 合规性。
3. 视窗函式(Window Functions)从 MySQL 8.0 开始,新增了一个叫视窗函式的概念,它可以用来实现若干新的查询方式。视窗函式与 SUM()、COUNT() 这种集合函式类似,但它不会将多行查询结果合併为一行,而是将结果放回多行当中。即视窗函式不需要 GROUP BY。
4. 隐藏索引在 MySQL 8.0 中,索引可以被“隐藏”和“显示”。当对索引进行隐藏时,它不会被查询最佳化器所使用。我们可以使用这个特性用于性能调试,例如我们先隐藏一个索引,然后观察其对资料库的影响。如果资料库性能有所下降,说明这个索引是有用的,然后将其“恢复显示”即可;如果资料库性能看不出变化,说明这个索引是多余的,可以考虑删掉。
5. 降序索引MySQL 8.0 为索引提供按降序方式进行排序的支持,在这种索引中的值也会按降序的方式进行排序。
6. 通用表表达式(Common Table Expressions CTE)在複杂的查询中使用嵌入式表时,使用 CTE 使得查询语句更清晰。
7. UTF-8 编码从 MySQL 8 开始,使用 utf8mb4 作为 MySQL 的默认字元集。
8. JSONMySQL 8 大幅改进了对 JSON 的支持,添加了基于路径查询参数从 JSON 栏位中抽取数据的 JSON_EXTRACT() 函式,以及用于将数据分别组合到 JSON 数组和对象中的 JSON_ARRAYAGG() 和 JSON_OBJECTAGG() 聚合函式。
9. 可靠性InnoDB 支持表 DDL 的原子性,也就是 InnoDB 表上的 DDL 也可以实现事务完整性,要幺失败回滚,要幺成功提交,不至于出现 DDL 时部分成功的问题,还支持 crash-safe 特性,元数据存储在单个事务数据字典中。
10. 高可用性(High Availability)InnoDB 集群为您的资料库提供集成的原生 HA 解决方案。
11. 安全性对 OpenSSL 的改进、新的默认身份验证、SQL 角色、密码强度、授权
新特性
- 表和索引的分区
- 行级複製
- MySQL 基群基于磁碟的数据支持
- MySQL 集群複製
- 增强的全文本搜寻函式
- 增强的信息模式(数据字典)
- 可插入的 API
- 伺服器日誌表
- XML(标準通用标记语言的子集)/ XPath支持
- 实例管理器
- 表空间备份
- mysql_upgrade 升级程式
- 内部任务/事件调度器
- 新的性能工具和选项如 mysqlslap
MySQL PHP 语法
MySQL 可套用于多种语言,包括 PERL, C, C++, JAVA 和 PHP。 在这些语言中,MySQL 在 PHP 的 web 开发中是套用最广泛。
在本教程中我们大部分实例都採用了PHP语言。如果你想了解 MySQL 在 PHP 中的套用,可以访问我们的PHP 中使用 MySQL 介绍。
PHP 提供了多种方式来访问和操作 MySQL 资料库记录。PHP MySQL 函式格式如下
mysql_function(value,value,...);
以上格式中function部分描述了mysql函式的功能,如mysqli_connect($connect);mysqli_query($connect,"SQLstatement");mysql_fetch_array()mysql_connect(),mysql_close()
以下实例展示了PHP调用mysql函式的语法
<html><head></head><body><?php$retval=mysql_function(value,[value,...]);if(!$retval){die("Error:arelatederrormessage");}//OtherwiseMySQLorPHPStatements?></body></html>