还剩11页未读,继续阅读
本资源只提供10页预览,全部文档请下载后查看!喜欢就下载吧,查找使用更方便
文本内容:
mySQL mySQL百科名片MySQL名字的来历MySQL是一个小型关系型数据库管理系统,开发者为瑞典MySQLAB公司,在2008年1月16号被Sun公司收购MySQL被广泛地应用在Internet上的中小型网站中由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,许多中小型网站为了降低网站总体拥有成本而选择了MySQL作为网站数据库[编辑本段]简介MySQL最初的开发者的意图是用mSQL和他们自己的快速低级例程ISAM去连接表格不管怎样,在经过一些测试后,开发者得出结论mSQL并没有他们需要的那么快和灵活这导致了一个使用几乎和mSQL一样的API接口的用于他们的数据库的新的SQL接口的产生,这样,这个API被设计成允许为用于mSQL而写的第三方代码更容易移植到MySQLMySQL这个名字是怎么来的已经不清楚了基本指南和大量的库和工具带有前缀my已经有10年以上,而且不管怎样,MySQL AB创始人之一的Monty Widenius的女儿也叫My这两个到底是哪一个给出了MySQL这个名字至今依然是个迷,包括开发者在内也不知道MySQL的海豚标志的名字叫sakila,它是由MySQL AB的创始人从用户在海豚命名的竞赛中建议的大量的名字表中选出的获胜的名字是由来自非洲斯威士兰的开源软件开发者Ambrose Twebaze提供根据Ambrose所说,Sakila来自一种叫SiSwati的斯威士兰方言,也是在Ambrose的家乡乌干达附近的坦桑尼亚的Arusha的一个小镇的名字[编辑本段]MySQL的概述MySQL是一个小型关系型数据库管理系统,开发者为瑞典MySQL AB公司在2008年1月16号被Sun公司收购而2009年,SUN又被Oracal收购.对于Mysql的前途,没有任何人抱乐观的态度.目前MySQL被广泛地应用在Internet上的中小型网站中由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,许多中小型网站为了降低网站总体拥有成本而选择了MySQL作为网站数据库MySQL的官方网站的网址是www.mysql.com[编辑本段]MySQL的特性
1.使用C和C++编写,并使用了多种编译器进行测试,保证源代码的可移植性
2.支持AIX、FreeBSD、HP-UX、Linux、Mac OS、Novell Netware、OpenBSD、OS/2Wrap、Solaris、Windows等多种操作系统
3.为多种编程语言提供了API这些编程语言包括C、C++、Python、Java、Perl、PHP、Eiffel、Ruby和Tcl等
4.支持多线程,充分利用CPU资源
5.优化的SQL查询算法,有效地提高查询速度
6.既能够作为一个单独的应用程序应用在客户端服务器网络环境中,也能够作为一个库而嵌入到其他的软件中提供多语言支持,常见的编码如中文的GB
2312、BIG5,日文的Shift_JIS等都可以用作数据表名和数据列名
7.提供TCP/IP、ODBC和JDBC等多种数据库连接途径
8.提供用于管理、检查、优化数据库操作的管理工具
9.可以处理拥有上千万条记录的大型数据库[编辑本段]MySQL的应用与其他的大型数据库例如Oracle、DB
2、SQL Server等相比,MySQL自有它的不足之处,如规模小、功能有限MySQL Cluster的功能和效率都相对比较差等,但是这丝毫也没有减少它受欢迎的程度对于一般的个人使用者和中小型企业来说,MySQL提供的功能已经绰绰有余,而且由于MySQL是开放源码软件,因此可以大大降低总体拥有成本目前Internet上流行的网站构架方式是LAMPLinux+Apache+MySQL+PHP,即使用Linux作为操作系统,Apache作为Web服务器,MySQL作为数据库,PHP作为服务器端脚本解释器由于这四个软件都是自由或开放源码软件FLOSS,因此使用这种方式不用花一分钱就可以建立起一个稳定、免费的网站系统[编辑本段]MySQL管理可以使用命令行工具管理MySQL数据库命令mysql和mysqladmin,也可以从MySQL的网站下载图形管理工具MySQL Administrator和MySQL QueryBrowserphpMyAdmin是由php写成的MySQL资料库系统管理程式,让管理者可用Web界面管理MySQL资料库phpMyBackupPro也是由PHP写成的,可以透过Web介面创建和管理数据库它可以创建伪cronjobs,可以用来自动在某个时间或周期备份MySQL数据库另外,还有其他的GUI管理工具,例如早先的mysql-front以及ems mysqlmanager,navicat等等[编辑本段]Mysql存储引擎MyISAM Mysql的默认数据库,最为常用拥有较高的插入,查询速度,但不支持事务InnoDB事务型数据库的首选引擎,支持ACID事务,支持行级锁定BDB源自Berkeley DB,事务型数据库的另一种选择,支持COMMIT和ROLLBACK等其他事务特性Memory所有数据置于内存的存储引擎,拥有极高的插入,更新和查询效率但是会占用和数据量成正比的内存空间并且其内容会在Mysql重新启动时丢失Merge将一定数量的MyISAM表联合而成一个整体,在超大规模数据存储时很有用Archive非常适合存储大量的独立的,作为历史记录的数据因为它们不经常被读取Archive拥有高效的插入速度,但其对查询的支持相对较差Federated将不同的Mysql服务器联合起来,逻辑上组成一个完整的数据库非常适合分布式应用Cluster/NDB高冗余的存储引擎,用多台数据机器联合提供服务以提高整体性能和安全性适合数据量大,安全和性能要求高的应用CSV逻辑上由逗号分割数据的存储引擎BlackHole黑洞引擎,写入的任何数据都会消失,一般用于记录binlog做复制的中继另外,Mysql的存储引擎接口定义良好有兴趣的开发者通过阅读文档编写自己的存储引擎[编辑本段]Mysql最常见的应用架构单点Single,适合小规模应用复制Replication,适合中小规模应用集群Cluster,适合大规模应用MySQL
4.1版本中增加了不少新的性能,包括对主键的更高速度的缓存,对子查询的更好的支持,以及应网络约会网站所要求的,基于地理信息的查询其同步开发的
5.0版本则把目标对准了企业用户,对于
4.1版本中的所有新特性,
5.0版本悉数收入囊中,并且独具以下特点对外键的良好支持;系统自动报错机制以及对存储过程的充分支持[编辑本段]MySQL的索引文件介绍
[1]索引是一种特殊的文件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、限制如果WEHERE子句的查询条件里有不等号WHEREcoloum!=,MySQL将无法使用索引类似地,如果WHERE子句的查询条件里使用了函数WHEREDAYcolumn=,MySQL也将无法使用索引在JOIN操作中需要从多个数据表提取数据时,MySQL只有在主键和外键的数据类型相同时才能使用索引如果WHERE子句的查询条件里使用比较操作符LIKE和REGEXP,MySQL只有在搜索模板的第一个字符不是通配符的情况下才能使用索引比如说,如果查询条件是LIKEabc%,MySQL将使用索引;如果查询条件是LIKE%abc,MySQL将不使用索引在ORDERBY操作中,MySQL只有在排序条件不是一个查询条件表达式的情况下才使用索引虽然如此,在涉及多个数据表查询里,即使有索引可用,那些索引在加快ORDERBY方面也没什么作用如果某个数据列里包含许多重复的值,就算为它建立了索引也不会有很好的效果比如说,如果某个数据列里包含的净是些诸如0/1或Y/N等值,就没有必要为它创建一个索引MySQL普通索引、唯一索引和主索引
1、普通索引普通索引由关键字KEY或INDEX定义的索引的唯一任务是加快对数据的访问速度因此,应该只为那些最经常出现在查询条件WHEREcolumn=或排序条件ORDERBYcolumn中的数据列创建索引只要有可能,就应该选择一个数据最整齐、最紧凑的数据列如一个整数类型的数据列来创建索引
2、唯一索引普通索引允许被索引的数据列包含重复的值比如说,因为人有可能同名,所以同一个姓名在同一个员工个人资料数据表里可能出现两次或更多次如果能确定某个数据列将只包含彼此各不相同的值,在为这个数据列创建索引的时候就应该用关键字UNIQUE把它定义为一个唯一索引这么做的好处一是简化了MySQL对这个索引的管理工作,这个索引也因此而变得更有效率;二是MySQL会在有新记录插入数据表时,自动检查新记录的这个字段的值是否已经在某个记录的这个字段里出现过了;如果是,MySQL将拒绝插入那条新记录也就是说,唯一索引可以保证数据记录的唯一性事实上,在许多场合,人们创建唯一索引的目的往往不是为了提高访问速度,而只是为了避免数据出现重复
3、主索引在前面已经反复多次强调过必须为主键字段创建一个索引,这个索引就是所谓的主索引主索引与唯一索引的唯一区别是前者在定义时使用的关键字是PRIMARY而不是UNIQUE
4、外键索引如果为某个外键字段定义了一个外键约束条件,MySQL就会定义一个内部索引来帮助自己以最有效率的方式去管理和使用外键约束条件
5、复合索引索引可以覆盖多个数据列,如像INDEXcolumnA,columnB索引这种索引的特点是MySQL可以有选择地使用一个这样的索引如果查询操作只需要用到columnA数据列上的一个索引,就可以使用复合索引INDEXcolumnA,columnB不过,这种用法仅适用于在复合索引中排列在前的数据列组合比如说,INDEXA,B,C可以当做A或A,B的索引来使用,但不能当做B、C或B,C的索引来使用
6、索引的长度在为CHAR和VARCHAR类型的数据列定义索引时,可以把索引的长度限制为一个给定的字符个数这个数字必须小于这个字段所允许的最大字符个数这么做的好处是可以生成一个尺寸比较小、检索速度却比较快的索引文件在绝大多数应用里,数据库中的字符串数据大都以各种各样的名字为主,把索引的长度设置为10~15个字符已经足以把搜索范围缩小到很少的几条数据记录了在为BLOB和TEXT类型的数据列创建索引时,必须对索引的长度做出限制;MySQL所允许的最大索引全文索引文本字段上的普通索引只能加快对出现在字段内容最前面的字符串也就是字段内容开头的字符进行检索操作如果字段里存放的是由几个、甚至是多个单词构成的较大段文字,普通索引就没什么作用了这种检索往往以的形式出现,这对MySQL来说很复杂,如果需要处理的数据量很大,响应时间就会很长这类场合正是全文索引full-textindex可以大显身手的地方在生成这种类型的索引时,MySQL将把在文本中出现的所有单词创建为一份清单,查询操作将根据这份清单去检索有关的数据记录全文索引即可以随数据表一同创建,也可以等日后有必要时再使用下面这条命令添加ALTERTABLEtablenameADDFULLTEXTcolumn1,column2有了全文索引,就可以用SELECT查询命令去检索那些包含着一个或多个给定单词的数据记录了下面是这类查询命令的基本语法SELECT*FROMtablename WHEREMATCHcolumn1,column2AGAINSTword1,word2,word3上面这条命令将把column1和column2字段里有word
1、word2和word3的数据记录全部查询出来注解InnoDB数据表不支持全文索引[编辑本段]MySQL文件优化
[2]查询和索引的优化只有当数据库里已经有了足够多的测试数据时,它的性能测试结果才有实际参考价值如果在测试数据库里只有几百条数据记录,它们往往在执行完第一条查询命令之后就被全部加载到内存里,这将使后续的查询命令都执行得非常快--不管有没有使用索引只有当数据库里的记录超过了1000条、数据总量也超过了MySQL服务器上的内存总量时,数据库的性能测试结果才有意义在不确定应该在哪些数据列上创建索引的时候,人们从EXPLAINSELECT命令那里往往可以获得一些帮助这其实只是简单地给一条普通的SELECT命令加一个EXPLAIN关键字作为前缀而已有了这个关键字,MySQL将不是去执行那条SELECT命令,而是去对它进行分析MySQL将以表格的形式把查询的执行过程和用到的索引等信息列出来在EXPLAIN命令的输出结果里,第1列是从数据库读取的数据表的名字,它们按被读取的先后顺序排列type列指定了本数据表与其它数据表之间的关联关系JOIN在各种类型的关联关系当中,效率最高的是system,然后依次是const、eq_ref、ref、range、index和AllAll的意思是对应于上一级数据表里的每一条记录,这个数据表里的所有记录都必须被读取一遍--这种情况往往可以用一索引来避免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安装注意
1、如果是用MySQL+Apache,使用的又是FreeBSD网路操作系统的话,安装时候你应按注意到FreeBSD的版本问题,在FreeBSD的
3.0以下版本来说,MySQLSource内含的MIT-pthread运行是正常的,但在这版本以上,你必须使用nativethreads,也就是加入一个with-named-thread-libs=-lc_r的选项
2、如果在COMPILE过程中出了问题,请先检查你的gcc版本是否在
2.81版本以上,gmake版本是否在
3.75以上
3、如果不是版本的问题,那可能是你的内存不足,请使用./configure--with-low-memory来加入
4、如果要重新做你的configure,那么你可以键入rmconfig.cache和makeclean来清除记录
5、把MySQL安装在/usr/local目录下,这是缺省值,您也可以按照你的需要设定你所安装的目录[编辑本段]mysql历史版本MySQL公司目前在同时开发两个版本的软件,
4.1版以及
5.0版
4.1版本的代码已经发布并有望在8个月后公布最终代码而
5.0版本的最后产品将在6个月后发布MySQL
4.1版本中增加了不少新的性能,包括对主键的更高速度的缓存,对子查询的更好的支持,以及应网络约会网站所要求的,基于地理信息的查询而其同步开发的
5.0版本则把目标对准了企业用户,对于
4.1版本中的所有新特性,
5.0版本悉数收入囊中,并且独具以下特点对外键的良好支持;系统自动报错机制以及对存储过程的充分支持2009年初.MYSQL
5.4版预览本已放出.[编辑本段]Mysql中文视频教学左光华的mysql网络数据库开发教学视频Mysql
6.0的alpha版于2007年初发布,新版增加了对falcon存储引擎的支持Falcon是Mysql社区自主开发的引擎,支持ACID特性事务,支持行锁,拥有高性能的并发性Mysql AB公司想用Falcon替代已经非常流行的InnoDB引擎,因为拥有后者技术的InnoBase已经被竞争对手Oracle所收购2008年1月16日,Sun Microsystems宣布收购MySQL AB,出价约10亿美元现金包括期权[编辑本段]MySQL的基本命令[]中的内容为可选项--创建数据库mysql create database数据库名称--创建表mysql create table表名列的名字id类型int4primary key定义主键auto_increment描述自增,…,;--查看所有数据库mysql show databases;--使用某个数据库mysql use数据库名称;--查看所使用数据库下所有的表mysql show tables;--显示表的属性结构mysql desc表名;--选择表中数据的显示--*代表选择所有列,mysql select*from表名where id=[and name=][or name=];mysql selectid,name from表名order by某一列的名称desc降序,asc为升序--删除表中的数据mysql delete from tablewhere id=[or name=and name=];--删除表mysql drop table;--删除数据库mysql drop database;索引是一种特殊的文件InnoDB数据表上的索引是表空间的一个组成部分,它们包含着对数据表里所有记录的引用指针注
[1]索引不是万能的!索引可以加快数据检索操作,但会使数据修改操作变慢每修改数据记录,索引就必须刷新一次为了在某种程序上弥补这一缺陷,许多SQL命令都有一个DELAY_KEY_WRITE项这个选项的作用是暂时制止MySQL在该命令每插入一条新记录和每修改一条现有之后立刻对索引进行刷新,对索引的刷新将等到全部记录插入/修改完毕之后再进行在需要把许多新记录插入某个数据表的场合,DELAY_KEY_WRITE选项的作用将非常明显
[2]另外,索引还会在硬盘上占用相当大的空间因此应该只为最经常查询和最经常排序的数据列建立索引注意,如果某个数据列包含许多重复的内容,为它建立索引就没有太大的实际效果从理论上讲,完全可以为数据表里的每个字段分别建一个索引,但MySQL把同一个数据表里的索引总数限制为16个
1.InnoDB数据表的索引与MyISAM数据表相比,在InnoDB数据表上,索引对InnoDB数据表的重要性要在得多在InnoDB数据表上,索引不仅会在搜索数据记录时发挥作用,还是数据行级锁定机制的苊、基础数据行级锁定的意思是指在事务操作的执行过程中锁定正在被处理的个别记录,不让其他用户进行访问这种锁定将影响到但不限于SELECT.LOCK INSHARE MODE、SELECT.FOR UPDATE命令以及INSERT、UPDATE和DELETE命令出于效率方面的考虑,InnoDB数据表的数据行级锁定实际发生在它们的索引上,而不是数据表自身上显然,数据行级锁定机制只有在有关的数据表有一个合适的索引可供锁定的时候才能发挥效力
2.限制如果WHERE子句的查询条件里有不等号WHERE coloum!=.,MySQL将无法使用索引类似地,如果WHERE子句的查询条件里使用了函数WHERE DAYcolumn=.,MySQL也将无法使用索引在JOIN操作中需要从多个数据表提取数据时,MySQL只有在主键和外键的数据类型相同时才能使用索引如果WHERE子句的查询条件里使用比较操作符LIKE和REGEXP,MySQL只有在搜索模板的第一个字符不是通配符的情况下才能使用索引比如说,如果查询条件是LIKEabc%,MySQL将使用索引;如果查询条件是LIKE%abc,MySQL将不使用索引在ORDER BY操作中,MySQL只有在排序条件不是一个查询条件表达式的情况下才使用索引虽然如此,在涉及多个数据表查询里,即使有索引可用,那些索引在加快ORDER BY方面也没什么作用如果某个数据列里包含许多重复的值,就算为它建立了索引也不会有很好的效果比如说,如果某个数据列里包含的净是些诸如0/1或Y/N等值,就没有必要为它创建一个索引普通索引、唯一索引和主索引
1.普通索引普通索引由关键字KEY或INDEX定义的索引的唯一任务是加快对数据的访问速度因此,应该只为那些最经常出现在查询条件WHERE column=.或排序条件ORDER BYcolumn中的数据列创建索引只要有可能,就应该选择一个数据最整齐、最紧凑的数据列如一个整数类型的数据列来创建索引
2.唯一索引普通索引允许被索引的数据列包含重复的值比如说,因为人有可能同名,所以同一个姓名在同一个员工个人资料数据表里可能出现两次或更多次如果能确定某个数据列将只包含彼此各不相同的值,在为这个数据列创建索引的时候就应该用关键字UNIQUE把它定义为一个唯一索引这么做的好处一是简化了MySQL对这个索引的管理工作,这个索引也因此而变得更有效率;二是MySQL会在有新记录插入数据表时,自动检查新记录的这个字段的值是否已经在某个记录的这个字段里出现过了;如果是,MySQL将拒绝插入那条新记录也就是说,唯一索引可以保证数据记录的唯一性事实上,在许多场合,人们创建唯一索引的目的往往不是为了提高访问速度,而只是为了避免数据出现重复
3.主索引在前面已经反复多次强调过必须为主键字段创建一个索引,这个索引就是所谓的主索引主索引与唯一索引的唯一区别是前者在定义时使用的关键字是PRIMARY而不是UNIQUE
4.外键索引如果为某个外键字段定义了一个外键约束条件,MySQL就会定义一个内部索引来帮助自己以最有效率的方式去管理和使用外键约束条件
5.复合索引索引可以覆盖多个数据列,如像INDEXcolumnA,columnB索引这种索引的特点是MySQL可以有选择地使用一个这样的索引如果查询操作只需要用到columnA数据列上的一个索引,就可以使用复合索引INDEXcolumnA,columnB不过,这种用法仅适用于在复合索引中排列在前的数据列组合比如说,INDEXA,B,C可以当做A或A,B的索引来使用,但不能当做B、C或B,C的索引来使用
6.索引的长度在为CHAR和VARCHAR类型的数据列定义索引时,可以把索引的长度限制为一个给定的字符个数这个数字必须小于这个字段所允许的最大字符个数这么做的好处是可以生成一个尺寸比较小、检索速度却比较快的索引文件在绝大多数应用里,数据库中的字符串数据大都以各种各样的名字为主,把索引的长度设置为10~15个字符已经足以把搜索范围缩小到很少的几条数据记录了在为BLOB和TEXT类型的数据列创建索引时,必须对索引的长度做出限制;MySQL所允许的最大索引jlkjljkjlj全文索引文本字段上的普通索引只能加快对出现在字段内容最前面的字符串也就是字段内容开头的字符进行检索操作如果字段里存放的是由几个、甚至是多个单词构成的较大段文字,普通索引就没什么作用了这种检索往往以LIKE%word%的形式出现,这对MySQL来说很复杂,如果需要处理的数据量很大,响应时间就会很长这类场合正是全文索引full-text index可以大显身手的地方在生成这种类型的索引时,MySQL将把在文本中出现的所有单词创建为一份清单,查询操作将根据这份清单去检索有关的数据记录全文索引即可以随数据表一同创建,也可以等日后有必要时再使用下面这条命令添加ALTER TABLEtablename ADDFULLTEXTcolumn1,column2有了全文索引,就可以用SELECT查询命令去检索那些包含着一个或多个给定单词的数据记录了下面是这类查询命令的基本语法SELECT*FROM tablenameWHERE MATCHcolumn1,column2AGAINSTword1,word2,word3上面这条命令将把column1和column2字段里有word
1、word2和word3的数据记录全部查询出来注解InnoDB数据表不支持全文索引查询和索引的优化只有当数据库里已经有了足够多的测试数据时,它的性能测试结果才有实际参考价值如果在测试数据库里只有几百条数据记录,它们往往在执行完第一条查询命令之后就被全部加载到内存里,这将使后续的查询命令都执行得非常快--不管有没有使用索引只有当数据库里的记录超过了1000条、数据总量也超过了MySQL服务器上的内存总量时,数据库的性能测试结果才有意义在不确定应该在哪些数据列上创建索引的时候,人们从EXPLAIN SELECT命令那里往往可以获得一些帮助这其实只是简单地给一条普通的SELECT命令加一个EXPLAIN关键字作为前缀而已有了这个关键字,MySQL将不是去执行那条SELECT命令,而是去对它进行分析MySQL将以表格的形式把查询的执行过程和用到的索引如果有的话等信息列出来在EXPLAIN命令的输出结果里,第1列是从数据库读取的数据表的名字,它们按被读取的先后顺序排列type列指定了本数据表与其它数据表之间的关联关系JOIN在各种类型的关联关系当中,效率最高的是system,然后依次是const、eq_ref、ref、range、index和AllAll的意思是对应于上一级数据表里的每一条记录,这个数据表里的所有记录都必须被读取一遍--这种情况往往可以用一索引来避免possible_keys数据列给出了MySQL在搜索数据记录时可选用的各个索引key数据列是MySQL实际选用的索引,这个索引按字节计算的长度在key_len数据列里给出比如说,对于一个INTEGER数据列的索引,这个字节长度将是4如果用到了复合索引,在key_len数据列里还可以看到MySQL具体使用了它的哪些部分作为一般规律,key_len数据列里的值越小越好意思是更快ref数据列给出了关联关系中另一个数据表里的数据列的名字row数据列是MySQL在执行这个查询时预计会从这个数据表里读出的数据行的个数row数据列里的所有数字的乘积可以让我们大致了解这个查询需要处理多少组合最后,extra数据列提供了与JOIN操作有关的更多信息,比如说,如果MySQL在执行这个查询时必须创建一个临时数据表,就会在extra列看到using temporary字样[编辑本段]安装MySQL时候的注意事项
1、如果您是用MySQL+Apache,使用的又是FreeBSD网路操作系统的话,安装时候你应按注意到FreeBSD的版本问题,在FreeBSD的
3.0以下版本来说
[3]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目录下,这是缺省值,您也可以按照你的需要设定你所安装的目录[编辑本段]MySQL的学习资源MySQL的学习资源官方手册目前MySQL提供的官方手册中,英文版本包括以下系列MySQL
5.5参考手册MySQL
5.4参考手册MySQL
5.1参考手册MySQL
5.0参考手册MySQL
3.23/
4.0/
4.1参考手册中文版本为
5.1在线参考手册,URL参考扩展阅读前言这是关于
5.1版至
5.
1.2-alpha版MySQL数据库系统的参考手册该手册不适用于旧版本MySQL软件,这是因为在MySQL
5.1和以前的版本存在很多功能性差异和其他差异如果正在使用MySQL软件的较旧版本,请参阅MySQL
5.0参考手册,该手册涵盖了MySQL
5.0,或参阅MySQL
4.1参考手册,该手册涵盖了MySQL
4.1以及MySQL的所有早期版本在手册的文本中,通过引用发布版本号
5.
1.x,注明了MySQL
5.1的二级版本这是MySQL参考手册的翻译版本,关于MySQL参考手册,请访问dev.mysql.com原始参考手册为英文版,与英文版参考手册相比,本翻译版可能不是最新的[编辑本段]初学MySQL哪些需要你知道
一、连接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-h
110.
110.
110.110-uroot-pabcd123注u与root可以不用加空格,其它也一样
3、退出MYSQL命令exit回车注意想要成功连接到远程主机,需要在远程主机打开MySQL远程访问权限方法如下在远程主机中以管理员伙身份进入输入如下命令mysql GRANTALL PRIVILEGESON*.*TOagui@%IDENTIFIED BY123WITH GRANTOPTION;FLUSH PRIVILEGES;//赋予任何主机访问数据的权限mysql FLUSHPRIVILEGES//修改生效agui为我们使用的用户名密码为123即在远程主机上作好设置,我们即可通过mysql-h
110.
110.
110.110-uagui-p123连接进远程主机
二、修改密码格式mysqladmin-u用户名-p旧密码password新密码
1、例1给root加个密码ab12首先在DOS下进入目录mysqlbin,然后键入以下命令mysqladmin-uroot-password ab12注因为开始时root没有密码,所以-p旧密码一项就可以省略了
2、例2再将root的密码改为djg345mysqladmin-uroot-pab12password djg345
三、增加新用户注意和上面不同,下面的因为是MYSQL环境中的命令,所以后面都带一个分号作为命令结束符格式grant selecton数据库.*to用户名@登录主机identified by密码例
1、增加一个用户test1密码为abc,让他可以在任何主机上登录,并对所有数据库有查询、插入、修改、删除的权限首先用以root用户连入MYSQL,然后键入以下命令grant select,insert,update,delete on*.*to test1@%Identified byabc;但例1增加的用户是十分危险的,你想如某个人知道test1的密码,那么他就可以在internet上的任何一台电脑上登录你的mysql数据库并对你的数据可以为所欲为了,解决办法见例2例
2、增加一个用户test2密码为abc,让他只可以在localhost上登录,并可以对数据库mydb进行查询、插入、修改、删除的操作localhost指本地主机,即MYSQL数据库所在的那台主机,这样用户即使用知道test2的密码,他也无法从internet上直接访问数据库,只能通过MYSQL主机上的web页来访问了grant select,insert,update,delete onmydb.*to test2@localhost identifiedbyabc;如果你不想test2有密码,可以再打一个命令将密码消掉grant select,insert,update,delete onmydb.*to test2@localhost identifiedby;下面来看看MYSQL中有关数据库方面的操作注意必须首先登录到MYSQL中,以下操作都是在MYSQL的提示符下进行的,而且每个命令以分号结束
四、操作技巧
1、如果你打命令时,回车后发现忘记加分号,你无须重打一遍命令,只要打个分号回车就可以了也就是说你可以把一个完整的命令分成几行来打,完后用分号作结束标志就OK
2、你可以使用光标上下键调出以前的命令但以前我用过的一个MYSQL旧版本不支持我现在用的是mysql-
3.
23.27-beta-win
五、显示命令
1、显示数据库列表showdatabases;刚开始时才两个数据库mysql和test mysql库很重要它里面有MYSQL的系统信息,我们改密码和新增用户,实际上就是用这个库进行操作
2、显示库中的数据表use mysql;//打开库,学过FOXBASE的一定不会陌生吧showtables;
3、显示数据表的结构describe表名;
4、建库create database库名;
5、建表use库名;createtable表名字段设定列表;
6、删库和删表drop database库名;droptable表名;
7、将表中记录清空deletefrom表名;
8、显示表中的记录select*from表名;
六、一个建库和建表以及插入数据的实例dropdatabaseif existsschool;//如果存在SCHOOL则删除createdatabaseschool;//建立库SCHOOL useschool;//打开库SCHOOL createtable teacher//建立表TEACHERid int3auto_increment not null primary key,name char10not null,address varchar50default深圳,year date;//建表结束//以下为插入字段insert intoteacher values,glchengang,深圳一中,1976-10-10;insert intoteacher values,jack,深圳一中,1975-12-23;注在建表中1将ID设为长度为3的数字字段int3并让它每个记录自动加一auto_increment并不能为空notnull而且让他成为主字段primarykey2将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来代替.例3rose深圳二中1976-10-104mike深圳一中1975-12-
232、数据传入命令load datalocal infile文件名into table表名;注意你最好将文件复制到\mysql\bin目录下,并且要先用use命令打开表所在的数据库
八、备份数据库命令在DOS的\mysql\bin目录下执行mysqldump--opt schoolschool.bbb注释将数据库school备份到school.bbb文件,school.bbb是一个文本文件,文件名任取,打开看看你会有新发现
[4]参考资料
1.[url=版本构架及索引文件介绍
2.[url=服务器配置方案MySQL
3.[url=下IIS/Apache PHPMySQL的安装配置
4.[url=初学MySQL哪些需要你知道扩展阅读
1.mysql技术服务器安全技术开源中国mysql资料/讨论区
4.书籍库技术讨论区
5.如何修改遗失MYSQL的ROOT用户密码初学MySQL哪些需要你知道中文在线参考手册
8.特别声明1资料来源于互联网,版权归属原作者2资料内容属于网络意见,与本账号立场无关3如有侵权,请告知,立即删除。