1、  MySQL的安装
先安装perl-DBD-MySQL-2.9004-3.1.I386.rpm 软件包,
mysql-4.4.10a-2.RHEL4.1.i386.rpm  客户程序及共享库
mysqlclient10-3.23.58-4.RGEL4.1.i386.rpm  用来兼容3.23.x版本客户端库
mysql-server-4.1.10a-2.RHEL4.1.386.rpm   MySQL数据库服务
mysql-bench-4.1.10a-2.RHEL4.1.386.rpm   MySQL数据库基准和性能测试工具
mysql-devel-4.1.10a-2.RHEL4.1.386.rpm   开发MySQL程序时使用的库和头文件
mysqlclient10-devel-3.23.58-4.RHEL4.1.386.rpm   开发MySQL客房端程序时使用的库和头文件
2、  MySQL服务的配置和使用
修改MySQL管理员的口令:mysqladmin –u root password 密码字符串             
如:mysqldmin –u root password 111111
连接MySQL服务器,使用命令: mysql [-h 主机名或IP地址] [-u 用户名] [-p]      
如:mysql –u root –p
如已有密码需修改root密码用命令: mysqladmin –u root –p password 新密码字符串  
如:mysqladmin –u root –p password 111111
创建数据库格式为:CREATE DATABASE 数据库名称;
如:mysql>create database abc;    默认创建数据库保存在/var/lib/mysql
查看数据库是  mysql>show abc;
选择数据库是  USE 数据库名称;  如:mysql>use abc;
删除数据库是  DROP DATABASE 数据库名称; 如:mysql>drop database abc;
  
数据库的创建和删除
创建表是 CREATE TABLE 表名称(字段1,字段2…[表级约束]) [TYPE=表类型]
其中字段(1,2 )格式为:字段名 字段类型 [字段约束]
如创建一个表student,如下:
mysql>create table student (
sno varchar(7) not null,   字段不允许为空
sname varchar (20 )not null,
ssex char (1) default ‘t’,
sbirthday date,
sdepa char (20),
primary key (sno)       表的主键
);
可用describe命令查看表的结构。
默认表的类型为MYISAM,并在/var/lib/mysql/abc 目录下建立student.frm(表定义文件)student.MDY(数据文件)stedent.MYI(索引文件)
复制表 CREATE TABLE 新表名称 LIKE 原表名称;
如:mysql>create table xtable like student;
删除表 DROP TABLE 表名称1[表名称2…];
如:mysql> drop table xtale;
 
修改表 ALTER TABLE 表名称 更改动作1[动作2]
动作有ADD(增加) DROP(删除)CHANGEMODIFY(更改字段名和类型)RENAME
 
增加字段:mysql>alter table student add saddress varchar(25);
更改字段名和字段类型: mysql>alter table student change saddress sremark test;
即使不更改字段类型也要给出字段类型如:
mysql>alter table student change saddress sremark varchar (25);
更改字段类型 :mysql> alter table student modify sremark varchar(25);
删除字段:mysql>alter table student drop sremark
更改表名称: mysql>alter table student rename to xs
 
表中数据的插入、删除和修改
   插入记录: INSERT INTO 表名称(字段名1,字段名2…
               VALUES(字段1的值,字段2的值
   如:mysql>insert into student (sno,sname,ssex,sbirthday,sdepa)
             values(‘0321001’,’Liu Tao’,dagault,19870201,’math’);
   查看表  mysql>select * from student;
插入与前面相同的记录,可用insert命令的缩写格式,
: mysql>insert into student values (‘0321001’, ‘Liu Tao’, default, 19870201, ‘mth’);
如果字段名列表中没有给出表中的某些字段,那么这些字段设置为默认值,
如:mysql>insert into student (sno,sname,sbirthday)
          values(‘0321002’,’Wang Jun’,1870112);
一个单独的insert语句中可使用多个valuse字句,插入多条记录,
如:mysql>insert into  student values
         (‘0322001’, ‘Zhang Liaoyun’, ‘f’ 1971102,’computer’),
         (‘0322002’, ‘Li Ming’, ‘t’ 1971105,’computer’);
   删除记录: DELETE FROM 表名称 WHERE 条件表达式;
   如:mysql>delete from student where sno=’0321002’;
   删除student表中sno字段值前4位为‘0322’的记录
   如:mysql>delete from student where left (sno,4)=’0322’;
   删除所以记录,可以不带where字句
   如:mysql>delete from student;
   删除所以记录可以用命令truncate     删除表,然后重建表,所以比delete命令快
   如:mysql>truncate table student;
   修改记录 UPDATE 表名称 SET 字段名1=字段值1
            WHERE 条件表达式
   如: mysql>update student set sbirthday=1920113, sdepa=’math’ where sno=’0321002’;
 
索引的创建与删除
   在创建表的同时创建索引
   创建表时,可用INDEX字句或UNIQUE(字段值必须惟一)字句创建索引
   如:创建课程表course, 课程编号cno字段为主键,课程名称cname字段创建一个名为can的索引
mysql>create table course(
cno varchar(5) not null,
cname varchar(30) not null,
teacher varchar(20),
primary key (cno),
index can (cname)
);
   向已存在的表添加索引   CREATE [UNIQUE ] INDEX 索引名ON表名称 (字段名1[(长度)])
   如:mysql>create index sna on student (sname);
   对于类型为CHARVARCHAR的字段建立索引时还可指定长度值,类型为BLOBTEXT的字段索引时必须指定长度值。
   mysql>create index sna on student (sname(10));
   删除索引  DROP INDEX 索引 ON表名称;
   如:mysql>drop index sna on student;
 
 
用户的创建和删除
初始化时有5MySQL授权表,其中hosttables_privcolumnts_priv 是空的,表userdb决定了MySQL默认的访问规则。默认有mysqltest两个数据库。
授权表:user  用户从哪些主机可以连接到数据库服务器,以及对所以数据库的访问权限(全局权限)
        db   用户可以使用哪些权限,以及对数据库执行哪些操作(数据库级权限)
        host  当表db 中的host 字段值为空时,用户从哪些主机可以连接到数据库服务器。
        tables_priv  连接的用户可以访问哪些表(表级权限)
        columnts_priv  连接的用户可以访问哪些字段 (字段级权限)
创建新用户
MySQL管理员连接到数据库服务器: #mysql –u root –p
创建新用户guess并设置密码,同时可以从任何主机连接数据库服务器:
mysql>insert into mysql.user (host,user,password)
values (‘%’,’gusee’,password(‘guest’));      使用password()函数,密码是加密的
重载MySQL授权表:mysql>flush privileges;
远程客户端连接数据库服务器 :#mysql –h 192.168.0.50 –u guess –p      开放服务器的TCP断口3306
查看当前用户可用数据库: show database
删除用户
mysql>delete from mysql.user where user=’guest’;
mysql>flush privileges;      重载MySQL授权表
更改用户密码
如:更改guset密码为123456
mysql>update mysql.user set password=password(‘123456’)
      where user =’guset’;
mysql>flush privileges;
或者是 mysql>set password for guset@’%’=password(‘123456’);
 
 
用户权限的设置
   在表userdbhost中,所有字段声明为ENUM(‘N’,’Y’),默认是‘N;
   在表tables_privcolumns_priv中,权限字段声明为SET类型
   修改授权表中的访问权限有两中方法,一是使用 INSERTUPDATEDELETEDML语句,
   另一中是GRANTGRVOKE语句
   使用GRANT语句授权:
   格式如下:
 
   GRANT 权限列表 [(字段列表)] on 数据库名称.表名称
   TO 用户名@域名或IP地址
   [INDETIFIED BY ‘密码值’] [WITH CRANT OPTION];
 
   授权哪个用户能连接,从哪连接
   如:授权用户guest从任意主机连接数据库服务器,并具有完全访问数据库abc的权限。
   Mysql>grant all on abc.* to guset@’%’ identified by ‘guest’
   注意几点:如指定用户不存在,则创建该新用户;
             ‘权限列表’处ALL表示授予全部权限,USAGE表不授予任何权限。
             ‘数据库名称.表名称’处可以使用通配符“*”。如“abc.*”表数据库abc中所有表
               用户名@域名或IP地址设置谁能连,从哪连。用户名 不能用通配符,但可以用‘ ’空字符串,表任何用户;域名或IP地址可以用通配符“%”,使用是用单引号括起来。
 
   授权用户不同级别的访问权限
   如:新建用户tom,能从子网192.168.16.0访问数据库服务器,可以读取数据库xsxk,并能修改表course 中字段teacher的值
   mysql>grant select on xsxd.* to tom@’192.168.16.%’ indentifiend by ‘123456’;
   mysql>grant update(teacher) on xsxd.course to tom@’192.168.16.%’’
   注意几点:数据库名称.表名称 用来设置权限运用的级别,有全局的(*.*,指定数据库的(xsxd.*
             和指定表的(xsxd.student;
             字段列表 设置权限运用中指定的表中的哪些字段,如update(cname,teacher)
             权限列表 指定的权限与权限运行的级别有关,如有写权限(FILEPROCESSRELOADSHUTDOWN)作为管理权限用于全局级别;对于字段级别只能指定SELECTINSERTUPDATEREFERENCES
 
授予用户管理权限的权利
   如:管理员授予拥护admin可以从本地连接数据库服务器,对数据库xsxk具有完全访问权限,并可以
       将拥有的权限赋予其他用户
   mysql>grant all on xsxd.* to admin@localhost indentified by ‘123456’ with grant option;
   其中with grant option 子句表示拥护拥有的权限可以赋予其他用户。
   mysql>qrant select on xsxd.student to bill@localhost;  授予bill用户权限
   mysql>show grants for admin@localhost;   查看用户权限
 
使用REVOKE语句撤权
   格式如下:
   REVOKE 权限列表[(字段列表)] on数据库名称.表名称
   FROM用户名@域名或IP地址
   如:撤消用户admin@localhost 对数据库xsxd的创建、删除数据库及表的权限,不撤消用户赋予其它用户的权限
   mysql>revoke create,drop on xsxd.* from admin@localhost;
   mysql>revoke grant option on xsxd.* from admin@localhost;
 
MySQL的图形化配置
   安装phpMyAdmin:
   tar文件解压到/root目录下  #tar xvzf phpMyAdmin-2.6.4-pll.tat.gz
   将子目录phpMyAdmin-2.6.4-pll 移到Apache Web 站点主目录/var/www/html ,并改名为phpMyAdmin
   #mv phpMyAdmin-2.6.4-pll /var/www/html/phpMyAdmin
 
   配置phpMyAdmin
   配置文件是config.inc.php 在目录/var/www/html/phpMyAdmin
   设置phpMyAdmin URL路径  $cfg[‘PmaAbxoluterUri’] = ‘’;
        默认是空字符串,便于系统测试,实际应用中不是的,如:要将phpMyAdmin程序上传到站点mysql.gdvcp.net phpMyAdmin目录使用,变是如下:
        $cfg[‘PmaAbsoluteUri’] = ‘http://mysql.gdvcp.net/phpMyAdmin’;
   设置MySQL数据库服务器的域名或IP地址   $cfg[‘server’] [$i] [‘host’] = ‘localhost’’;
        $i=1时,对应第一个MySQL服务器,当$i=2时,表第二个MySQL服务器
   设置MySQL端口号    $cfg[‘server’] [$i] [‘port’] = ‘’ ;   默认端口号是 3306
   设置用户验证方式     $cfg[‘server’] [$i] [‘auth_type’] = ‘config’;
        默认是‘config,需要配置文件有可连接到MySQL数据库的用户和密码,还有其它验证方式,如httpcookie
设置可连接MySQL数据库的用户名 $cfg[‘server’] [$i] [‘user’] = ‘root’;  默认是root
设置可连接MySQL数据库的用户密码  $cfg[‘server’] [$i] [‘password’] = ‘111111’;  root密码
设置可管理的数据库名称   $cfg[‘server’] [$i] [‘only_db’] = ‘’;
  默认是空字符串,表示服务器的所有数据库,可指定某个数据库$cfg[‘server’] [$i] [‘only_db’] = ‘abc’;
     配置完毕,输入http://localhost/phpMyAdmin 测试。
  注意:需要有两个rpm php-mysql-4.3.9.6i386.rpmphp-mbstring-4.3.9-3.6.i386.rpm
        编辑/etc/php.ini文件  extension=mysql.so这行加入 extension=mbstring.so 重启httpd服务。
 
配置phpMyAdmin虚拟目录
   如:在安装有ApacheMySQL服务的计算机(域名为mysql.gdvcp.net)上的/var/phpMyadmin目录配置为虚拟目录,且目录名为pma. 步骤如下:
      配置DNS。假设已有’gdvcp.net’的主区域,在该区域的配置文件中加入一条CNAME(别名)记录
       mysql   IN   CNAME  dong.gdvcp.net
      安装phpMyAdmin.配置phpMyAdmin,并将/var/www/html/phpMyAdin目录移动到/var目录中
       #mv /var/www/html/phpMyAdmin /var
      配置phpMyAdmin虚拟目录,修改Apache服务的配置文件/etc/httpd/conf/httpd.conf 加入以下内容
      Alias /pma  “/var/phpMyAdmin”
      <Directory “/var/phpMyAdmin”>
      Option FloolwSymLinks
      AllowOverride none
      AuthType Basic
      AuthName “Please Login”
      AuthUserFile /etc/apachpasswd/userpwd
      Require user root
      Require user mysql
      </Directory>
  建立密码文件并为用户设置密码,如下:
      #mkdir /etc/apachepasswd
      #cd /etc/apacdepasswd
      #htpasswd –c userpwd root   
      htpasswd –c 命令创建密码文件userpwd,同时创建了用户root
      #htpasswd userpwd mysql
      重新启动 httpd 服务
     设置允许Apache守护进程httpd访问phpMyAdmin虚拟目录,如下:
      #chcon –R –h –t httpd_sys_content_t /var/phpMyAdmin
      该命令让httpd可以虚拟目录phpMyAdmin中标记为httpd_sys_content_t的所有文件,然后可以用   ls –laZ查看设置效果
     MySQL中创建用户
      注意MySQL管理员root密码可以和刚才创建用于访问phpMyAdmin虚拟目录的root密码可以相同
      这样在phpMyAdmin的配置文件config.inc.php中可以用config验证方式,并输入root用户和密码,如下:
      $cfg[‘server’] [$i] [‘auth_type’] = ‘config’;
      $cfg[‘server’] [$i] [‘user’] = ‘root’;
      $cfg[‘server’] [$i] [‘password’] = ‘111111’;
      为了使刚才用于访问phpMyAdimn虚拟目录的用户mysql也能使用phpMyAdmin访问MySQL数据库,具有浏览所有数据库的权限,如下:
      mysql>grant select on *.* to mysql@localhost identified by ‘123456’;
      这样,如果平时使用mysql用户通过phpMyAdmin来浏览数据库,可在config.ini.php 中如下修改:
      $cfg[‘server’] [$i] [‘auth_type’] = ‘config’;
      $cfg[‘server’] [$i] [‘user’] = ‘mysal’;
      $cfg[‘server’] [$i] [‘password’] = ‘123456’;
     访问phpMyAdmin虚拟目录 http://mysql.gdvcp.net/pma/