Discuz!官方免费开源建站系统

 找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索

WINXP+2003 PHP5.0.4+ Zend 2.5.7+GD库++MySQL Control Center0.9.4安装方法

[复制链接]
kt600 发表于 2005-12-31 10:01:29 | 显示全部楼层 |阅读模式
本贴转自倾情靓软  作者:kankan (苍蝇)

PHP环境安装篇一、 所需软件
PHP 5.0.4
下载地址:

http://cn.php.net/get/php-5.0.4-Win32.zip/from/this/mirror

Zend
Optimizer2.5.7 for windows
下载地址:

http://jstt.downloadsky.com:8081/down/ZendOptimizer-2.5.7-Windows-i386.exe

  以上下载地址若失效,请另寻它处下载!
二、
开始安装软件:
(一)
安装PHP:
1、将PHP5.0.4解压出来存放C:\PHP文件夹中(存放路径可以更改,但以后用到路径要一并更改),
将C:\php目录下的所有dll文件和C:\php\ext下的所有DLL文件复制到c:\Windows\system32\下覆盖已有的dll文件如下图:


2、将C:\PHP目录下的php.exe、php-win.exe和php.ini-dist三个文件拷到C:\Windows
\下;
将C:\Windows\php.ini-dist改名为php.ini,然后用记事本打开,利用记事本的查找功能搜索
register_globals
= Off ,将 Off 改成 On ;
再搜索
extension_dir = "./" ,并将"./"改为"C: \php\ext"

搜索找到
;Windows Extensions
将;Windows
Extensions后面的:
;extension=php_dbase.dll   可选
;extension=php_gd2.dll    这个是用来支持GD库的,一般需要,必选
;extension=php_ldap.dll    可选
;extension=php_mbstring.dll  必选
;extension=php_mssql.dll    这个是用来支持MSSQL的,可选
;extension=php_mysql.dll    这个是用来支持MYSQL的,要支持MYSQL必选将以上代码前的";"去掉,其他的如果需要用到也可以去掉前面的;然后关闭保存该文件。
3、接下来安装“Zend
Optimizer2.5.7”
Zend Optimizer2.5.7用于优化PHP,提高PHP效率;
安装“Zend
Optimizer2.5.7”和安装普通软件没什么区别都按默认的即可,除其中有一步骤选择IIS,一路NEXT、确定、是、Finish,具体步骤此处省略!
************************************************************************
以下为XP和2003
IIS安装PHP支持的差别处,其他地方完全相同!
************************************************************************
4、XP安装IIS5.1支持PHP: 打开IIS,在默认网站”上单击右键选择“属性”,在打开的“
Web 站点属性”窗口的“ISAPI 筛选器”标签里找到并点击“添加”按钮,在弹出的“筛选器属性”窗口中的“筛选器名称”栏中输入:PHP ,再将可执行文件指向
php5isapi.dll 所在路径,如:C: \php\php5isapi.dll (如下图设置)。


确定后如下图:


打开“Web
站点属性”窗口的“主目录”标签,点击“配置”按钮,在弹出的“应用程序配置”窗口中找到并点击“添加”按钮,在弹出的窗口中新增一个扩展名映射,扩展名为 .php
,单击“浏览”将可执行文件指向 php5isapi.dll 所在路径,如:C:
\php\php5isapi.dll,然后一路确定即可(如下图设置所示)。如果还想支持诸如 .php3 ,.phtml 等扩展名的 PHP
文件,可以重复“添加”步骤。


再打开“Web 站点属性”窗口的“文档”标签,找到并点击“添加”按钮,向默认的 Web 站点启动文档列表中添加
index.php 项。您可以将 index.php 升到最高优先级,这样,访问站点时就会首先自动寻找并打开 index.php 文档。
确定 Web
目录的应用程序设置和执行许可中选择为“纯脚本”,
然后重新启动IIS!
再打开IIS管理器,再查看网站属性中“ISAPI筛选器”,如下图所示表明XP已成功为IIS加载了PHP支持。


4、2003安装IIS6.0支持PHP:
 打开IIS,在WEB服务器扩展中“添加一个新的Web服务器扩展”,
 扩展名填上:PHP,然后点“添加”设置如下图接着确定,把“设置扩展状态为允许”勾上确定完成服务器扩展添加。


选择IIS中“你需要支持PHP的Web站点”比如“默认Web站点”上单击右键选择“属性”,在打开的“ Web
站点属性”窗口的“ISAPI 筛选器”标签里找到并点击“添加”按钮,在弹出的“筛选器属性”窗口中的“筛选器名称”栏中输入:PHP ,再将可执行文件指向
php5isapi.dll 所在路径,如:C: \php\php5isapi.dll (如下图设置)。


打开“Web
站点属性”窗口的“主目录”标签,找到并点击“配置”按钮,在弹出的“应用程序配置”窗口中找到并点击“添加”按钮,在弹出的窗口中新增一个扩展名映射,扩展名为
.php ,单击“浏览”将可执行文件指向 php5isapi.dll 所在路径,如:C:
\php\php5isapi.dll,然后一路确定即可(如下图设置所示)。如果还想支持诸如 .php3 ,.phtml 等扩展名的 PHP
文件,可以重复“添加”步骤。


再打开“Web 站点属性”窗口的“文档”标签,找到并点击“添加”按钮,向默认的 Web 站点启动文档列表中添加
index.php 项。您可以将 index.php 升到最高优先级,这样,访问站点时就会首先自动寻找并打开 index.php 文档。确定 Web
目录的应用程序设置和执行许可中选择为纯脚本,然后关闭 Internet 信息服务管理器,在“命令提示符”中执行如下命令:
net stop
w3svc
net stop iisadmin
net start w3svc
再打开IIS管理器,在“Internet
服务管理器”左边的“WEB服务扩展”中设置ISAPI 扩展允许,
Active Server Pages
允许,Internet数据连接器为允许,最后重启IIS,再查看网站属性中“ISAPI筛选器”,如下图所示表明2003已成功为IIS加载了PHP支持。


************************************************************************
以上为XP和2003
IIS安装PHP支持的差别处,其他地方完全相同!
************************************************************************
5、在IIS
目录下新建一index.php文件,写上如下代码:

打开index.php网页,能正常打开(如下图所示)证明已经成功配置了PHP环境。


至此PHP环境在Windows XP&2003中顺利安装完成!
MySQL 4.1.12安装篇
[相关软件下载:]
Mysql 4.1.12-win32 -
For Windows ( Mysql 4.1.12-win32.exe ) -- 数据库服务
下载地址:

http://cdgwbn.downloadsky.com:8080/down/mysql-4.1.12-win32.zip

Connector/ODBC
- MySQL ODBC driver ( MyODBC-3.51.11-1-win.exe ) -- 数据源
下载地址:

http://down.21sun.net/webtools/MyODBC-3.51.11-1-win.exe

MySQL
Control Center ( mysqlcc-0.9.4-win32.zip ) -- 管理工具
下载地址:

http://down.21sun.net/webtools/mysqlcc-0.9.4-win32.zip

以上下载地址若失效,请另寻它处下载!
[升级系统ODBC
- MySQL ODBC driver ]
首先打开你的控制面版,找到 [添加删除程序] 把旧的MySQL ODBC driver
删除
然后安装MyODBC-3.51.11-1-win.exe
[删除你电脑里的旧版MYSQL服务]
如果你是全新安装,就可以跳过这一步啦
如果你以前安装过旧版的,那就要看看如何完整从你的系统内删除Mysql
在你从电脑里卸载旧的MYSQL数据库服务时
首先先在WINDOWS服务里停掉MYSQL的服务
再到控制面板里的增加删除程序内进行删除
但是你并不能完整的把MYSQL服务删除
那么就要在注册表里清除你的MYSQL服务
有几个地方:(应该有两项,不记得啦,大家查查吧)
1、HKEY_LOCAL_MACHINE\SYSTEM\ControlSet001\Services\Eventlog\Application\MySQL
目录删除
2、HKEY_LOCAL_MACHINE\SYSTEM\ControlSet002\Services\Eventlog\Application\MySQL
目录删除
3、HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Eventlog\Application\MySQL
目录删除如下图所示:


清除完以后,还要记得把 C:\WINDOWS\my.ini
这个文件删除哦然后重新启动计算机再到你计算机服务里看一下是不是MYSQL服务已经不见啦,好了可以进行安装新版的MYSQL啦!
[ 开始安装MYSQL 4.1.12 ]
1、运行MYSQL Server 4.1
安装包如下图:


2、点击(Change..)选择更改安装路径,建议不要装在C盘,我只是在机器上测试,所以就没有更改!


3、更改完路径后点击Next,接着点Install开始安装
4、我们看到安装进度!


5、选择Skip Sign-Up 项,点击Next>继续安装!


6、到这里我们安装已经完成,选上Configure the MySQL Server now后点击 Finish
进入Mysql的配置工作:


7、进入Mysql的配置界面!


8、选择Detailed Configuration 选择后,点击Next>进行下一步!


9、选择Server Machine 然后点击Next>继续!


10、选择Multifunctional Database 然后点击Next 继续!


11、这一步我还是以默认(让你选择数据库文件的存放地点)建意不要放在C盘!


12、选上Online Transaction Processing(OLTP)然后点击Next>继续!


13、如下图,继续Next>


14、选择语言的支持!用默认为Standard Character Set即可!


15、记得要选上Include Bin Directory In Windows Path
选项,继续Next>


16、如下图,输入密码,继续Next>


17、点击Execute 开始完成配置并启动MYSQL服务!


18、点击Finish 完成你的Mysql的全部安装!


安装 MySQL Control Center 来管理Mysql数据服务
首先安装
mysqlcc-0.9.4-win32.zip
其次是用 MySQL Control Center 来配置和管理Mysql
数据库!
1、第一次运行MySQL Control Center为英文版,并弹出如下窗口:


在Name中填上数据库名如:mysql,数据库名可自行更改,在Password中填刚才安装MySQL所设置的密码,然后点Add!然后在mysql上右击选择如下左图,连接成功后如下右图所示:




2、由于MySQL Control
Center现在是英文界面,下面我们就来设置语言包,找到Options点击里面的General Ctrl+0 这个选项,如下图:


3、在打开的General中Language项,选Simplified
Chinese选项,然后Apply应用!然后关闭MySQL Control Center, 再打开MySQL Control
Center即为熟悉的中文界面啦!


4、新建数据库,在数据库右击新数据库:


5、输入数据库名称:


6、按OK完成新建数据库,双击sql数据库进行连接,连接后如下图:


7、下面我们新增加一个root管理员,有人会问现在不是已经有一个啦吗,
为什么还要再增加一个呀,下面我就说说为何需要增加一个Mysql Admin
User ,
在以往的mysql 4.0版本里,默认安装即会有四个Mysql Admin User
的帐号,分别是!
----------------------------------------------------------
root@%
root@localhost
@%
@%localhost
-----------------------------------------------------------
又有的人会问,那这么多帐号都有什么作用呀,下面我们来讲一下关于MYSQL的帐号原则,
我们看到root@%和root@localhost这两个帐号对比是不是不同,当然用法也不同,当我们在设置Mysql联接时,会需要到这两项就是(Server)(User);Server就是你的Mysql服务器的IP地址
或域名或者是机器名,User
就是连接SQL数据库的帐号,如下表所示
-----------------------------------------------------------
帐号@服务器地址
-----------------------------------------------------------
root@%root@localhost
-----------------------------------------------------------
关健在于服务器地址,这个地方,@%
代表任意地址都可以连接,@localhost代表只能在本地用localhost做为地址连接,在Mysql 4.1.12版本安装时只有一个
root@localhost这个帐号,可以说Mysql
4.1.12版本MYSQL针对安全性上有所增强啦,假如我的MYSQL服务器,安装在192.168.0.100
这台机器上,如果我只有root@localhost这个帐号,我就只能在 192.168.0.100 地址用
localhost标示才能连接上MYSQL数据库;如果我里面有一个root@%的帐号,我可以用 127.0.0.1\192.168.0.100
都可以连接上数据库,所以有时我们需要其它机器连接时,就需要我们自己建立一个帐号啦!在用户管理上右击,如下图,建立一个新的Mysql Admin
User帐号:


8、输下需要建立的帐号信息,然后添加!


9、看到了吗,建立一个新的MYSQL ADMIN
USER帐号就完成了,当然你也可以建立其它名称的,
也可以针对不同的帐号进行附加不同的权限,这个需要你以后体会啦!


这只是对MySQL的基本设置,要设置更安全可靠的MySQL,只能靠大家自己去查相关资料了。

[ 本帖最后由 kt600 于 2005-12-31 23:58 编辑 ]
 楼主| kt600 发表于 2005-12-31 10:02:14 | 显示全部楼层
MySQL的ODBC接口实现是通过安装MyODBC驱动,这个驱动程序是跨平台的。如果在Linux等unix体系操作系统下使用,需要先安装iodbc这些第三方ODBC标准支援平台。
简单的ASP示例代码:
上边这段代码是采用MyODBC开发版3.51连接的示例,使用开发版是因为一些新的特性和稳定性2.x正式版所不具备的。前几天看了篇微软安全专家所撰写的如何编写安全程序的教程。上边提到如果按照上边示例的方法一旦ASP文件的代码被骇客看到,那么数据库可能不保,然后引发一连串的问题,甚至被夺得管理权限。文章中顺便提到了解决方法,是通过编写com组件,然后由ASP调用组件的方法连接数据库。这么做的好处是提高了安全性,但是问题是有能力这么做的人毕竟是少数。那么我的折衷方案是定义数据源。将库、用户、密码以及设置这些连接信息统统在数据源中定义,从很大程度简单化了实现的难度,而且也起到增强安全性的作用。当然,为了保证数据源可以在实际运作环境中被访问到,一定要定义为“系统数据源”,开发时定义为“用户数据源”或者“系统数据源”我倒觉得无伤大雅。
使用数据源的ASP示例代码
 
 
一、应该优化什么?
硬件
操作系统/软件库
SQL服务器(设置和查询)
应用编程接口(API)
应用程序
二、优化硬件
如果你需要庞大的数据库表(>2G),你应该考虑使用64位的硬件结构,像Alpha、Sparc或即将推出的IA64。因为MySQL内部使用大量64位的整数,64位的CPU将提供更好的性能。
对大数据库,优化的次序一般是RAM、快速硬盘、CPU能力。
更多的内存通过将最常用的键码页面存放在内存中可以加速键码的更新。
如果不使用事务安全(transaction-safe)的表或有大表并且想避免长文件检查,一台UPS就能够在电源故障时让系统安全关闭。
对于数据库存放在一个专用服务器的系统,应该考虑1G的以太网。延迟与吞吐量同样重要。
三、优化磁盘
为系统、程序和临时文件配备一个专用磁盘,如果确是进行很多修改工作,将更新日志和事务日志放在专用磁盘上。
低寻道时间对数据库磁盘非常重要。对于大表,你可以估计你将需要log(行数)/log(索引块长度/3*2/(键码长度 +
数据指针长度))+1次寻到才能找到一行。对于有500000行的表,索引Mediun int类型的列,需要log(500000) /
log(1024/3*2/(3 +
2))+1=4次寻道。上述索引需要500000*7*3/2=5.2M的空间。实际上,大多数块将被缓存,所以大概只需要1-2次寻道。
然而对于写入(如上),你将需要4次寻道请求来找到在哪里存放新键码,而且一般要2次寻道来更新索引并写入一行。
对于非常大的数据库,你的应用将受到磁盘寻道速度的限制,随着数据量的增加呈N log N数据级递增。
将数据库和表分在不同的磁盘上。在MySQL中,你可以为此而使用符号链接。
条列磁盘(RAID 0)将提高读和写的吞吐量。
带镜像的条列(RAID 0+1)将更安全并提高读取的吞吐量。写入的吞吐量将有所降低。
不要对临时文件或可以很容易地重建的数据所在的磁盘使用镜像或RAID(除了RAID 0)。
在Linux上,在引导时对磁盘使用命令hdparm
-m16 -d1以启用同时读写多个扇区和DMA功能。这可以将响应时间提高5~50%。
在Linux上,用async
(默认)和noatime挂载磁盘(mount)。
对于某些特定应用,可以对某些特定表使用内存磁盘,但通常不需要。
四、优化操作系统
不要交换区。如果内存不足,增加更多的内存或配置你的系统使用较少内存。
不要使用NFS磁盘(会有NFS锁定的问题)。
增加系统和MySQL服务器的打开文件数量。(在safe_mysqld脚本中加入ulimit -n
#)。
增加系统的进程和线程数量。
如果你有相对较少的大表,告诉文件系统不要将文件打碎在不同的磁道上(Solaris)。
使用支持大文件的文件系统(Solaris)。
选择使用哪种文件系统。在Linux上的Reiserfs对于打开、读写都非常快。文件检查只需几秒种。
五、选择应用编程接口
PERL
可在不同的操作系统和数据库之间移植。
适宜快速原型。
应该使用DBI/DBD接口。
PHP
比PERL易学。
使用比PERL少的资源。
通过升级到PHP4可以获得更快的速度。
C
MySQL的原生接口。
较快并赋予更多的控制。
低层,所以必须付出更多。
C++
较高层次,给你更多的时间来编写应用。
仍在开发中
ODBC
运行在Windows和Unix上。
几乎可在不同的SQL服务器间移植。
较慢。MyODBC只是简单的直通驱动程序,比用原生接口慢19%。
有很多方法做同样的事。很难像很多ODBC驱动程序那样运行,在不同的领域还有不同的错误。
问题成堆。Microsoft偶尔还会改变接口。
不明朗的未来。(Microsoft更推崇OLE而非ODBC)
JDBC
理论上可在不同的操作系统何时据库间移植。
可以运行在web客户端。
Python和其他
可能不错,可我们不用它们。
六、优化应用
应该集中精力解决问题。
在编写应用时,应该决定什么是最重要的:
速度
操作系统间的可移植性
SQL服务器间的可移植性
使用持续的连接。.
缓存应用中的数据以减少SQL服务器的负载。
不要查询应用中不需要的列。
不要使用SELECT * FROM table_name...
测试应用的所有部分,但将大部分精力放在在可能最坏的合理的负载下的测试整体应用。通过以一种模块化的方式进行,你应该能用一个快速“哑模块”替代找到的瓶颈,然后很容易地标出下一个瓶颈。
如果在一个批处理中进行大量修改,使用LOCK TABLES。例如将多个UPDATES或DELETES集中在一起。
七、应该使用可移植的应用
Perl DBI/DBD
ODBC
JDBC
Python(或其他有普遍SQL接口的语言)
你应该只使用存在于所有目的SQL服务器中或可以很容易地用其他构造模拟的SQL构造。

http://www.mysql.com上的crash-me页可以帮助你。/


为操作系统/SQL服务器编写包装程序来提供缺少的功能。
八、如果你需要更快的速度,你应该:
找出瓶颈(CPU、磁盘、内存、SQL服务器、操作系统、API或应用)并集中全力解决。
使用给予你更快速度/灵活性的扩展。
逐渐了解SQL服务器以便能为你的问题使用可能最快的SQL构造并避免瓶颈。
优化表布局和查询。
使用复制以获得更快的选择(select)速度。
如果你有一个慢速的网络连接数据库,使用压缩客户/服务器协议。
不要害怕时应用的第一个版本不能完美地移植,在你解决问题时,你总是可以在以后优化它。
九、优化MySQL
挑选编译器和编译选项。
位你的系统寻找最好的启动选项。
通读MySQL参考手册并阅读Paul
DuBios的《MySQL》一书。(已有中文版-译注)
多用EXPLAIN SELECT、SHOW VARIABLES、SHOW STATUS和SHOW
PROCESSLIST。
了解查询优化器的工作原理。
优化表的格式。
维护你的表(myisamchk、CHECK TABLE、
OPTIMIZE TABLE)
使用MySQL的扩展功能以让一切快速完成。
如果你注意到了你将在很多场合需要某些函数,编写MySQL
UDF函数。
不要使用表级或列级的GRANT,除非你确实需要。
购买MySQL技术支持以帮助你解决问题


十、编译和安装MySQL
通过位你的系统挑选可能最好的编译器,你通常可以获得10-30%的性能提高。
在Linux/Intel平台上,用pgcc(gcc的奔腾芯片优化版)编译MySQL。然而,二进制代码将只能运行在Intel奔腾CPU上。
对于一种特定的平台,使用MySQL参考手册上推荐的优化选项。
一般地,对特定CPU的原生编译器(如Sparc的Sun
Workshop)应该比gcc提供更好的性能,但不总是这样。
用你将使用的字符集编译MySQL。
静态编译生成mysqld的执行文件(用--with-mysqld-ldflags=all-static)并用strip
sql/mysqld整理最终的执行文件。
注意,既然MySQL不使用C++扩展,不带扩展支持编译MySQL将赢得巨大的性能提高。
如果操作系统支持原生线程,使用原生线程(而不用mit-pthreads)。
用MySQL基准测试来测试最终的二进制代码。
十一、维护
如果可能,偶尔运行一下OPTIMIZE table,这对大量更新的变长行非常重要。
偶尔用myisamchk -a更新一下表中的键码分布统计。记住在做之前关掉MySQL。
如果有碎片文件,可能值得将所有文件复制到另一个磁盘上,清除原来的磁盘并拷回文件。
如果遇到问题,用myisamchk或CHECK
table检查表。
用mysqladmin -i10 precesslist extended-status监控MySQL的状态。
用MySQL
GUI客户程序,你可以在不同的窗口内监控进程列表和状态。
使用mysqladmin debug获得有关锁定和性能的信息。
十二、优化SQL
扬SQL之长,其它事情交由应用去做。使用SQL服务器来做:
找出基于WHERE子句的行。
JOIN表
GROUP BY
ORDER BY
DISTINCT
不要使用SQL来做:
检验数据(如日期)
成为一只计算器
技巧:
明智地使用键码。
键码适合搜索,但不适合索引列的插入/更新。
保持数据为数据库第三范式,但不要担心冗余信息或这如果你需要更快的速度,创建总结表。
在大表上不做GROUP BY,相反创建大表的总结表并查询它。
UPDATE table set count=count+1 where
key_column=constant非常快。
对于大表,或许最好偶尔生成总结表而不是一直保持总结表。
充分利用INSERT的默认值。
十三、不同SQL服务器的速度差别(以秒计)
通过键码读取2000000行: NT Linux
mysql
367 249
mysql_odbc 464  
db2_odbc 1206  
informix_odbc 121126  
ms-sql_odbc 1634  
oracle_odbc 20800  
solid_odbc 877  
sybase_odbc 17614  
 
插入350768行: NT Linux
mysql 381 206
mysql_odbc 619  
db2_odbc 3460  
informix_odbc 2692  
ms-sql_odbc 4012  
oracle_odbc 11291  
solid_odbc 1801  
sybase_odbc 4802  
在上述测试中,MySQL配置8M高速缓存运行,其他数据库以默认安装运行。
十四、重要的MySQL启动选项
back_log 如果需要大量新连接,修改它。
thread_cache_size 如果需要大量新连接,修改它。
key_buffer_size 索引页池,可以设成很大。
bdb_cache_size BDB表使用的记录和键吗高速缓存。
table_cache 如果有很多的表和并发连接,修改它。
delay_key_write 如果需要缓存所有键码写入,设置它。
log_slow_queries 找出需花大量时间的查询。
max_heap_table_size 用于GROUP BY
sort_buffer 用于ORDER BY和GROUP BY
myisam_sort_buffer_size 用于REPAIR TABLE
join_buffer_size 在进行无键吗的联结时使用。
十五、优化表
MySQL拥有一套丰富的类型。你应该对每一列尝试使用最有效的类型。
ANALYSE过程可以帮助你找到表的最优类型:SELECT * FROM table_name PROCEDURE ANALYSE()。
对于不保存NULL值的列使用NOT NULL,这对你想索引的列尤其重要。
将ISAM类型的表改为MyISAM。
如果可能,用固定的表格式创建表。
不要索引你不想用的东西。
利用MySQL能按一个索引的前缀进行查询的事实。如果你有索引INDEX(a,b),你不需要在a上的索引。
不在长CHAR/VARCHAR列上创建索引,而只索引列的一个前缀以节省存储空间。CREATE TABLE table_name (hostname
CHAR(255) not null, index(hostname(10)))
对每个表使用最有效的表格式。
在不同表中保存相同信息的列应该有同样的定义并具有相同的列名。
十六、MySQL如何次存储数据
数据库以目录存储。
表以文件存储。
列以变长或定长格式存储在文件中。对BDB表,数据以页面形式存储。
支持基于内存的表。
数据库和表可在不同的磁盘上用符号连接起来。
在Windows上,MySQL支持用.sym文件内部符号连接数据库。
十七、MySQL表类型
HEAP表:固定行长的表,只存储在内存中并用HASH索引进行索引。
ISAM表:MySQL 3.22中的早期B-tree表格式。
MyIASM:IASM表的新版本,有如下扩展:
二进制层次的可移植性。
NULL列索引。
对变长行比ISAM表有更少的碎片。
支持大文件。
更好的索引压缩。
更好的键吗统计分布。
更好和更快的auto_increment处理。
来自Sleepcat的Berkeley DB(BDB)表:事务安全(有BEGIN
WORK/COMMIT|ROLLBACK)。
十八、MySQL行类型(专指IASM/MyIASM表)
如果所有列是定长格式(没有VARCHAR、BLOB或TEXT),MySQL将以定长表格式创建表,否则表以动态长度格式创建。
定长格式比动态长度格式快很多并更安全。
动态长度行格式一般占用较少的存储空间,但如果表频繁更新,会产生碎片。
在某些情况下,不值得将所有VARCHAR、BLOB和TEXT列转移到另一个表中,只是获得主表上的更快速度。
利用myiasmchk(对ISAM,pack_iasm),可以创建只读压缩表,这使磁盘使用率最小,但使用慢速磁盘时,这非常不错。压缩表充分地利用将不再更新的日志表
十九、MySQL高速缓存(所有线程共享,一次性分配)
键码缓存:key_buffer_size,默认8M。
表缓存:table_cache,默认64。
线程缓存:thread_cache_size,默认0。
主机名缓存:可在编译时修改,默认128。
内存映射表:目前仅用于压缩表。
注意:MySQL没有行高速缓存,而让操作系统处理。
二十、MySQL缓存区变量(非共享,按需分配)
sort_buffer:ORDER BY/GROUP BY
record_buffer:扫描表。
join_buffer_size:无键联结
myisam_sort_buffer_size:REPAIR TABLE
net_buffer_length:对于读SQL语句并缓存结果。
tmp_table_size:临时结果的HEAP表大小。
二十一、MySQL表高速缓存工作原理
每个MyISAM表的打开实例(instance)使用一个索引文件和一个数据文件。如果表被两个线程使用或在同一条查询中使用两次,MyIASM将共享索引文件而是打开数据文件的另一个实例。
如果所有在高速缓存中的表都在使用,缓存将临时增加到比表缓存尺寸大些。如果是这样,下一个被释放的表将被关闭。
你可以通过检查mysqld的Opened_tables变量以检查表缓存是否太小。如果该值太高,你应该增大表高速缓存。
二十二、MySQL扩展/优化-提供更快的速度
使用优化的表类型(HEAP、MyIASM或BDB表)。
对数据使用优化的列。
如果可能使用定长行。
使用不同的锁定类型(SELECT HIGH_PRIORITY,INSERT
LOW_PRIORITY)
Auto_increment
REPLACE (REPLACE INTO table_name VALUES
(...))
INSERT DELAYED
LOAD DATA INFILE / LOAD_FILE()
使用多行INSERT一次插入多行。
SELECT INTO OUTFILE
LEFT JOIN, STRAIGHT JOIN
LEFT JOIN ,结合IS NULL
ORDER BY可在某些情况下使用键码。
如果只查询在一个索引中的列,将只使用索引树解决查询。
联结一般比子查询快(对大多数SQL服务器亦如此)。
LIMIT
SELECT * from table1 WHERE a > 10
LIMIT 10,20
DELETE * from table1 WHERE a > 10 LIMIT 10
foo IN (常数列表)
高度优化。
GET_LOCK()/RELEASE_LOCK()
LOCK TABLES
INSERT和SELECT可同时运行。
UDF函数可装载进一个正在运行的服务器。
压缩只读表。
CREATE TEMPORARY TABLE
CREATE TABLE
.. SELECT
带RAID选项的MyIASM表将文件分割成很多文件以突破某些文件系统的2G限制。
Delay_keys
复制功能
二十二、MySQL何时使用索引
对一个键码使用>, >=, =,  5;
SELECT * FROM table_name WHERE key_part1 IS NULL;
当使用不以通配符开始的LIKE
SELECT * FROM table_name WHERE key_part1 LIKE jani%
在进行联结时从另一个表中提取行时
SELECT * from t1,t2 where t1.col=t2.key_part
找出指定索引的MAX()或MIN()值
SELECT MIN(key_part2),MAX(key_part2) FROM
table_name where key_part1=10
一个键码的前缀使用ORDER BY或GROUP BY
SELECT *
FROM foo ORDER BY key_part1,key_part2,key_part3
在所有用在查询中的列是键码的一部分时间
SELECT key_part3 FROM table_name WHERE key_part1=1
二十三、MySQL何时不使用索引
如果MySQL能估计出它将可能比扫描整张表还要快时,则不使用索引。例如如果key_part1均匀分布在1和100之间,下列查询中使用索引就不是很好:
SELECT * FROM table_name where key_part1 > 1 and key_part1  explain select t3.DateOfAction, t1.TransactionID
->
from t1 join t2 join t3
-> where t2.ID = t1.TransactionID and t3.ID =
t2.GroupID
-> order by t3.DateOfAction, t1.TransactionID;
+-----+----+-------------+---+-------+----+--------------------
|table|type|possible_keys|key|key_len|ref | rows|Extra |
+-----+----+-------------+---+-------+----+-----+--------------+
| t1 |
ALL| NULL|NULL|NULL |NULL| 11 |Using mporary;Using filesort |
| t2 | ref |
ID | ID | 4 | t1.TransactionID | 13 | |
| t3 | eq_ref | PRIMARY | PRIMARY |
4 | t2.GroupID | 1 | |
+-------+--------+---------------+---------+---------+-----------
ALL和范围类型提示一个潜在的问题。
 
二十五、学会使用SHOW PROCESSLIST
使用SHOW processlist来发现正在做什么:
+----+-------+-----------+----+---------+------+--------------+-------------------------------------+
| Id | User | Host | db | Command | Time | State | Info |
+----+-------+-----------+----+---------+------+--------------+-------------------------------------+
| 6 | monty | localhost | bp | Query | 15 | Sending data | select * from
station,station as s1 |
| 8 | monty | localhost | | Query | 0 | | show
processlist |
+----+-------+-----------+----+---------+------+--------------+-------------------------------------+
在mysql或mysqladmin中用KILL来杀死溜掉的线程。
二十六、如何知晓MySQL解决一条查询
运行项列命令并试图弄明白其输出:
SHOW VARIABLES;
SHOW COLUMNS FROM ...\G
EXPLAIN SELECT ...\G
FLUSH STATUS;
SELECT ...;
SHOW STATUS;
二十七、MySQL非常不错
日志
在进行很多连接时,连接非常快。
同时使用SELECT和INSERT的场合。
在不把更新与耗时太长的选择结合时。
在大多数选择/更新使用唯一键码时。
在使用没有长时间冲突锁定的多个表时。
在用大表时(MySQL使用一个非常紧凑的表格式)。
二十八、MySQL应避免的事情
用删掉的行更新或插入表,结合要耗时长的SELECT。
在能放在WHERE子句中的列上用HAVING。
不使用键码或键码不够唯一而进行JOIN。
在不同列类型的列上JOIN。
在不使用=匹配整个键码时使用HEAP表。
在MySQL监控程序中忘记在UPDATE或DELETE中使用一条WHERE子句。如果想这样做,使用mysql客户程序的--i-am-a-dummy选项。
二十九、MySQL各种锁定
内部表锁定
LOCK TABLES(所有表类型适用)
GET
LOCK()/RELEASE LOCK()
页面锁定(对BDB表)
ALTER TABLE也在BDB表上进行表锁定
LOCK
TABLES允许一个表有多个读者和一个写者。
一般WHERE锁定具有比READ锁定高的优先级以避免让写入方干等。对于不重要的写入方,可以使用LOW_PRIORITY关键字让锁定处理器优选读取方。
UPDATE LOW_PRIORITY SET value=10 WHERE id=10;
三十、给MySQL更多信息以更好地解决问题的技巧
注意你总能去掉(加注释)MySQL功能以使查询可移植:
SELECT /*! SQL_BUFFER_RESULTS */ ...
SELECT SQL_BUFFER_RESULTS ...
将强制MySQL生成一个临时结果集。只要所有临时结果集生成后,所有表上的锁定均被释放。这能在遇到表锁定问题时或要花很长时间将结果传给客户端时有所帮助。
SELECT SQL_SMALL_RESULT ... GROUP BY ...
告诉优化器结果集将只包含很少的行。
SELECT
SQL_BIG_RESULT ... GROUP BY ...
告诉优化器结果集将包含很多行。
SELECT STRAIGHT_JOIN ...
强制优化器以出现在FROM子句中的次序联结表。
SELECT ... FROM table_name [USE INDEX
(index_list) | IGNORE INDEX (index_list)] table_name2
强制MySQL使用/忽略列出的索引。
三十一、事务的例子
MyIASM表如何进行事务处理:
mysql> LOCK TABLES
trans READ, customer WRITE;
mysql> select sum(value) from trans where
customer_id=some_id;
mysql> update customer set
total_value=sum_from_previous_statement
where customer_id=some_id;
mysql> UNLOCK TABLES;
BDB表如何进行事务:
mysql> BEGIN WORK;
mysql> select sum(value) from trans where customer_id=some_id;
mysql> update customer set total_value=sum_from_previous_statement
where customer_id=some_id;
mysql> COMMIT;
注意你可以通过下列语句回避事务:
UPDATE customer SET value=value+new_value WHERE customer_id=some_id;
三十二、使用REPLACE的例子
REPLACE的功能极像INSERT,除了如果一条老记录在一个唯一索引上具有与新纪录相同的值,那么老记录在新纪录插入前则被删除。不使用
SELECT 1 FROM t1 WHERE key=#
IF found-row
LOCK TABLES t1
DELETE FROM t1 WHERE key1=#
INSERT INTO t1 VALUES (...)
UNLOCK
TABLES t1;
ENDIF
而用
REPLACE INTO t1 VALUES (...)
三十三、一般技巧
使用短主键。联结表时使用数字而非字符串。
当使用多部分键码时,第一部分应该时最常用的部分。
有疑问时,首先使用更多重复的列以获得更好地键码压缩。
如果在同一台机器上运行MySQL客户和服务器,那么在连接MySQL时则使用套接字而不是TCP/IP(这可以提高性能7.5%)。可在连接MySQL服务器时不指定主机名或主机名为localhost来做到。
如果可能,使用--skip-locking(在某些OS上为默认),这将关闭外部锁定并将提高性能。
使用应用层哈希值而非长键码:
SELECT * FROM table_name WHERE hash=MD5(concat(col1,col2)) AND
col_1=constant AND col_2=constant
在文件中保存需要以文件形式访问的BLOB,在数据库中只保存文件名。
删除所有行比删除一大部分行要快。
如果SQL不够快,研究一下访问数据的较底层接口。
三十四、使用MySQL
3.23的好处
MyISAM:可移植的大表格式
HEAP:内存中的表
Berkeley DB:支持事务的表。
众多提高的限制
动态字符集
更多的STATUS变量
CHECK和REPAIR表
更快的GROUP BY和DISTINCT
LEFT JOIN ... IF NULL的优化
CREATE TABLE ... SELECT
CREATE TEMPORARY
table_name (...)
临时HEAP表到MyISAM表的自动转换
复制
mysqlhotcopy脚本
三十五、正在积极开发的重要功能
改进事务处理
失败安全的复制
正文搜索
多个表的删除(之后完成多个表的更新)
更好的键码缓存
原子RENAME (RENAME TABLE foo as foo_old,
foo_new as foo)
查询高速缓存
MERGE TABLES
一个更好的GUI客户程序
回复

使用道具 举报

 楼主| kt600 发表于 2005-12-31 10:22:09 | 显示全部楼层
汗。。。。。。。费了半天劲怎么没人回应啊
回复

使用道具 举报

baoanzhen 发表于 2005-12-31 11:07:35 | 显示全部楼层
呵呵
不错 不错
学习了
我用的php是php-5.1.1
mysql版本是mysql-5.0.17
phpMyAdmin-2.7.0
ZendOptimizer-2.6.0
在2003系统下安装Discuz!_4.0,运行了一个多月了一切正常
回复

使用道具 举报

楼上 发表于 2005-12-31 11:27:39 | 显示全部楼层
这么好的东东,楼主幸苦了!我现在用的是PHP4
回复

使用道具 举报

qq12300 发表于 2005-12-31 11:43:44 | 显示全部楼层
很好的东西不要错过哦...顶上去大家一起来学习,我多学到了一点东西
回复

使用道具 举报

 楼主| kt600 发表于 2005-12-31 11:52:25 | 显示全部楼层
感谢楼上的支持
回复

使用道具 举报

南芝恋 发表于 2006-1-8 08:02:55 | 显示全部楼层
顶哦
很不错~
回复

使用道具 举报

南芝恋 发表于 2006-1-8 11:27:39 | 显示全部楼层
mysql安装的最后一步四步里。。。第三个 start service 前边打了个大红叉。。。。。。。。。
回复

使用道具 举报

AIRZHONG 发表于 2006-1-8 18:07:45 | 显示全部楼层
老大!精华贴呀!强力顶!
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|Discuz! 官方站 ( 皖ICP备16010102号 )star

GMT+8, 2024-9-29 19:18 , Processed in 0.411588 second(s), 17 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2023, Tencent Cloud.

快速回复 返回顶部 返回列表