發新話題
打印

MySQL中文参考手册5(安装MySQL下)

MySQL中文参考手册5(安装MySQL下)

作者:未知 | 文章出处:未知 | 阅读次数:85 | 发布日期:2005-11-07


MySQL中文参考手册5(安装MySQL下)

转载 译者:晏子

〖返回〗〖转发〗







译者:晏子 (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.htmlhttp://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以便服务器再次装入授权表信息。
国学参考:www.zgwww.com

TOP

轻松搞定mysql的启动问题---从启动到 初步入门必读

--------------------------------------------------------------------------------


英文的原文“run the command chown -R mysql:mysql /var/lib/mysql 。
Then su mysql to become the proper user and to run the mysql_install_db script .
Now you should be able to start the MySQL server by running safe_mysqld --user=mysql as root.”(可能是手误,命令应该是mysqld_safe ...)

修改数据库位置参考:http://dev.mysql.com/doc/refman/4.1/en/linux-rpm.html

具体步骤:
os:slackware10.2
1.#chown -R mysql:mysql /var/lib/mysql
2.#su mysql
3.$ mysql_install_db
4.$ /usr/bin/mysqld_safe &
5.su
6.mysql

to change the data directory

1. stop mysql server
2. mkdir /home/mysql
3. mv /var/lib/mysql/* /home/mysql/
4. rmdir /var/lib/mysql
5. ln -s /home/mysql /var/lib/mysql
6. chown -R mysql:mysql /home/mysql
7. start mysql server again

--------------------------------------------------------------------------------
此帖于 05-12-22 19:50 被 linuxtester1 编辑.  


     

linuxtester1
查看公开信息
发悄悄话给 linuxtester1
查找 linuxtester1 发表的更多帖子

linuxtester1
资 料:注册会员

注册日期: Nov 2005
帖子: 106
精华: 0
     第 2 帖   发帖时间: 05-12-21, 01:04



本人刚使用mysql,
也遇到不能启动的问题。

原来刚安装的mysql有一个默认的用户和组,名字都是mysql.
运行mysql_install-db的时候,必须是以mysql组的用户运行。
具体操作见上面。

很多启动不了的问题就出在这里---我是看FAQ才知道的,与大伙共享。

关于MYSQL的教程,我去EMULE主页,搜索发现有很多的教材,还有MYSQL-PHP视频教程,爽


     

linuxtester1
查看公开信息
发悄悄话给 linuxtester1
查找 linuxtester1 发表的更多帖子

linuxtester1
资 料:注册会员

注册日期: Nov 2005
帖子: 106
精华: 0
     第 3 帖   发帖时间: 05-12-21, 02:40


常用命令

--------------------------------------------------------------------------------


mysql>下面:
create database 数据库名
use 数据库名
select database()
create table 表名(字段名1 类型 [not null],... );
describe 表名;
show tables
show databases
insert into 表名 value(字段1值,字段2值,...);
select 字段1,字段2,... from 表明 where 条件;
\q 退出mysql
国学参考:www.zgwww.com

TOP

MySQL用户管理

作者:ITFAT.com收集整理    来源:www.ITFAT.com    更新时间:2005-12-06

[ 收藏此页到: 天天 | 和讯 | 博采 | ViVi | 狐摘 | 我摘 ]  

MySQL管理员应该知道如何设置MySQL用户账号,指出哪个用户可以连接服务器,从哪里连接,连接后能做什么。MySQL 3.22.11开始引入两条语句使得这项工作更容易做:GRANT语句创建MySQL用户并指定其权限,而REVOKE语句删除权限。两条语句扮演了mysql数据库的前端角色,并提供与直接操作这些表的内容不同的另一种方法。CREATE和REVOKE语句影响4个表:授权表
内容
user 能连接服务器的用户以及他们拥有的任何全局权限
db 数据库级权限
tables_priv 表级权限
columns_priv 列级权限

还有第5个授权表(host),但它不受GRANT和REVOKE的影响。
当你对一个用户发出一条GRANT语句时,在user表中为该用户创建一条记录。如果语句指定任何全局权限(管理权限或适用于所有数据库的权限),这些也记录在user表中。如果你指定数据库、表和列级权限,他们被分别记录在db、tables_priv和columns_priv表中。
用GRANT和REVOKE比直接修改授权表更容易些,然而,建议你阅读一下《MySQL安全性指南》。这些表异常重要,而且作为一名管理员,你应该理解它们如何超越GRANT和REVOKE语句的功能水平。
在下面的章节中,我们将介绍如何设置MySQL用户账号并授权。我们也涉及如何撤权和从授权表中删除用户。
你可能也想考虑使用mysqlaccess和mysql_setpermission脚本,它是MySQL分发的一部分,它们是Perl脚本,提供GRANT语句的另一种选择设置用户账号。mysql_setpermission需要安装DBI支持。
1 创建用户并授权

GRANT语句的语法看上去像这样:
GRANT privileges (columns)  ON what  TO user IDENTIFIED BY "password"  WITH GRANT OPTION 

要使用该语句,你需要填写下列部分:
privileges

授予用户的权限,下表列出可用于GRANT语句的权限指定符:
权限指定符
权限允许的操作
ALTER 修改表和索引
CREATE 创建数据库和表
DELETE 删除表中已有的记录
DROP 抛弃(删除)数据库和表
INDEX 创建或抛弃索引
INSERT 向表中插入新行
REFERENCE 未用
SELECT 检索表中的记录
UPDATE 修改现存表记录
FILE 读或写服务器上的文件
PROCESS 查看服务器中执行的线程信息或杀死线程
RELOAD 重载授权表或清空日志、主机缓存或表缓存。
SHUTDOWN 关闭服务器
ALL 所有;ALL PRIVILEGES同义词
USAGE 特殊的“无权限”权限

上表显示在第一组的权限指定符适用于数据库、表和列,第二组数管理权限。一般,这些被相对严格地授权,因为它们允许用户影响服务器的操作。第三组权限特殊,ALL意味着“所有权限”,UASGE意味着无权限,即创建用户,但不授予权限。
columns

权限运用的列,它是可选的,并且你只能设置列特定的权限。如果命令有多于一个列,应该用逗号分开它们。
what

权限运用的级别。权限可以是全局的(适用于所有数据库和所有表)、特定数据库(适用于一个数据库中的所有表)或特定表的。可以通过指定一个columns字句是权限是列特定的。
user

权限授予的用户,它由一个用户名和主机名组成。在MySQL中,你不仅指定谁能连接,还有从哪里连接。这允许你让两个同名用户从不同地方连接。MySQL让你区分他们,并彼此独立地赋予权限。
MySQL中的一个用户名就是你连接服务器时指定的用户名,该名字不必与你的Unix登录名或Windows名联系起来。缺省地,如果你不明确指定一个名字,客户程序将使用你的登录名作为MySQL用户名。这只是一个约定。你可以在授权表中将该名字改为nobody,然后以nobody连接执行需要超级用户权限的操作。
password

赋予用户的口令,它是可选的。如果你对新用户没有指定IDENTIFIED BY子句,该用户不赋给口令(不安全)。对现有用户,任何你指定的口令将代替老口令。如果你不指定口令,老口令保持不变,当你用IDENTIFIED BY时,口令字符串用改用口令的字面含义,GRANT将为你编码口令,不要象你用SET PASSWORD 那样使用password()函数。
WITH GRANT OPTION子句是可选的。如果你包含它,用户可以授予权限通过GRANT语句授权给其它用户。你可以用该子句给与其它用户授权的能力。
用户名、口令、数据库和表名在授权表记录中是大小写敏感的,主机名和列名不是。
一般地,你可以通过询问几个简单的问题来识别GRANT语句的种类:
谁能连接,从那儿连接?
用户应该有什么级别的权限,他们适用于什么?
用户应该允许管理权限吗?

下面就讨论一些例子。
1.1 谁能连接,从那儿连接?

你可以允许一个用户从特定的或一系列主机连接。有一个极端,如果你知道降职从一个主机连接,你可以将权限局限于单个主机:
GRANT ALL ON samp_db.* TO boris@localhost IDENTIFIED BY "ruby"GRANT ALL ON samp_db.* TO fred@res.mars.com IDENTIFIED BY "quartz"

(samp_db.*意思是“samp_db数据库的所有表)另一个极端是,你可能有一个经常旅行并需要能从世界各地的主机连接的用户max。在这种情况下,你可以允许他无论从哪里连接:
GRANT ALL ON samp_db.* TO max@% IDENTIFIED BY "diamond"

“%”字符起通配符作用,与LIKE模式匹配的含义相同。在上述语句中,它意味着“任何主机”。所以max和max@%等价。这是建立用户最简单的方法,但也是最不安全的。
取其中,你可以允许一个用户从一个受限的主机集合访问。例如,要允许mary从snake.net域的任何主机连接,用一个%.snake.net主机指定符:
GRANT ALL ON samp_db.* TO mary@.snake.net IDENTIFIED BY "quartz";

如果你喜欢,用户标识符的主机部分可以用IP地址而不是一个主机名来给定。你可以指定一个IP地址或一个包含模式字符的地址,而且,从MySQL 3.23,你还可以指定具有指出用于网络号的位数的网络掩码的IP号:
  GRANT ALL ON samp_db.* TO boris@192.168.128.3 IDENTIFIED BY "ruby"  GRANT ALL ON samp_db.* TO fred@192.168.128.% IDENTIFIED BY "quartz"  GRANT ALL ON samp_db.* TO rex@192.168.128.0/17 IDENTIFIED BY "ruby"

第一个例子指出用户能从其连接的特定主机,第二个指定对于C类子网192.168.128的IP模式,而第三条语句中,192.168.128.0/17指定一个17位网络号并匹配具有192.168.128头17位的IP地址。 
如果MySQL抱怨你指定的用户值,你可能需要使用引号(只将用户名和主机名部分分开加引号)。
GRANT ALL ON samp_db.president TO "my friend"@"boa.snake.net"
1.2 用户应该有什么级别的权限和它们应该适用于什么?

你可以授权不同级别的权限,全局权限是最强大的,因为它们适用于任何数据库。要使ethel成为可做任何事情的超级用户,包括能授权给其它用户,发出下列语句:
GRANT ALL ON *.* TO ethel@localhost IDENTIFIED BY "coffee" WITH GRANT OPTION

ON子句中的*.*意味着“所有数据库、所有表”。从安全考虑,我们指定ethel只能从本地连接。限制一个超级用户可以连接的主机通常是明智的,因为它限制了试图破解口令的主机。
有些权限(FILE、PROCESS、RELOAD和SHUTDOWN)是管理权限并且只能用"ON *.*"全局权限指定符授权。如果你愿意,你可以授权这些权限,而不授权数据库权限。例如,下列语句设置一个flush用户,他只能发出flush语句。这可能在你需要执行诸如清空日志等的管理脚本中会有用:
GRANT RELOAD ON *.* TO flushl@localhost IDENTIFIED BY "flushpass"

一般地,你想授权管理权限,吝啬点,因为拥有它们的用户可以影响你的服务器的操作。
数据库级权限适用于一个特定数据库中的所有表,它们可通过使用ON db_name.*子句授予:
GRANT ALL ON samp_db TO bill@racer.snake.net INDETIFIED BY "rock"  GRANT SELECT ON samp_db TO ro_user@% INDETIFIED BY "rock"

第一条语句向bill授权samp_db数据库中所有表的权限,第二条创建一个严格限制访问的用户ro_user(只读用户),只能访问samp_db数据库中的所有表,但只有读取,即用户只能发出SELECT语句。
你可以列出一系列同时授予的各个权限。例如,如果你想让用户能读取并能修改现有数据库的内容,但不能创建新表或删除表,如下授予这些权限:
GRANT SELECT,INSERT,DELETE,UPDATE ON samp_db TO bill@snake.net INDETIFIED BY "rock"

对于更精致的访问控制,你可以在各个表上授权,或甚至在表的每个列上。当你想向用户隐藏一个表的部分时,或你想让一个用户只能修改特定的列时,列特定权限非常有用。如:
GRANT SELECT ON samp_db.member TO bill@localhost INDETIFIED BY "rock"GRANT UPDATE (expiration) ON samp_db. member TO bill@localhost

第一条语句授予对整个member表的读权限并设置了一个口令,第二条语句增加了UPDATE权限,当只对expiration列。没必要再指定口令,因为第一条语句已经指定了。
如果你想对多个列授予权限,指定一个用逗号分开的列表。例如,对assistant用户增加member表的地址字段的UPDATE权限,使用如下语句,新权限将加到用户已有的权限中:
GRANT UPDATE (street,city,state,zip) ON samp_db TO assistant@localhost
通常,你不想授予任何比用户确实需要的权限宽的权限。然而,当你想让用户能创建一个临时表以保存中间结果,但你又不想让他们在一个包含他们不应修改内容的数据库中这样做时,发生了要授予在一个数据库上的相对宽松的权限。你可以通过建立一个分开的数据库(如tmp)并授予开数据库上的所有权限来进行。例如,如果你想让来自mars.net域中主机的任何用户使用tmp数据库,你可以发出这样的GRANT语句:
GRANT ALL ON tmp.* TO ""@mars.net
在你做完之后,用户可以创建并用tmp.tbl_name形式引用tmp中的表(在用户指定符中的""创建一个匿名用户,任何用户均匹配空白用户名)。
1.3 用户应该被允许管理权限吗?

你可以允许一个数据库的拥有者通过授予数据库上的所有拥有者权限来控制数据库的访问,在授权时,指定WITH GRANT OPTION。例如:如果你想让alicia能从big.corp.com域的任何主机连接并具有sales数据库中所有表的管理员权限,你可以用如下GRANT语句:
GRANT ALL ON sales.* TO alicia@%.big.corp.com INDETIFIED BY "applejuice" WITH GRANT OPTION
在效果上WITH GRANT OPTION子句允许你把访问授权的权利授予另一个用户。要注意,拥有GRANT权限的两个用户可以彼此授权。如果你只给予了第一个用户SELECT权限,而另一个用户有GRANT加上SELECT权限,那么第二个用户可以是第一个用户更“强大”。
2 撤权并删除用户

要取消一个用户的权限,使用REVOKE语句。REVOKE的语法非常类似于GRANT语句,除了TO用FROM取代并且没有INDETIFED BY和WITH GRANT OPTION子句:
REVOKE privileges (columns) ON what FROM user
user部分必须匹配原来GRANT语句的你想撤权的用户的user部分。privileges部分不需匹配,你可以用GRANT语句授权,然后用REVOKE语句只撤销部分权限。
REVOKE语句只删除权限,而不删除用户。即使你撤销了所有权限,在user表中的用户记录依然保留,这意味着用户仍然可以连接服务器。要完全删除一个用户,你必须用一条DELETE语句明确从user表中删除用户记录:
%mysql -u root mysqlmysql>DELETE FROM user   ->WHERE User="user_name" and Host="host_name";mysql>FLUSH PRIVILEGES; 

DELETE语句删除用户记录,而FLUSH语句告诉服务器重载授权表。(当你使用GRANT和REVOKE语句时,表自动重载,而你直接修改授权表时不是。)
国学参考:www.zgwww.com

TOP

学习MySQL常用操作命令

作者:unknown 更新时间:2005-03-18   
  
    上篇讲了如何安装并测试MySQL,环境建好后就可以继续我们的学习了。本篇主要熟悉一写常用命令。

    1、启动MySQL服务器

    实际上上篇已讲到如何启动MySQL。两种方法: 一是用winmysqladmin,如果机器启动时已自动运行,则可直接进入下一步操作。 二是在DOS方式下运行 d:mysqlbinmysqld

    2、进入mysql交互操作界面

    在DOS方式下,运行: d:mysqlbinmysql

    出现: mysql 的提示符,此时已进入mysql的交互操作方式。

    如果出现 "ERROR 2003: Can′t connect to MySQL server on ′localhost′ (10061)“,

说明你的MySQL还没有启动。

    3、退出MySQL操作界面

    在mysql>提示符下输入quit可以随时退出交互操作界面:
    mysql> quit
    Bye
    你也可以用control-D退出。

    4、第一条命令

mysql> select version(),current_date();
+----------------+-----------------+
| version() | current_date() |
+----------------+-----------------+
| 3.23.25a-debug | 2001-05-17 |
+----------------+-----------------+
1 row in set (0.01 sec)
mysql>



    此命令要求mysql服务器告诉你它的版本号和当前日期。尝试用不同大小写操作上述命令,看结果如何。结果说明mysql命令的大小写结果是一致的。

    练习如下操作:

mysql>Select (20+5)*4;
mysql>Select (20+5)*4,sin(pi()/3);
mysql>Select (20+5)*4 AS Result,sin(pi()/3); (AS: 指定假名为Result)
    <B>5、多行语句</B>
    一条命令可以分成多行输入,直到出现分号“;”为止:
<ccid_nobr>
<table width="400" border="1" cellspacing="0" cellpadding="2"
bordercolorlight = "black" bordercolordark = "#FFFFFF" align="center">
<tr>
    <td bgcolor="e6e6e6" class="code" style="font-size:9pt">
    <pre><ccid_code>  mysql> select
-> USER()
-> ,
-> now()
->;
+--------------------+---------------------+
| USER() | now() |
+--------------------+---------------------+
| ODBC@localhost | 2001-05-17 22:59:15 |
+--------------------+---------------------+
1 row in set (0.06 sec)
mysql>



    注意中间的逗号和最后的分号的使用方法。

    6、一行多命令

    输入如下命令:

mysql> SELECT USER(); SELECT NOW();
+------------------+
| USER() |
+------------------+
| ODBC@localhost |
+------------------+
1 row in set (0.00 sec)

+---------------------+
| NOW() |
+---------------------+
| 2001-05-17 23:06:15 |
+---------------------+
1 row in set (0.00 sec)
mysql>



    注意中间的分号,命令之间用分号隔开。

    7、显示当前存在的数据库

mysql> show databases;
+----------+
| Database |
+----------+
| mysql |
| test |
+----------+
2 row in set (0.06 sec)
mysql>



    8、选择数据库并显示当前选择的数据库

mysql> USE mysql
Database changed
mysql>
(USE 和 QUIT 命令不需要分号结束。)
mysql> select database();
+---------------+
| database() |
+---------------+
| mysql |
+---------------+
1 row in set (0.00 sec)



    9、显示当前数据库中存在的表
    mysql> SHOW TABLES;

    10、显示表(db)的内容
mysql>select * from db;

    11、命令的取消

    当命令输入错误而又无法改变(多行语句情形)时,只要在分号出现前就可以用 c来取消该条命令

mysql> select
-> user()
-> c
mysql>



    这是一些最常用的最基本的操作命令,通过多次练习就可以牢牢掌捂了。
国学参考:www.zgwww.com

TOP

MySQL数据库基础教程

--------------------------------------------------------------------------------

http://www.webjx.com  更新日期:2005-12-19  网页教学网  浏览次数:73


  数据库从最初的数据文件的简单集合发展到今天的大型数据库管理系统已经成为我们日常生活中不可缺少的组成部分。如果不借助数据库的帮助,许多简单的工作将变得冗长乏味,甚至难以实现。尤其是象银行、院校和图书馆这样的大型组织更加依靠数据库系统实现其正常的运作。再看互联网上,从搜索引擎到在线商场,从网上聊天到邮件列表,都离不开数据库。
  目前,市面上的数据库产品多种多样,从大型企业的解决方案到中小企业或个人用户的小型应用系统,可以满足用户的多样化需求。这里,我们所要向大家介绍的MySQL数据库是众多的关系型数据库产品中的一个,相比较其它系统而言,MySQL数据库可以称得上是目前运行速度最快的SQL语言数据库。除了具有许多其它数据库所不具备的功能和选择之外,MySQL数据库是一种完全免费的产品,用户可以直接从网上下载数据库,用于个人或商业用途,而不必支付任何费用(推荐下载站点http://www.mysql.com)。

  总体来说,MySQL数据库具有以下主要特点:

1. 同时访问数据库的用户数量不受限制;

2. 可以保存超过50,000,000条记录;

3. 是目前市场上现有产品中运行速度最快的数据库系统;

4. 用户权限设置简单、有效。

  如今,包括Siemens和Silicon Graphics这样的国际知名公司也开始把MySQL作为其数据库管理系统,这就更加证明了MySQL数据库的优越性能和广阔的市场发展前景。

  本文将重点向读者介绍MySQL数据库的一些基本操作,包括如何与数据库建立连接,如果设置数据库,以及如何执行基本的命令等。希望能够对读者学习和掌握MySQL数据库有所助益。

入门

  一般来说,我们访问MySQL数据库时,首先需要使用telnet远程登录安装数据库系统的服务器,然后再进入MySQL数据库。MySQL数据库的连接命令如下:

mysql -h hostname -u username -p[password]

或者:

mysql -h hostname -u username --password=password

  其中,hostname为装有MySQL数据库的服务器名称,username和password分别是用户的登录名称和口令。

  如果MySQL数据库安装和配置正确的话,用户在输入上述命令之后会得到如下系统反馈信息:

Welcome to the MySQL monitor. Commands end with ; or \g.

Your MySQL connection id is 49 to server version: 3.2 3-beta-log

Type help for help.

mysql$#@62;

  这样,用户就成功进入了MySQL数据库系统,可以在mysql命令提示符之后输入各种命令。下面,我们列出一些MySQL数据库的主要管理命令供读者参考,用户也可以通过在命令符之后输入help,\h或?得到以下命令的简单说明。

mysql$#@62; help

help (\h) 显示命令帮助

? (\h) 作用同上

clear (\c) 清除屏幕内容

connect (\r) 重新连接服务器,可选参数为 db(数据库)和 host(服务器)

exit (\) 退出mysql数据库,作用与quit命令相同

go (\g) 将命令传送至mysql数据库

print (\p) 打印当前命令

quit (\q) 退出mysql数据库

status (\s) 显示服务器当前信息

use (\u) 打开数据库,以数据库名称作为命令参数

  上述命令主要用于MySQL数据库的系统管理,如果用户需要对某个具体的数据库进行操作,可以使用use命令进入该数据库,格式如下:

mysql$#@62; use dbname;

  这里需要提醒读者注意的一点就是MySQL数据库要求使用者在所有命令的结尾处使用“;”作为命令结束符。


数据类型和数据表

  从本质上说,数据库就是一种不断增长的复杂的数据组织结构。在MySQL数据库中,用于保存数据记录的结构被称为数据表。而每一条数据记录则是由更小的数据对象,即数据类型组成。因此,总体来说,一个或多个数据类型组成一条数据记录,一条或多条数据记录组成一个数据表,一个或多个数据表组成一个数据库。我们可以把上述结构理解为如下形式:

Database $#@60; Table $#@60; Record $#@60; Datatype

  数据类型分为不同的格式和大小,可以方便数据库的设计人员创建最理想的数据结构。能否正确的选择恰当的数据类型对最终数据库的性能具有重要的影响,因此,我们有必要首先对数据类型的有关概念进行较为详细的介绍。

MySQL 数据类型

  MySQL 数据库提供了多种数据类型,其中较为常用的几种如下:

CHAR (M)

  CHAR数据类型用于表示固定长度的字符串,可以包含最多达255个字符。其中M代表字符串的长度。

举例如下:

car_model CHAR(10);

VARCHAR (M)

  VARCHAR是一种比CHAR更加灵活的数据类型,同样用于表示字符数据,但是VARCHAR可以保存可变长度的字符串。其中M代表该数据类型所允许保存的字符串的最大长度,只要长度小于该最大值的字符串都可以被保存在该数据类型中。因此,对于那些难以估计确切长度的数据对象来说,使用VARCHAR数据类型更加明智。VARCHAR数据类型所支持的最大长度也是255个字符。

  这里需要提醒读者注意的一点是,虽然VARCHAR使用起来较为灵活,但是从整个系统的性能角度来说,CHAR数据类型的处理速度更快,有时甚至可以超出VARCHAR处理速度的50%。因此,用户在设计数据库时应当综合考虑各方面的因素,以求达到最佳的平衡。

举例如下:

car_model VARCHAR(10);

INT (M) [Unsigned]

  INT数据类型用于保存从- 2147483647 到2147483648范围之内的任意整数数据。如果用户使用Unsigned选项,则有效数据范围调整为0-4294967295。举例如下:

light_years INT;

  按照上述数据类型的设置,-24567为有效数据,而3000000000则因为超出了有效数据范围成为无效数据。

再例如:

light_years INT unsigned;

这时,3000000000成为有效数据,而-24567则成为无效数据。

FLOAT [(M,D)]

  FLOAT数据类型用于表示数值较小的浮点数据,可以提供更加准确的数据精度。其中,M代表浮点数据的长度(即小数点左右数据长度的总和),D表示浮点数据位于小数点右边的数值位数。

举例如下:

rainfall FLOAT (4,2);

  按照上述数据类型的设置,42.35为有效数据,而324.45和3.542则因为超过数据长度限制或者小数点右边位数大于规定值2成为无效数据。

DATE

  DATE数据类型用于保存日期数据,默认格式为YYYY-MM-DD。MySQL提供了许多功能强大的日期格式化和操作命令,本文无法在此一一进行介绍,感兴趣的读者可以参看MySQL的技术文档。

DATE数据类型举例如下:

the_date DATE;

TEXT / BLOB

  TEXT和BLOB数据类型可以用来保存255 到65535个字符,如果用户需要把大段文本保存到数据库内的话,可以选用TEXT或BLOB数据类型。TEXT和BLOB这两种数据类型基本相同,唯一的区别在于TEXT不区分大小写,而BLOB对字符的大小写敏感。

SET

  SET数据类型是多个数据值的组合,任何部分或全部数据值都是该数据类型的有效数据。SET数据类型最大可以包含64个指定数据值。

举例如下:

transport SET ("truck", "wagon") NOT NULL;

  根据上述数据类型的设置,truck、wagon、以及truck,wagon都可以成为transport的有效值。

ENUM

  ENUM数据类型和SET基本相同,唯一的区别在于ENUM只允许选择一个有效数据值。例如:

transport ENUM ("truck", "wagon") NOT NULL;

  根据上述设置,truck或wagon将成为transport的有效数据值。

  以上,我们只是对用户使用MySQL数据库的过程中经常用到的数据类型进行了简单介绍,有兴趣的读者,可以参看MySQL技术文档的详细说明。


数据记录

  一组经过声明的数据类型就可以组成一条记录。记录小到可以只包含一个数据变量,大到可以满足用户的各种复杂需求。多条记录组合在一起就构成了数据表的基本结构。


数据表

  在我们执行各种数据库命令之前,首先需要创建用来保存信息的数据表。我们可以通过以下方式在MySQL数据库中创建新的数据表:

mysql$#@62; CREATE TABLE test (

$#@62; name VARCHAR (15),

$#@62; email VARCHAR (25),

$#@62; phone_number INT,

$#@62; ID INT NOT NULL AUTO_INCREMENT,

$#@62; PRIMARY KEY (ID));

系统反馈信息为:

Query OK, 0 rows affected (0.10 sec)

mysql$#@62;

  这样,我们就在数据库中创建了一个新的数据表。注意,同一个数据库中不能存在两个名称相同的数据表。

  这里,我们使用CREATE TABLE命令创建的test数据表中包含name,email,phone_number和ID四个字段。MySQL数据库允许字段名中包含字符或数字,最大长度可以达到64个字符。

  下面,我们来看一看创建数据表时所用到的几个主要的参数选项。

Primary Key

  具有Primary Key限制条件的字段用于区分同一个数据表中的不同记录。因为同一个数据表中不会存在两个具有相同值的Primary Key字段,所以对于那些需要严格区分不同记录的数据表来说,Primary Key具有相当重要的作用。

Auto_Increment

  具有Auto_Increment限制条件的字段值从1开始,每增加一条新记录,值就会相应地增加1。一般来说,我们可以把Auto_Increment字段作为数据表中每一条记录的标识字段。

NOT NULL

  NOT NULL限制条件规定用户不得在该字段中插入空值。

其它数据表命令

  除了创建新的数据表之外,MySQL数据库还提供了其它许多非常实用的以数据表作为操作对象的命令。

显示数据表命令

mysql$#@62; show tables;

  该命令将会列出当前数据库下的所有数据表。

显示字段命令

mysql$#@62; show columns from tablename;

  该命令将会返回指定数据表的所有字段和字段相关信息。


数据操作

  对MySQL数据库中数据的操作可以划分为四种不同的类型,分别是添加、删除、修改和查询,我们将会在本节中对此进行介绍。但是,首先我们需要强调的一点就是MySQL数据库所采用的SQL语言同其它绝大多数计算机编程语言一样,对命令的语法格式有严格的规定。任何语法格式上的错误,例如不正确的使用括号、逗号或分号等都可能导致命令执行过程中的错误。因此,建议用户在学习时一定要多留心语法格式的使用。

添加记录

  用户可以使用INSERT命令向数据库中添加新的记录。

例如:

mysql$#@62; INSERT INTO test VALUES

mysql$#@62; (John, carrots@mail.com,

mysql$#@62; 5554321, NULL);

  上述命令正确执行后会返回以下信息:

Query OK, 1 row affected (0.02 sec)

mysql$#@62;

  对上述命令有几点我们需要说明。首先,所有的字符类型数据都必须使用单引号括起来。其次,NULL关键字与AUTO_INCREMENT限制条件相结合可以为字段自动赋值。最后,也是最重要的一点就是新记录的字段值必须与数据表中的原字段相对应,如果原数据表中有4个字段,而用户所添加的记录包含3个或5个字段的话都会导致错误出现。

  MySQL数据库的一个非常显著的优势就是可以对整数、字符串和日期数据进行自动转换。因此,用户在添加新记录时就不必担心因为数据类型不相符而出现错误。

查询数据

  如果我们无法从数据库中查找和读取数据的话,数据库就丧失了其存在和使用的价值。

  在MySql数据库中,用户可以使用SELECT命令进行数据的查询。

例如:

mysql$#@62; SELECT * FROM test

mysql$#@62; WHERE (name = "John");

上述命令会返回如下结果:

name
email
phone
ID

John
carrots@mail.com
5554321
1





删除数据

  用户除了可以向数据表中添加新的记录之外,还可以删除数据表中的已有记录。删除记录可以使用DELETE命令。

例如:

mysql$#@62; DELETE FROM test

mysql$#@62; WHERE (name = "");

  该命令将会删除test数据表中name字段的值为John的记录。同样,

mysql$#@62; DELETE FROM test

mysql$#@62; WHERE (phone_number = 5554321);

  将会从数据表中删除phone_number字段值为5554321的记录。

修改数据

  MySQL数据库还支持用户对已经输入到数据表中的数据进行修改。修改记录可以使用UPDATE命令。

例如:

mysql$#@62; UPDATE test SET name = Mary

mysql$#@62; WHERE name = "John";

上述命令的执行结果如下:

name
email
phone
ID

Mary
carrots@mail.com
5554321
1





  到此为止,我们对MySQL数据库数据操作的核心概念,即数据的添加、删除、修改和查询进行了简单的介绍。事实上,MySQL数据库所支持的SQL语言具有非常丰富和强大的数据操作功能,感兴趣的读者可以参看网页教学网栏目内的相关文章。我们在这里就不重复介绍了。
国学参考:www.zgwww.com

TOP

在MySQL中修改一个用户(比如叫"hunte")的密码,可以用如下3个办法:

>>>
#在控制台上输入
bash$ mysql -u root mysql
#用mysql客户程序
mysql> UPDATE user SET password=PASSWORD("new password") WHERE user=hunte;
mysql> FLUSH PRIVILEGES;
mysql> QUIT
<<<

>>>
#在控制台上输入
bash$ mysql -u root mysql
mysql> SET PASSWORD FOR hunte=PASSWORD(new password);
mysql> QUIT
<<<

>>>
#直接在控制台上输入
bash$ mysqladmin -u root "old password" "new password"
<<<
国学参考:www.zgwww.com

TOP

MYSQL初学者使用指南
作者:ITFAT.com收集整理    来源:www.ITFAT.com    更新时间:2005-12-05

[ 收藏此页到: 天天 | 和讯 | 博采 | ViVi | 狐摘 | 我摘 ]  

(上篇)
有很多朋友虽然安装好了mysql但却不知如何使用它。在这篇文章中我们就从连接MYSQL、修改密码、增加用户等方面来学习一些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 -h110.110.110.110 -uroot -pabcd123
(注:u与root可以不用加空格,其它也一样)
3、退出MYSQL命令: exit (回车)
二、修改密码。
格式:mysqladmin -u用户名 -p旧密码 password 新密码
1、例1:给root加个密码ab12。首先在DOS下