当前位置:七道奇文章资讯数据防范MSSQL防范
日期:2011-05-02 15:21:00  来源:本站整理

<b>MySQL中文参考手册5(安装MySQL下)</b>[MSSQL防范]

赞助商链接



  本文“<b>MySQL中文参考手册5(安装MySQL下)</b>[MSSQL防范]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:

MySQL中文参考手册5(安装MySQL下)ww w.iTbulo.coUkonL

转载 译者:晏子

〖返回〗〖转发〗

译者:晏子 (clyan@sohu.com)主页:http://linuxdb.yeah.net

4.12 Win32 注意事项
这节描写在Win32上安装和利用MySQL,这也在MySQL Win32分发所带的"readme"文件中描写. 

4.12.1 在Win32上安装MySQL
假如你没有一个注册的MySQL版本,你应当首先下载同享软件版本,从: 

MySQL 3.21.29 

假如你预备从一些其他程序衔接MySQL,你也大概需求MyODBC驱动程序.你可在MySQL下载页找到. 

安装任何一个分发,在某个空目录解紧缩它并且运行Setup.exe程序. 

缺省地,MySQL-Win32被配置安装在"C:mysql".假如你想要在别的地方安装MySQL,在"C:mysql"安装它,然后将安装移到你想要的地方.假如你真的移走MySQL,你必须通过供应选项给mysqld奉告mysqld那边的全部一切,利用C:mysqlinmysqld --help显示全部的选项目!比方,假如你移动MySQL分发到"D:programsmysql",你必须用D:programsmysqlinmysqld --basedir D:programsmysql来启动mysqld.

用登记的MySQL版本,你也可以成立一个"C:my.cnf"文件来保存用于MySQL服务器的任何缺省选项.拷贝文件"mysqlmy-example.cnf"到"C:my.cnf"并且编辑它来实用于你的安装.注意你应当用"/"而不是""指定全部的途径.假如你利用"",你需求指定两次(""),因为在MySQL中""是转义字符,见4.15.4 选项文件. 

4.12.2 在Win95/Win98上启动MySQL
MySQL利用 TCP/IP 把一个客户衔接到一个服务器.(这将答应在你的网络上任何机械衔接你的MySQL服务器).因此,你必须在启动MySQL前在你的机械上安装TCP/IP,你可以在你的Windows CDROM上找到TCP/IP . 

注意:假如你正在利用一个旧的Win95版本(比方OSR2),很有大概你有一个老的Winsock包!MySQL需求Winsock 2!你可从微软得到最新的Winsock.Win98有新的Winsock 2库作为缺省,这样上述不实用于Win98. 

你能利用2个差别的MySQL服务器: 

mysqld  用完好调试和自动存储器分配查抄编译 
mysqld-opt  对Pentium 处理器优化.  

上面两个应当在任何 > = i386的Intel处理器上工作  . 

为了启动mysqld服务器,你应当启动一个MSDos窗口并键入: 

C:mysqlinmysqld
这将在一个没有窗口的后台启动mysqld. 

你可以这样杀死MySQL服务器,履行: 

C:mysqlinmysqladmin -u root shutdown
注意Win95/Win98不支持命名管道的成立.在Win95/Win98上,你只能利用命名管道衔接运行在一个NT服务器上的远程MySQL. 

4.12.3 在NT上启动MySQL
Win95/Win98小节也实用于在NT上的MySQL,有下列差别: 

为了是MySQL用TCP/IP工作,你必须安装服务包3(service pack 3)(或更新)! 

关于NT,服务器名字是mysqld-nt.普通你应当在 NT 上安装MySQL作为一种服务: 

C:mysqlinmysqld-nt --install
(你可以在 NT 上利用mysqld或mysqld-opt服务器,但是那些不能作为一种服务启动或利用命名管道.)

你可以用下列号令启动和终止MySQL服务: 

NET START mysql
NET STOP mysql

注意在这种情形下,你不能对mysqld-nt利用任何其他选项! 

假如你需求用任何选项启动mysqld-nt,你也可以作为在NT上的一个独立程序运行mysqld-nt!假如你在NT上没有选项启动mysqld-nt,mysqld-nt尝试启动自己作为一种有默许选项的服务.假如你终止了mysqld-nt,你必须用NET START mysql启动它.

服务用MySql名字被安装,一旦安装,它必须利用服务掌握管理器(SCM)实用程序启动服务(在掌握面板中找到)或利用NET START MySQL号令.假如需求任何选项,在你启动MySQL服务前必须作为SCM实用程序的"启动参数"指定它们.一旦运行,可以利用mysqladmin或从SCM实用程序或利用号令NET STOP MySQL终止mysqld-nt.假如你利用SCM终止mysqld-nt,SCM有一条关于mysqld shutdown normally奇特的消息,当作为一种服务运行时,mysqld-nt没有掌握台的存取权限,所以没有消息可以瞥见. 

在NT上你可以得到下列服务错误消息: 

Permission Denied (权限回绝) 意味着它不能找到mysqld-nt.exe  
Cannot Register (不能登记) 意味着途径是不精确的 

假如你作为一种服务安装mysqld-nt有问题,尝试用完好的途径启动它: 

C:mysqlinmysqld --install
假如这还不工作,你能通过在注册表改正途径使得mysqld-nt精确启动! 

假如你不想作为一种服务启动mysqld-nt,你可以以下启动它: 

C:mysqlinmysqld-nt --standalone


C:mysqlinmysqld-nt --standalone --debug
最新的版本在"C:mysqld.trace"给你一个调试踪影. 

4.12.4 在 Win32 上运行 MySQL
MySQL在全部Win32平台上支持TCP/IP和NT上命名管道.假如客户安装了TCP/IP,缺省是对NT上的本地衔接利用命名管道而对全部其他情形利用TCP/IP,主机名指定利用哪个协议: 

主机名  协议  
空 (没有) 在NT上,首先尝试命名管道;假如它不工作,利用TCP/IP.在Win95/Win98上,利用TCP/IP.  
.  命名管道 
localhost TCP/IP到当前主机  
主机名 TCP/IP  

通过指定命名管道--pipe选项,你可以强迫一个MySQL客户利用命名管道.利用--socket选项指定管道的名字. 

通过履行下列号令,你能测试MySQL能否正在工作: 

C:mysqlinmysqlshow
C:mysqlinmysqlshow -u root mysql
C:mysqlinmysqladmin version status proc
C:mysqlinmysql test

假如在Win95/Win98上mysqld很慢地答复衔接,大概你的DNS有问题.在这种情形中下,用--skip-name-resolve启动mysqld并且在MySQL受权表中仅利用localhost和IP数字.在你衔接运行在NT上一个mysqld-nt的MySQL服务器时,利用--pipe指定命名管道利用的参数,你也能避开DNS,对大大都MySQL客户是可行的. 

有2个版本的MySQL号令行工具: 

mysql  用原生Win32编译,它供应很有有限的文本编辑本领.  
mysqlc  用Cygnus GNU 编译器和库编译,它供应readline编辑.  

假如你想利用mysqlc.exe,你必须拷贝"C:mysqllibcygwinb19.dll"到"windowssystem"(或近似的地方). 

在Win32上缺省的权限给全部本地用户以全部数据库的完好权限.为了使MySQL更安全,你应当为每个用户设置口令并删除mysql.user中有Host='localhost'和User='的行. 

你也应当为root用户增添一个口令:(下列例子通过删除匿名用户,答应任何人存取"测试"数据库)

C:mysqlinmysql mysql
mysql> DELETE FROM user WHERE Host='localhost' AND User=';
mysql> QUIT
C:mysqlinmysqladmin reload
C:mysqlinmysqladmin -u root password your_password

在你设置了口令今后,假如你想要关掉mysqld服务器, 你能利用这个号令做到: 

mysqladmin -- user=root -- password=your_password  shutdown
假如你正在利用在windows下的MySQL同享软件版本,上面的号令将以 parse error near 'SET OPTION password'的错误而失利,这是因为,这是同享软件版本,它基于MySQL 3.21,没有SET PASSWORD号令. 

对同享软件版本,你能以下设置root用户口令: 

C:mysqlinmysql mysql
mysql> UPDATE user SET password=PASSWORD('your password') WHERE user='root';
mysql> QUIT
C:mysqlinmysqladmin reload

有注册的MySQL版本,你能很简单地用GRANT和REVOKE号令增添新用户和更改权限,见7.26 GRANT和REVOKE句法.对Windows 的同享软件版本,必须利用INSERT、UPDATE和DELETE在mysql数据库中的一个表来管理用户和他们的权限,见6.13 存取回绝(Access denied)的错误缘由. 

4.12.5 用SSH从Win32衔接一个远程MySQL
这是一个关于怎样用SSH 得到一个安全的衔接远程MySQL服务器的注意事项(David Carlson). 


      
  • 在你的windows机械上安装SSH客户 - 我利用了一个来自http://www.doc.ic.ac.uk/~ci2/ssh/的免费SSH客户.其他有效的链接:http://www.npaci.edu/Security/npaci_security_software.html和http://www.npaci.edu/Security/samples/ssh32_windows/index.html. 
      
      
  • 启动SSH.设置主机名字 = 你的MySql服务器名或IP地址,设置userid=你的用户名登录到你的服务器.
      
  • 点击"local forwords".设定local port: 3306, host: localhost, remote port: 3306
      
  • 保存一切,不然下次你将必须再做一遍. 
      
  • 用SSH登录到你的服务器. 
      
  • 启动一些ODBC利用程序(比方Access).
      
  • 创造一个新文件并且用ODBC驱动程序链接到mySQL,就像你普通做的一样,除了对服务器用用户"localhost". 
      


搞定.它对一个直接的因特网衔接工作得很好.我有些问题,SSH与我的Win95网络和Wingate有冲突 - 但是那将是张贴在其他软件公司的用户组的话题! 

4.12.6 MySQL-Win32与Unix MySQL对比
MySQL- Win32目前已经证明了自己很安定.这个版本得MySQL有与对应的Unix版本一样的特点,除了下面: 

Win95和线程 
Win95 为每个线程的成立丧失大约200个字节的内存.因此,假如你举行很多衔接,你不该该在Win95运行mysqld很长时间,因为MySQL的每个衔接都成立一个新线程!WinNT和Win98不能容忍这个bug. 
阻塞式读(blocking read) 
MySQL为每个衔接利用一个阻塞式读取,这意味着: 
一个衔接将不在8个小时后自动被断开,就像MySQL的Unix版本所发生的. 
假如一个衔接"挂起",不杀死MySQL就不大概冲破它. 
mysqladmin kill在一个就寝的衔接上将不工作. 
只要有就寝的衔接,mysqladmin shutdown不能半途中止. 
我们筹划在不久的将来改正它. 

UDF函数 
暂时MySQL-Win32不支持用户可定义函数. 
DROP DATABASE 
你不能丢弃一个正在被某些线程利用的数据库. 
从任务管理器杀死MySQL 
Windows95上,你不能从任务管理器或用shutdown实用程序杀死MySQL.你必须用mysqladmin shutdown关闭它. 
大小写辨别的名字 
文件名在Win32上是忽视大小写的,因此Win32上的MySQL数据库和表的名字也是忽视大小写的.唯一的限制是数据库和表的名字必须在整个一个给定的语句中大小写是一样的,因为它用my_table和MY_TABLE都指向同一个表子,下列查询将不工作: 
SELECT * FROM my_table WHERE MY_TABLE.col=1; 

"  "目录字符 
在Win95上的途径名构成由""字符脱离,它在MySQL中也是转义字符.假如你正在利用LOAD DATA INFILE或SELECT ... INTO OUTFILE,你必须用两个""字符或利用Unix气势的文件名"/"字符: 
LOAD DATA INFILE "C: mpskr.txt" INTO TABLE skr;
SELECT * FROM skr INTO OUTFILE 'C:/tmp/skr.txt';

Can't open named pipe错误 
假如你利用NT上的MySQL-Win32同享软件版本,用最新的mysql客户,你将得到下列错误: 
error 2017: can't open named pipe to host: . pipe...

这是因为NT上MySQL正式版本缺省地利用命名管道.你能通过为新MySQL客户利用--host=localhost选项或成立一个包含下列信息的文件"C:my.cnf"来避免这个错误: 

[client]
host = localhost

Access denied for user错误 
在拜候在同一机械上的一个MySQL服务器时,假如你得到Access denied for user: 'some-user@unknown' to database 'mysql'的错误,这意味着MySQL不能精确注释你的主机名.为了改正它,你应当成立一个文件"windowshosts",有下列信息: 
127.0.0.1  localhost
关于大概想要帮忙我们做好Win32版本的任何人,这里有的一些开放的问题: 

制作一个单用户MYSQL.DLL服务器.这应当包含一个尺度MySQL服务器的一切,除了线程成立外.这将使MySQL在不需求一个真正的客户机/服务器和不需求从其他主机存取服务器的利用程序时更简单利用. 
为MySQL安装增添一些漂亮的"start"和"shutdown"图标. 
为MySQL启动选项成立造一个工具管理注册表条目.注册表条目的度缺已经被编码进mysqld.cc,但是它应当重新编码而越发面向"参数",该工具应当也能更新" my.cnf"文件,假如用户对比喜好利用它而不是注册表. 
当用--install登记mysqld作为一种服务(在 NT 上 )时,假如你也可以在号令行上增添缺省选项,它将更好,目前办理办法是更新"C:my.cnf"文件. 
当你挂起一个运行Win95的膝上计算机时,当膝上计算机被恢复时,mysqld保护程序不承受新衔接.我们不知道这能否 Win95、TCP/IP或MySQL的问题. 
能从任务管理器杀死mysqld将绝对是功德,目前,你必须利用mysqladmin shutdown. 
移植用在 mysql号令行工具的readline到Win32. 
尺度的GUI版本MySQL客户(mysql、mysqlshow、mysqladmin和mysqldump) 将更好. 
假如在"net.c"中的套接字"读"和"写"函数是可中止的,那将更好.这将有大概在Win32上用mysqladmin kill杀死翻开的线程. 
制作有关哪些Windows程序能工作在MySQL-Win32/MyODBC和必须做什么在能让他们工作的文档. 
mysqld老是在"C"处启动而不在缺省地址,我们想让mysqld利用当前地址用于排序次序. 
移植sqlclient到Win32(几近完成)并加入更多的特点! 
把更多的选项加到Mysql Manager. 
在服务器和客户之间改变通讯协议,利用Windows内部通讯而不是套接字和TCP/IP. 
用.DLL实现UDF函数. 
增添宏以利用由Win32供应的更快的对线程安全的增添/削减办法. 
其他Win32特定问题在MySQL-Win32分发的"README"文件中描写. 

4.13 OS/2 注意事项
MySQL利用太多的翻开文件.因此,你应当增添近似下面的东西到你的"CONFIG.SYS"文件: 

SET EMXOPT=-c -n -h1024 
假如你不这样做,你将大概碰到下列错误: 

File 'xxxx' not found (Errcode: 24) 
当OS/2 Warp 3上利用MySQL时,要求FixPack 29或以上.用OS/2 Wrap 4,要求FixPack 4或以上.这是Pthreads库的一个要求.MySQL必须安装在支持长文件名的一个分区上,如HPFS、FAT32等等. 

"INSTALL.CMD"脚本必须从OS/2'自己的"CMD.EXE"运行并且不能工作在替换品如"4OS2.EXE". 

"scripts/mysql-install-db"脚本已经被重新命名了:它目前调用"install.cmd"并且是一个 REXX 手迹,将安装缺省的MySQL安全配置并为MySQL成立WorkPlace Shell 图标. 

动态模块支持通过编译但没有充分测试,动态模块应当利用Pthreads运行时刻库编译. 

gcc -Zdll -Zmt -Zcrtdll=pthrdrtl -I../include -I../regex -I.. 
    -o example udf_example.cc -L../lib -lmysqlclient udf_example.def
mv example.dll example.udf

注意:由于OS/2的限制,UDF模块名字的词干不能超越8个字符.模块被存储在"/mysql2/udf"目录;safe-mysqld.cmd脚本将把这个目录放在BEGINLIBPATH环境变量中.当利用UDF模块时,指定的扩大名被忽视--它被假定为".udf".比方,在 Unix上,同享模块大概被命名为"example.so"并且你可以象这样从它装载函数: 

CREATE FUNCTION metaphon RETURNS STRING SONAME "example.so";

恰是OS/2,模块将被命名为"example.udf",但是你不指定模块扩大名: 
CREATE FUNCTION metaphon RETURNS STRING SONAME "example"; 
4.14 TcX二进制代码
作为一种服务,TcX供应一套MySQL的二进制分发,它在TcX或在客户友好地授与我们拜候他们机械的权限的站点上被编译. 

这些分发用scripts/make_binary_distribution生成并且用下列编译器和选项配置: 

SunOS 4.1.4 2 sun4c with gcc 2.7.2.1 
CC=gcc CXX=gcc CXXFLAGS=-O3 ./configure --prefix=/usr/local/mysql --disable-shared 
SunOS 5.5.1 sun4u with egcs 1.0.3a 
CC=gcc CFLAGS="-O6 -fomit-frame-pointer" CXX=gcc CXXFLAGS="-O6 -fomit-frame-pointer -felide-constructors -fno-exceptions -fno-rtti" ./configure --prefix=/usr/local/mysql --with-low-memory 
SunOS 5.6 sun4u with egcs 2.90.27 
CC=gcc CFLAGS="-O6 -fomit-frame-pointer" CXX=gcc CXXFLAGS="-O6 -fomit-frame-pointer -felide-constructors -fno-exceptions -fno-rtti" ./configure --prefix=/usr/local/mysql --with-low-memory 
SunOS 5.6 i86pc with gcc 2.8.1 
CC=gcc CXX=gcc CXXFLAGS=-O3 ./configure --prefix=/usr/local/mysql --with-low-memory 
Linux 2.0.33 i386 with pgcc 2.90.29 (egcs 1.0.3a) 
CFLAGS="-O6 -mpentium -mstack-align-double -fomit-frame-pointer" CXX=gcc CXXFLAGS="-O6 -mpentium -mstack-align-double -fomit-frame-pointer -felide-constructors -fno-exceptions -fno-rtti" ./configure --prefix=/usr/local/mysql --enable-assembler --with-mysqld-ldflags=-all-static 
SCO 3.2v5.0.4 i386 with gcc 2.7-95q4 
CC=gcc CXX=gcc CXXFLAGS=-O3 ./configure --prefix=/usr/local/mysql 
AIX 2 4 with gcc 2.7.2.2 
CC=gcc CXX=gcc CXXFLAGS=-O3 ./configure --prefix=/usr/local/mysql 
OSF1 V4.0 564 alpha with gcc 2.8.1 
CC=gcc CFLAGS=-O CXX=gcc CXXFLAGS=-O3 ./configure --prefix=/usr/local/mysql --with-low-memory 
Irix 6.3 IP32 with gcc 2.8.0 
CC=gcc CXX=gcc CXXFLAGS=-O3 ./configure --prefix=/usr/local/mysql 
BSDI BSD/OS 3.1 i386 with gcc 2.7.2.1 
CC=gcc CXX=gcc CXXFLAGS=-O ./configure --prefix=/usr/local/mysql 
BSDI BSD/OS 2.1 i386 with gcc 2.7.2 
CC=gcc CXX=gcc CXXFLAGS=-O3 ./configure --prefix=/usr/local/mysql 
任何有比上述配置更优的选项的人老是能把他们寄给开辟者邮件列表中.

MySQL3.22从前的RPM分发是用户奉献的,自3.22开始,一些RPM是TcX 生成的. 

4.15 安装后期的设置和测试
一旦你已经安装了MySQL(从一个二进制代码或源代码分发),你需求初始化受权表,启动服务器并且保证服务器精确运行.你也可以但愿安置服务器在你的系统开机和关机时自动地被启动和终止. 

普通,对从源代码分发的安装,你象这样安装受权表并启动服务器: 

shell> ./scripts/mysql_install_db
shell> cd mysql_installation_Directory
shell> ./bin/safe_mysqld &

对二进制分发,这样做: 

shell> cd mysql_installation_directory
shell> ./bin/mysql_install_db
shell> ./bin/safe_mysqld &

测试在MySQL发行的顶级目录是最简单举行的.对二进制分发,这是你的安装目录(典型地近似"/usr/local/mysql").对源代码分发,这是你的MySQL源代码树的主目录. 

在本小节和今后的小节中,下列号令中,BINDIR是到程序如mysqladmin和safe_mysqld被安装地址的途径.对二进制分发,是在分发内的"bin"目录.对源代码分发,BINDIR大概是"/usr/local/bin",除非在你运行configure时指定了一个" /usr/local"以外的安装目录.EXECDIR是mysqld服务器安装的地址,对二进制分发,这与BINDIR一样.对源代码分发,EXECDIR大概是"/usr/local/libexec". 

测试具体在下面描写: 

假如必要,启动mysqld服务器并且成立初始MySQL受权表,包含决意用户若何被答应衔接服务器的权限.这普通用mysql_install_db脚本做: 
shell> scripts/mysql_install_db

典型地,mysql_install_db仅在你第一次安装MySQL时需求运行,因此,假如你正在进级现有的安装,你可以跳过这一步.(但是,mysql_install_db的利用相当安全,并且将不更新已经存在的任何表,因此假如你是不能必定做什么,你老是可以运行mysql_install_db.) mysql_install_db在mysql数据库里成立6个表(user、db、host、tables_priv、columns_priv和func),初始权限的描写在6.10 设置初始MySQL权限给出.简单地说,这些权限答应MySQL root用户做任何事情,并且答应任何人成立立或利用一个名字以'test'或'test_'开始的数据库.假如你不设置权限表,当你启动服务器时,下列错误将在日记文件呈现: 

mysqld: Can't find file: 'host.frm' 

假如你不是通过明显地履行./bin/safe_mysqld来启动MySQL,上述错误大概也发生在MySQL二进制代码分发!你大概需求作为root运行mysql_install_db,但是,假如你喜好, 假如用户能在数据库目录读并且写文件,你可以作为一个非特权(非--root)用户运行MySQL服务器.作为一个非特权用户运行MySQL的指令在18.8 怎样作为一个普通用户运行 MySQL中给出.假如你有mysql_install_db的问题,见4.15.1 运行mysql_install_db的问题.因为mysql_install_db在MySQL发行中,还有一些其他办法运行它: 

你大概想在运行mysql_install_db前编辑它,改变被安装到受权表中的初始权限.假如你想要在有相同权限的很多机械安装MySQL,这很有效.在这种情形下,你大概应当只需求增添几个额外的INSERT语句到mysql.user和mysql.db表中! 
假如你想要在安装受权表后改变什么,你可以运行mysql_install_db,然后利用mysql -u root mysql作为MySQL root用户衔接受权表,发出SQL语句直接改正受权表. 
在已经成立了受权表后,有大概全部再次成立.假如你已经安装了表但是随后又想要在编辑mysql_install_db今后再成立,你大概想要这样做. 
关于这些选项的更多信息,见6.10 成立初始MySQL权限. 

象这样启动MySQL服务器: 
shell> cd mysql_installation_directory
shell> bin/safe_mysqld &

假如你启动服务器的问题,见4.15.2 启动MySQL服务器的问题. 

利用mysqladmin证实服务器正在运行.下列号令供应简单的测试来查抄服务器启动和衔接的应答: 
shell> BINDIR/mysqladmin version 
shell> BINDIR/mysqladmin variables

从mysqladmin version的输出按照你的平台和MySQL版本略有差别,但是应当近似以下显示: 
shell> BINDIR/mysqladmin version
mysqladmin  Ver 6.3 Distrib 3.22.9-beta, for pc-linux-gnu on i686
TCX Datakonsult AB, by Monty

Server version          3.22.9-beta
Protocol version        10
Connection              Localhost via UNIX socket
TCP port                3306
UNIX socket             /tmp/mysql.sock
Uptime:                 16 sec

Running threads: 1  Questions: 20  Reloads: 2  Open tables: 3

为了感受你能用BINDIR/mysqladmin做其他事情,用--help选项调用它. 

证实你能关掉服务器: 
shell> BINDIR/mysqladmin -u root shutdown

证实你能重启服务器.利用safe_mysqld或直接调用mysqld举行,比方: 
shell> BINDIR/safe_mysqld --log &

假如safe_mysqld失利,从MySQL安装目录尝试运行它(假如你已经不在那边).假如还不工作,见4.15.2 启动MySQL服务器的问题. 

运行一些简单的测试证实服务器正在工作.输出应当近似于下面所显示的: 
shell> BINDIR/mysqlshow
+-----------+
| Databases |
+-----------+
| mysql     |
+-----------+

shell> BINDIR/mysqlshow mysql
Database: mysql
+--------------+
|    Tables    |
+--------------+
| columns_priv |
| db           |
| func         |
| host         |
| tables_priv  |
| user         |
+--------------+

shell> BINDIR/mysql -e "select host,db,user from db" mysql
+------+--------+------+
| host | db     | user |
+------+--------+------+
| %    | test   |      |
| %    | test_% |      |
+------+--------+------+

在"sql-bench"目录(在MySQL安装目录下)下还有基准测试套件,你能用来对比在差别的平台上MySQL表现若何." sql-bench/Results"目录包含对差别的数据库和平台很多运行后果.为了运行全部的测试,履行这些号令: 


shell> cd sql-bench
shell> run-all-tests

假如你没有"sql-bench"目录,你大概在对二进制分发利用一个RPM(源代码分发的RPM包含基准目录).在这种情形下,在你能利用它从前,你必须首先安装基准套件.从MySQL 3.22开始,闻名为"mysql-bench-VERSION-i386.rpm"的基准RPM包,它们包含基准代码和数据.假如你有源代码分发,你也可以在"tests"子目录下运行测试.比方,运行"auto_increment.tst",这样做: 

shell> BINDIR/mysql -vvf test < ./tests/auto_increment.tst

盼望的后果被显示在" ./tests/auto_increment.res"文件中. 

4.15.1 运行mysql_install_db的问题
这节列出在你运行mysql_install_db时,你大概碰见的问题: 

mysql_install_db不安装受权表 
在显示下列消息今后,你可以发现mysql_install_db不能安装受权表并终止: 
starting mysqld daemon with databases from XXXXXX
mysql daemon ended

在这种情形下,你应当很当心地查验日记文件!日记文件应当位于目录"XXXXXX",用错误消息命名,并且应当指出为什么mysqld没启动.假如你不睬解发生的事情,当你利用mysqlbug邮寄一份错误报告时,包含日记文件!见2.3 怎样报告错误或问题. 

已经有一个mysqld保护程序在运行 
在这种情形下,你大概根本没必要运行mysql_install_db.当你第一次安装MySQL时,你必须只运行mysql_install_db一次. 
当一个保护进程正在运行时,安装第二个mysqld保护进程不工作 
这只有在当你已经有已存在的MySQL安装但是想要把新安装放在一个差别的地方时才会发生(比方,为了测试大概大概你简单地想要同时运行2个安装).普通当你试着运行第二个服务器时,发生的问题是它试图和旧一个利用一样的套接字和端口.在这种情形下,你将得到错误消息:Can't start server: Bind on TCP/IP port: Address already in use或Can't start server : Bind on unix socket...你能用一个差别的套接字和端口启动新的服务器,以下: 
shell> MYSQL_UNIX_PORT=/tmp/mysqld-new.sock
shell> MYSQL_TCP_PORT=3307
shell> export MYSQL_UNIX_PORT MYSQL_TCP_PORT
shell> scripts/mysql_install_db
shell> bin/safe_mysqld &

在这今后,你应当编辑你的服务器指导脚本手迹用差别的套接字和端口启动两个保护进程.比方,它能调用safe_mysqld两次,但是对每次调用利用差别的--socket、--port和--basedir选项. 

你没有" /tmp "的写权限 
假如你没有写权限在缺省地方(在"/tmp"里)成立一个套接字文件,或没有在"/tmp"成立暂时文件的答应,在运行mysql_install_db或当启动或利用mysqld时,你将得到一个错误.你可以以下地指定一个差别的套接字和暂时目录: 
shell> TMPDIR=/some_tmp_dir/ 
shell> MYSQL_UNIX_PORT=/some_tmp_dir/mysqld.sock 
shell> export TMPDIR MYSQL_UNIX_PORT

"some_tmp_dir"应当是你有写答应的某个目录的途径.在这今后,你应当能运行mysql_install_db并且这些号令启动服务器: 

shell> scripts/mysql_install_db
shell> BINDIR/safe_mysqld &

mysqld立即崩溃 
假如你正在运行RedHat 5.0,有一个比2.0.7-5旧的glibc版本,你应当保证你安装了glibc全部补钉!在MySQL邮件档案中有很多关于它的信息.邮件档案的链接可在联机MySQL文档页得到.也可见4.11.5 Linux 注意事项(全部Linux版本).你也可以手工启动mysqld,利用--skip-grant选项并且增添利用mysql本身的权限信息: 
shell> BINDIR/safe_mysqld --skip-grant &
shell> BINDIR/mysql -u root mysql

从mysql,手工履行在mysql_install_db里面的SQL号令.保证你随后运行mysqladmin reload奉告服务器再装入受权表. 

4.15.2 启动MySQL服务器的问题
普通,你用3个办法之一启动mysqld服务器: 

通过调用mysql.server.这个脚本主要用于系统启动和关闭,更全面的描写在4.15.3 自动启动和终止MySQL. 
通过调用safe_mysqld,它试图为mysqld决意精确的选项并然后用那些挑选运行它. 
通过直接调用mysqld. 
无论你利用哪个办法启动服务器,假如它没有精确启动,查抄日记文件看你能否能发现为什么.日记文件位于数据目录(对二进制分发普通是"/usr/local/mysql/data",对源代码分发是"/usr/local/var").用"host_name.err"和"host_name.log"情势的名字在数据目录下查找文件,这里host_name是你服务器主机的名字,然后查抄这些文件的最后几行: 

shell> tail host_name.err
shell> tail host_name.log

当mysqld保护进程启动时,它把目录改变到数据目录.这是它盼望写日记文件和pid(进程ID)文件的地方,和它盼望在那儿找到数据库. 

数据目录地址是在分发编译时定死的.但是,假如mysqld盼望它在你的系统上其他某个地方找到数据目录,它将工作不正常.假如你有不精确途径的问题,你可以利用--help选项调用mysqld,找到mysqld答应什么选项和缺省途径设置是什么.你能通过指定精确的途径作为mysqld号令行参数来覆盖缺省值.(这些挑选也能用于safe_mysqld.)

普通你应当只需求奉告mysqld基本目录,在它下面安装MySQL.你可以用--basedir选项做到,你也能利用--help查抄改变途径选项的效果(注意,--help必须是mysqld号令的最后选项).比方: 

shell> EXECDIR/mysqld --basedir=/usr/local --help

一旦你肯定你想要的途径设置,不用--help选项启动服务器. 

假如你得到下列错误,它意味着mysqld正在试牟利用某些其他程序(或其他mysqld服务器)已经正在利用TCP/IP端口或套接字: 

Can't start server: Bind on TCP/IP port: Address already in use
  或
Can't start server : Bind on unix socket...

利用ps保证你没有别的一个mysqld服务器正在运行.假如你不能发现其他运行的服务器,你可以尝试履行号令telnet your-host-name tcp-ip-port-number并且按几次RETURN键,假如你没有得到一个错误消息,像telnet: Unable to connect to remote host: Connection refused,某个东西正在利用mysqld正在试牟利用的TCP/IP端口,见4.15.1 运行mysql_install_db的问题和19.3 在同一台机械上运行多个MySQL服务器. 

safe_mysqld脚本被编写以便能正常地启动一个从MySQL源代码或二进制代码版本安装的服务器,就算这些在略微差别的地址安装服务器.safe_mysqld但愿这些条件之一是真的: 

服务器和数据库能在相对safe_mysqld被调用的目录下找到.safe_mysqld在它的工作目录下面找"bin"和"data"目录(对二进制分发)或"libexec"和"var"目录(对源代码分发).假如你从你的MySQL安装目录(比方,对二进制分发为"/usr/local/mysql")履行safe_mysqld,这个条件应当满意. 
假如服务器和数据库不能在相对其工作目录找到,safe_mysqld试图通过绝对途径找到他们.典型的地址是" /usr/local/libexec"和"/usr/local/var".实际的地址在构造来自分发的safe_mysqld时肯定,假如MySQL安装在一个尺度的地址,他们应当是精确的. 
因为safe_mysqld将试图在相对它自己的工作目录下找到服务器和数据库,你可以在任何地方安装MySQL的二进制分发,只要你从MySQL安装目录启动safe_mysqld便可: 

shell> cd mysql_installation_directory
shell> bin/safe_mysqld &

假如safe_mysqld失利,乃至在从MySQL安装目录调用时,你可以改正它以便利用到mysqld途径并且对你的系统的途径选项是精确的.注意,假如在将来你进级MySQL,你的safe_mysqld改正版本将被覆盖,因此你应当做一个你能重新安装的编辑过的版本的拷贝. 

假如mysqld当前正在运行,通过履行这个号令,你能发现它正在利用什么途径设置: 

shell> mysqladmin variables



shell> mysqladmin -h 'your-host-name' variables

假如safe_mysqld启动服务器但是你不能与它衔接,你应当保证你在"/etc/hosts"里面有一个条目,看起来像这样: 

127.0.0.1  localhost
这个问题仅发生在没有一个能工作的线程库的系统上并且对该系统MySQL必须配置为利用MIT-pthreads. 

4.15.3 自动启动和终止MySQL
mysql.server脚本可以被用来启动或终止服务器,通过用start或stop参数调用它: 

shell> mysql.server start
shell> mysql.server stop

mysql.server可在MySQL安装目录下的"share/mysql"目录里找到,或在MySQL源代码树的"support-files"目录下找到. 

在mysql.server启动服务器之前,它把目录改变到MySQL安装目录,然后调用safe_mysqld.假如你有在一个非尺度的地址安装的二进制分发,你大概需求编辑mysql.server.改正它,运行safe_mysqld前,cd到精确的目录.假如你想要作为一些特定的用户运行服务器,你可以改变mysql_daemon_user=root行利用其他用户,你也能改正mysql.server把其他选项传给safe_mysqld. 

mysql.server stop通过向服务器发出一个信号终止它.你可手工履行mysqladmin shutdown关闭服务器. 

当你开始利用MySQL作为生产利用时,你大概想要增添这些启动并且终止号令到在你的"/etc/rc * 文件中得当的地方.注意假如你改正mysql.server,那么假如某个时刻你进级MySQL时,你的改正版本将被覆盖,因此你应当做一个你可重新安装的编辑过的版本的拷贝. 

假如你的系统利用"/etc/rc.local"启动外部脚本,你应当增添下列到此中: 

/bin/sh -c 'cd /usr/local/mysql ; ./bin/safe_mysqld &' 
你也可以在一个全局"/etc/my.cnf"文件中增添mysql.server的选项.一个典型的"/etc/my.cnf"文件大概看起来像这样: 

mysqld]
datadir=/usr/local/mysql/var
socket=/tmp/mysqld.sock
port=3306

[mysql.server]
user=mysql
basedir=/usr/local/mysql

mysql.server脚本利用下列变量:user、datadir、basedir、bindir和pid-file. 
见4.15.4 选项文件. 

4.15.4 选项文件
MySQL3.22 可以从选项文件中为服务器和客户读取缺省启动选项. 

在Unix上,MySQL从下列文件读取缺省挑选: 


文件名  用处  
/etc/my.cnf  全局选项 
DATADIR/my.cnf  服务器特定的选项目 
~/.my.cnf  用户特定的选项 

DATADIR是MySQL的数据目录(典型地对二进制安装是"/usr/local/mysql/data"或对源代码安装是"/usr/local/var").注意:这是在配置时间指定的目录,不是mysqld启动时用--datadir指定的目录!(--datadir在服务器探求选项文件的地方无效,因为它从前探求他们,它处理任何号令行参数.)

MySQL在Win32上从下列文件读取缺省选项: 

文件名  用处 
windows-system-directorymy.ini  
C:my.cnf  全局选项 
C:mysqldatamy.cnf  服务器特定的选项 

注意,在Win32上你应当用/而不是指定全部的途径,假如你利用,你需求指定两个,因为在MySQL里面是转义字符. 

MySQL试图以上述所列的次序读取选项文件.假如存在多个选项文件,在一个背面文件读取的选项优先于在先前读取的一个文件中指定的同一个选项,在号令行上指定的选项优先于在任何选项文件指定了的选项.有些挑选能利用环境变量指定,在号令行或在选项文件指定的选项优先于环境变量. 

下列程序支持选项文件:mysql、mysqladmin、mysqld、mysqldump、mysqlimport、mysql.server、myisamchk和myisampack. 

你能利用选项文件指定一个程序支持的肆意长的选项!用--help选项运路程序可得到的可用选项的表. 

一个选项文件可以包含下列情势的行: 

#comment 
注释行以"#"或";"开始,空行被忽视. 
[group] 
group是你想为其设置选项的程序或组的名字.在一个组行后,任何option或set-variable行利用于命名的组,直到挑选文件完毕或其他组的给出. 
option 
这等价于在号令行上的--option. 
option=value 
这等价于在号令行上的--option=value. 
set-variable = variable=value 
这等价于在号令行上的--set-variable variable=value.该语法必须被用来设置一个mysqld变量. 
client组答应你指定实用于全部MySQL客户的选项(不是mysqld).这是抱负的组来指定你用来与服务器衔接的口令.(但是保证只是选项文件本身是可读的和可写的.)

注意,对域选项和值,全部头部和尾部空白自动被删除.你可以在的值串中利用转义次序""、" "、"
"、"
"、""和"s"("s"==空白). 

这是一个典型的全局选项文件: 

[client] 
port=3306 
socket=/tmp/mysql.sock 
[mysqld] 
port=3306 
socket=/tmp/mysql.sock 
set-variable = key_buffer=16M 
set-variable = max_allowed_packet=1M 

[mysqldump] 
quick 

这是典型的用户选项文件: 

[client]
# The following password will be sent to all standard MySQL clients
password=my_password

[mysql]
no-auto-rehash

假如你有一个源代码分发,你将在"support-files"目录下找到一个名为"my-example.cnf"样品配置文件.假如你有二进制分发,在"DIR/share/mysql"目录下查找,在此DIR是MySQL安装目录的途径(普通是"/usr/local/mysql").你可以拷贝"my-example.cnf"到你的主目录(重新命名拷贝为".my.cnf")来试验. 

为了奉告一个MySQL程序不读任何选项文件,在号令行上指定--no-defaults作为第一个选项.这必须是第一个选项,不然它将无效!假如你想查抄利用哪个选项,你可以给出--print-defaults选项作为第一个选项. 

假如你想要强迫利用一个特定配置文件,你可以利用选项--defaults-file=full-path-to-default-file.假如你这样做,只有指定的文件将被读取. 

开辟者注意:选项文件的处理简单地通过处理全部在任何号令行前参数的匹配选项来实现(即,在得当的组里的选项),这对利用多次指定的一个选项的最后实例的程序工作的很好.假如你有这样一个处理多重指定选项但不读选项文件的旧程序, 你只需求增添2行授与它那种本领.查抄任何尺度的MySQL客户的源代码看怎样做. 

4.16 进级/降级MySQL时有什么分外的事情要做?
只要你有MySQL同一个的底子版本,你总可以在一样的体系构造上的差别版本之间的移动MySQL表格(form)和数据文件.当前的底子版本是3.假如你通太重新编译MySQL改变字符集(也可以改变排序次序),你必须在全部的表上运行myisamchk -r -q,不然你的索引不能精确被排序. 

假如你偏执于或耽忧新版本,你总能重新命名的旧mysqld为近似于mysqld-'old-version-number'.那么假如你的新mysqld做一些不测的事情,你可以简单地关掉它并重启你的旧mysqld! 

当你做一个进级时,当然你也应当备份你的旧数据库.有时有点偏执狂是好的! 

在进级后,假如你重新编译客户程碰到问题,像Commands out of sync或不测的核心倾倒,在编译你的程序时,你大概利用了一个旧的头文件或库文件.在这种情形下,你应当查抄你的"mysql.h"文件和"libmysqlclient.a"库文件的日期以证实他们来自新的MySQL发行.假如不是,请重新编译你的程序! 

假如你有些问题,新的mysqld服务器不想启动或你不能没有口令衔接,查抄你确切没有来自你的旧安装的一些旧的"my.cnf"文件!你可以用program-name --print-defaults查抄.假如这输出任何非程序名字的任何东西,你有一个活泼my.cnf文件将可以影响一些事情! 

无论什么时刻你安装一个新版本的MySQL,重新构造并重新安装Msql-Mysql-modules分发是一个好主张,分外是在进级MySQL后,假如你注意到诸如你的全部DBI脚本倾倒核心症状. 


4.16.1 从一个3.22版本进级到3.23
MySQL 3.23支持新MyISAM范例和旧ISAM范例的表.你没必要须变更你的旧式表给3.23利用.缺省地,全部的新表将用范例MyISAM成立(除非你利用--default-table-type=isam选项启动mysqld).你可以用ALTER TABLE或Perl脚本mysql_convert_table_format将一个ISAM表转换成一个MyISA表. 

3.22和3.21客户将毫无问题地与一个3.23服务器一同工作. 

当进级到3.23时,下面列出你必须注意的事情: 

INNER和DELAYED目前是保存字. 
FLOAT(X)目前是一个真正的浮点范例. 
当声明DECIMAL(length,dec)时,长度参数不再包含一个标记或小数点位置. 
一个TIME字符串必须是下列现有格局之一:[[[DAYS] [H]H:]MM:]SS[.fraction]或[[[[[H]H]H]H]MM]SS[.fraction]. 
目前,LIKE利用'='一样的字符对比法则对比字符串.假如你要求旧的行为,你可以用CXXFLAGS=-DLIKE_CMP_TOUPPER标志编以MySQL. 
REGEXP目前对正常(不是二进制的)字符串是忽视大小写的. 
在你查抄/修复表时,对MyISAM表(.MYI),你应当利用myisamchk,而对ISAM(.ISM)表利用isamchk. 
假如你想要你的mysqldumps在MySQL3.22和3.23之间兼容,你应当不利用mysqldump的--opt或--full选项. 
查抄全部对DATE_FORMAT()的调用,保证在在每个格局字符前有一个"%". 
mysql_fetch_fields_direct目前是函数(它从前是一个宏)并且它返回一个指向MYSQL_FIELD的指针而不是一个MYSQL_FIELD. 
mysql_num_fields()可以不再被用在一个MYSQL*对象上(它目前是一个函数,拿MYSQL_RES*作为一个参数).相反你目前应当利用mysql_field_count(). 
在MySQL3.22,SELECT DISTINCT ...的输出几近老是被排序的.在3.23上,你必须利用GROUP BY或ORDER BY得到排序的输出. 
假如没有匹配的行,SUM()目前返回NULL,而不是 0.这是遵循ANSI SQL. 
新的限制词:CASE、THEN、WHEN、ELSE和END. 

4.16.2 从一个3.21版本进级到3.22
没有影响相容性的东西在3.21和3.22之间已改变.唯一的缺陷是用DATE类范例成立的新表将利用新办法存储日期.你不能从一个mysqld旧版本存取这些新字段. 

在安装MySQL3.22 今后,你应当启动新的服务器并且然后运行mysql_fix_privilege_tables脚本.这将增添你利用GRANT号令所需的新权限.假如你忘掉了这个,当你试着利用ALTER TABLE, CREATE INDEX或DROP INDEX时,你将得到Access denied.假如你的MySQL根用户要求一个口令,你应当把它作为一个参数给mysql_fix_privilege_tables. 

mysql_real_connect()的C API接口改变了.假如你有一个旧的客户程序调用该函数,你必须放一个0作为新db参数(或为了快速衔接重新编码发送的db单元的客户).你在mysql_real_connect()前也必须调用mysql_init()!做这个改变答应新的mysql_options()函数在MYSQL处理程序构造中保存选项. 

4.16.3 从一个3.20版本进级到3.21
假如你正在运行一个比3.20.28旧的版本并且想要换到3.21.x,你需求做下列事情: 

你能用safe_mysqld --old-protocol启动mysqld3.21服务器从3.20分发的客户利用它.在这种情形下,新客户函数mysql_errno()将不返回任何服务器错误,而仅仅是CR_UNKNOWN_ERROR(但是它为客户错误服务)并且服务器利用旧的passwd() 查抄而非新的一个. 

假如你在而不是对mysqld利用--old-protocol选项,你将需求做下列改变: 

全部的客户代码必须重新编译.假如你正在利用ODBC,你必须得到新的MyODBC 2.x驱动程序. 
脚本scripts/add_long_password必须运行以便变更在mysql.user表中的Password字段为CHAR(16). 
全部在mysql.user中的口令必须被重新赋值(为了得到62位而非31位口令). 
表格局没改变,因此你没必要须变更任何表. 
MySQL3.20.28和以上版本可以处理新的user表格局而不影响客户.假如你有一个比3.20.28早的MySQL版本,假如你变更user表,口令将不再与之工作.因此为了安全,你首先应当进级到至少3.20.28并且然后进级到3.21.x.

新的客户代码可与一个3.20.x 版的mysqld服务器一同工作,因此假如你碰到3.21.x的问题,你可以利用旧的3.20.x服务器而无须重新编译客户. 

假如你对mysqld不利用--old-protocol选项,旧的客户将发出错误消息: 

ERROR: Protocol mismatch. Server Version = 10 Client Version = 9

新的Perl DBI/DBD接口也支持旧的mysqlperl接口.假如你利用mysqlperl,你必须做的唯一改变是改变到connect()函数的参数.新参数是:host、database、user、password(user和password参数改变了位置).见20.5.2 DBI接口. 

下列改变大概影响到旧的利用程序的查询: 

目前HAVING必须在任何ORDER BY子句前被指定. 
LOCATE()参数被交换了. 
有一些新的保存字.最闻名是DATE、TIME和TIMESTAMP. 

4.16.4 进级到其他体系构造
假如你正在利用MySQL3.23,你能在差别的支持一样浮点格局的体系构造之间拷贝.frm、.MYI和.MYD.(MySQL考虑了任何字节交换的问题). 

MySQL ISAM数据" *.ISD"和索引文件" *.ISM"文件是依靠于系统构造并在某些情形下依靠于OS.假如你想要移动你的利用程序到有与你当前系统差别的体系构造或OS的其他机械上,你不该该试图通过简单地拷贝文件到别的的机械上来移动一个数据库,相反利用mysqldump. 

缺省地,mysqldump将成立一个尽是SQL语句的文件,然后你可以把文件转移到其他机械上并且把它作为mysql客户的输入. 

试一试mysqldump --help看可得到什么选项.假如你正在移动数据到一个更新的MySQL版本,你应当用得到的更新的版本利用mysqldump --opt得到一个快速、紧凑的倒出(dump). 

最简单(固然不是最快)的在2台机械之间移动一个数据库的办法是在数据库所在的机械上运行下列号令: 

shell> mysqladmin -h 'other hostname' create db_name
shell> mysqldump --opt db_name 
        | mysql -h 'other hostname' db_name

假如你想要在一个慢的网络上从一台远程机械上拷贝一个数据库,你可以利用: 

shell> mysqladmin create db_name 
shell> mysqldump -h 'other hostname' --opt --compress db_name  
| mysql db_name

你也可以在一个文件中存储后果, 然后把文件转移到目标机械并且在那边装载文件到数据库.比方,你能象这样在源机械上倾倒一个数据库到一个文件: 

shell> mysqldump --quick db_name | gzip > db_name.contents.gz 

(本例成立的文件被紧缩) 转移包含数据库内容的文件到目标机械,并且在那边运行这些号令: 

shell> mysqladmin create db_name
shell> gunzip < db_name.contents.gz | mysql db_name

你也可以利用mysqldump和mysqlimport完成数据库转移.对大数据库表,这比简单地利用mysqldump更快.在下列号令中,DUMPDIR代表你用来存储来自mysqldump的输出的目录的完好的途径. 

首先,为输出文件和倾倒数据库成立目录: 

shell> mkdir DUMPDIR
shell> mysqldump --tab=DUMPDIR db_name

然后转移在DUMPDIR目录下的文件到目标机械的一些呼应目录并且在那边装载文件到MySQL: 

shell> mysqladmin create db_name           # create database
shell> cat DUMPDIR/*.sql | mysql db_name   # create tables in database
shell> mysqlimport db_name DUMPDIR/*.txt   # load data into tables

别的,别忘掉拷贝mysql数据库,因为那是受权表(user、db、host)被存储的地方.你大概必须作为MySQL root用户在新机械上运行号令,直到你让mysql数据库到位. 

当你在新机械上导入mysql数据库后,履行mysqladmin flush-privileges以便服务器再次装入受权表信息. 


ww w.iTbulo.coUkonL

责任编辑:eight(2001-06-06 21:48)
  以上是“<b>MySQL中文参考手册5(安装MySQL下)</b>[MSSQL防范]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
  • <b>hosts是什么 hosts文件在什么位置 若何改正hosts</b>
  • <b>在 Windows 8 中手动安装语言包</b>
  • <b>五个常见 PHP数据库问题</b>
  • Windows中Alt键的12个高效快速的利用本领介绍
  • <b>MySQL ORDER BY 的实现解析</b>
  • <b>详解MySQL存储历程参数有三种范例(in、out、inout)</b>
  • <b>Win8系统恢复出来经典的开始菜单的办法</b>
  • <b>Win8系统花屏怎么办 Win8系统花屏的办理办法</b>
  • <b>Windows 7系统下无线网卡安装</b>
  • <b>为什么 Linux不需求碎片整理</b>
  • <b>Windows 8中删除账户的几种办法(图)</b>
  • <b>教你如安在win7下配置路由器</b>
  • 本文地址: 与您的QQ/BBS好友分享!
    • 好的评价 如果您觉得此文章好,就请您
        0%(0)
    • 差的评价 如果您觉得此文章差,就请您
        0%(0)

    文章评论评论内容只代表网友观点,与本站立场无关!

       评论摘要(共 0 条,得分 0 分,平均 0 分) 查看完整评论
    Copyright © 2020-2022 www.xiamiku.com. All Rights Reserved .