一、mysql的安装
在http://dev.mysql.com/downloads/mysql/4.0.html 下载MySQL 4.0的rpm文件。找到Linux x86 RPM downloads一栏,一般你只需要Server (standard)、Client、Shared、和devel四个rpm就够了。我们把这四个rpm文件下载到/root目录下。
  注:以下指令需要root权限。
  在安装之前,请先用一下指令判断一下你的系统中是否已经安装了Mysql的rpm:
  shell>rpm -qa | grep "*mysql*"
  如果显示有相关mysql的rpm已经安装在你系统上的话,建议先删除这些rpm:
  shell>rpm -e RPM_FILE_NAME
  如果出现dependency的问题,可用rpm -e --force --nodeps RPM_FILE_NAME来强行删除。
  确保所有关于mysql的rpm都删除后,我们开始安装MySQL 4.0。在/root目录下,ls一下显示所有的rpm文件,你应该找到刚才download下来的四个mysql rpm。开始安装:
  shell>rpm -i MySQL-server-4.0.18-0.i386.rpm
  shell>rpm -i MySQL-shared-4.0.18-0.i386.rpm
  shell>rpm -i MySQL-client-4.0.18-0.i386.rpm
  shell>rpm -i MySQL-devel-4.0.18-0.i386.rpm
  注:如果在上面的安装过程中出现错误信息,试试看调换一下上面指令的顺序。
  成功安装后,MySQL的mysqladmin等文件将会存放在/usr/bin目录下。并且一个mysql文件会添加到你的/etc/init.d目录下,这个文件是用来每次系统reboot后自动启动mysql service的。你可以用service mysql start, service mysql restart, service mysql stop来启动、重启、或终止mysql service。用chkconfig -list指令查找一下mysql service是否被加到了service列表中,如果没有,用以下指令添加mysql service:
  shell>chkconfig --add mysql
  注:如果你发现你的系统不认识chkconfig这个命令,你可以试着打/sbin/chkconfig看看。
  注:安装mysql rpm后,它会自动安装mysql 内建的database (mysql和test)。
  安装mysql后,用
  shell>mysqladmin –uroot password YOUR_NEW_PASSWORD
  重新设定root用户mysql的密码,比如,doodoofish。
  shell>mysqladmin -uroot password doodoofish
  下次,你必须用root和doodoofish作为用户名和密码使用mysql:
  shell>mysql -uroot -pdoodoofish
  在提示后,输入doodoofish密码,你应该能够进入mysql。
  注:输入\q可退出mysql。
  这还不算完。为了你的安全,我建议执行一下指令来保护你的mysql:
  shell>mysql -uroot -pdoodoofish
  mysql> use mysql
  mysql> delete from user where not (host="localhost" and user="root");
  mysql> flush priviledges;
  这样将强迫用户用root账号来登陆mysql。
  最好把root改成一个不容易猜到的名字,比如:
  mysql> update user set user="sqladmin" where user="root";
  mysql> flush priviledges;


二、 Mysql 的使用:
mysql创建一个新的用户betty,密码设为goodluck
> grant select,update,delete on *.* to betty@\”%\” indentified by “goodluck”;  在任何主机都可以登陆
>grant select,update,delete on *.* to betty@”localhost” indentified by “goodluck”;  只能在本机才可以登陆。

mysql登录:假设在mysql所在的数据库在:10.250.6.28上,有一个用户betty,已经授权在任何主机上都可以登录。、
a。 从本机登录 mysql -ubetty -pgoodluck
b. 从其他的主机登录:mysql -h10.250.6.28 -ubetty -pgoodluck
若当时创建betty用户的时候并没有授权在任何主机登录,则不能使用b登录方法。

登陆数据库后便可以进行数据库的常用操作了:
假设我们想要创建一个数据库bettydb,里面创建一个表class,包含两个字段,同学的id号跟姓名
1.创建数据库
create databases bettydb;

2.创建表class
use bettydb;
create table class(id int(5),name varchar(20));

3. 往已经建好的表里插入记录,有两种方式,一种是直接手动插入,另一种是从外面导入:
a. 手动插入:insert into class values(1,’wangbing’);
b.若有很多条记录,我们可以将其写到一个txt文件中,不同字段之间以tab相隔,然后执行命令
load data local infile “filename” into table class;
c.从其他数据库导出的表中导入数据
mysql < all-databases.sql(导入数据库)
mysql>source news.sql;(在mysql命令下执行,可导入表)

4、删除数据库或表
drop databases bettydb;
drop talbes class;

5. 修改表结构,包括加入字段,修改字段,删除字段 全部使用关键字alter
加入字段
alter table class add column age varchar(2) after name; 注意要加上类型的
修改字段的类型:
alter table class change age student_age int(10);  注意即使只修改名称或类型,红色部分都要全部写清楚,包括修改后的名称和类型。
删除字段:
alter table class drop column student_age;


6.第五部分是对表的宏观的操作,这一部分将讲解对插入数据的操作,使用关键字update
修改其中某记录某个字段的值:
update table class set name=”wangkun” where id=1;
删除记录:
delete from class where id=1;
 
三,数据库的导入与导出 
导出: 
使用select into outfile 'filename'语句 
使用mysqldump实用程序 
使用select into outfile 'filename'语句 
1.只能处理单个表,输出文件只有数据,没有表结构 
我们要将office,其中有一个表为personal,现在要把personal卸成文本文件out.txt: 
>use office; 
>select * from personal into outfile 'out.txt'; 可以看在/var/lib/mysql/office/目录下有out.txt 
select * from personal into outfile './out.txt'; 可以看在out.txt 在/var/lib/mysql/目录下用out.txt 
2.使用mysqldump实用程序(可以轻松处理多个表) 
# cd /var/lib/mysql 
导出建立相关表的建表命令和插入指令 
# mysqldump bbs >bbs.sql 将数据库bbs导入到bbs.sql中 
如果要将bbs.sql导入数据库可以使用: 
mysql> create database bbstest; 先建立一个名为office 的数据库. 
# mysql bbstest bbscreate.sql 
只想导出插入数据的sql指令: 
# mysqldump -t bbs >bbsinsert.sql 
同时导出数据库中建表指令和表中的数据: 
# mysqldump -T./ bbs cdb_admingroups (其中./表示当前目录,cdb_admingroups为bbs数据库其中的一个表) 
#ls 
cdb_admingroups.sql 导出了建表指令 
cdb_admingroups.txt 导出了表中的数据 
导入: 
从文件中加载数据库: 
mysql>load data infile "/tmp/name.txt" into table names; 
mysql>select * from names; 
您正在看的MySQL教程是:MySQL数据库学习笔记。
  MySQL数据库学习笔记 
(实验环境:Redhat9.0,MySQL3.23.54) 
纲要: 
一,连接MySQL 
二,MySQL管理与授权 
三,数据库简单操作 
四, 数据库备份 
五,后记 
一,连接MySQL 
格式:mysql -h 远程主机地址 -u 用户名 -p 回车 
输入密码进入: 
mysql -u root -p 回车 
Enter password: ,输入密码就可以进入 
mysql> 进入了 
退出命令:>exit 或者ctrl+D 
二,MySQL管理与授权 
1.修改密码: 
格式:mysqladmin -u 用户名 -p 旧密码 password 新密码 
2.增加新用户: 
>grant create,select,update....(授予相关的操作权限) 
->on 数据库.* 
-> to 用户名@登录主机 identified by '密码' 
操作实例: 
给root用户添加密码: 
# mysqladmin -u root password 52netseek 
因为开始root没有密码,所以-p旧密码一项可以省略. 
登陆测试: 
# mysql -u root -p 回车 
输入密码,成功登陆. 
将原有的mysql管理登陆密码52netseek改为52china. 
# mysqladmin -u root -p 52netseek password '52china' 
创建数据库添加用户并授予相应的权限: 
mysql> create database phpbb; 
Query OK, 1 row affected (0.02 sec) 
mysql> use phpbb; 
Database changed 
mysql> grant create,select,update,insert,delete,alter 
-> on phpbb.* 
-> to phpbbroot@localhost identified by '52netseek'; 
Query OK, 0 rows affected (0.00 sec) 
授予所有的权限: 
>grant all privileges 
>on bbs.* 
>to bbsroot@localhost identified by '52netseek' 
回收权限: 
revoke create,select,update,insert,delete,alter 
on phpbb.* 
from phpbbroot@localhost identified by '52netseek'; 
完全将phpbbroot这个用户删除: 
>use mysql 
>delete from user 
where user='phpbbroot' and host='localhost'; 
>flush privileges; 刷新数据库 
三,数据库简单操作 
1.显示数据库列表: 
>show databases; 
mysql 
test 
2.使其成为当前操作数据库 
>use mysql; 打开数据库. 
>show tables; 显示mysql数据库中的数据表. 
3.显示数据表的表结构: 
>describe 表名; 
>describe user; 显示user表的表结构: 
4.创建数据库,建表 
>create database 数据库名; 
>use 数据库名; 
>create table 表名(字段设定列表) 
5.删除数据库,册除表 
>drop database 数据库名; 
>drop table 表名; 
6.显示表中的记录; 
select * from 表名; 
7.修改数据库结构: 
增加字段: 
alter table dbname add column  
修改字段: 
alter table dbname change   
删除字段: 
alter table dbname drop column  
实例操作: 
>create database office; 
>use office; 
mysql> create table personal( 
-> member_no char(5) not null, 
-> name char(, 
-> birthday date, 
-> exam_score tinyint, 
-> primary key(member_no) 
-> ); 
Query OK, 0 rows affected (0.01 sec) 
>desc personal; 显示表结构: 
+------------+------------+------+-----+---------+-------+ 
| Field | Type | Null | Key | Default | Extra | 
+------------+------------+------+-----+---------+-------+ 
| member_no | char(5) | | PRI | | | 
| name | char( | YES | | NULL | | 
| birthday | date | YES | | NULL | | 
| exam_score | tinyint(4) | YES | | NULL | | 
+------------+------------+------+-----+---------+-------+ 
4 rows in set (0.00 sec) 
insert into personal values ('001','netseek','1983-03-15','95'); 
insert into personal values ('002','heihei','1982-02-24','90'); 
insert into personal values ('003','gogo','1985-05-21','85'); 
insert into personal values ('004','haha','1984-02-25','84'); 
insert into personal values ('005','linlin','1982-04-28','85'); 

您正在看的MySQL教程是:MySQL数据库学习笔记。 insert into personal values ('006','xinxin','1985-03-15','75'); 
mysql> select * from personal; 
+-----------+---------+------------+------------+ 
| member_no | name | birthday | exam_score | 
+-----------+---------+------------+------------+ 
| 001 | netseek | 1983-03-15 | 95 | 
| 002 | heihei | 1982-02-24 | 90 | 
| 003 | gogo | 1985-05-21 | 85 | 
| 004 | haha | 1984-02-25 | 84 | 
| 005 | linlin | 1982-04-28 | 85 | 
| 006 | xinxin | 1985-03-15 | 75 | 
+-----------+---------+------------+------------+ 
修改数据库表: 
要求: 在birthday这后增加一个为height的字段,数据类型为tinyint. 
将字段exam_score 改名为scores,数据类型不变 
>alter table personal 
->add column height tinyint after birthday, 
->change column exam_score scores tinyint; 
mysql> select * from personal; 
+-----------+---------+------------+--------+--------+ 
| member_no | name | birthday | height | scores | 
+-----------+---------+------------+--------+--------+ 
| 001 | netseek | 1983-03-15 | NULL | 95 | 
| 002 | heihei | 1982-02-24 | NULL | 90 | 
| 003 | gogo | 1985-05-21 | NULL | 85 | 
| 004 | haha | 1984-02-25 | NULL | 84 | 
| 005 | linlin | 1982-04-28 | NULL | 85 | 
| 006 | xinxin | 1985-03-15 | NULL | 75 | 
+-----------+---------+------------+--------+--------+ 
给表中插入数据: 
>update personal set scores=95+5 where name='netseek'; 
>select scores from personal where name='netseek'; 
+--------+ 
| scores | 
+--------+ 
| 100 | 
+--------+ 
删除表名字为'gogo'所有的信息中的的: 
> delete from personal where name='gogo'; 
册除数据库中的表: 
mysql>drop table if exists personal; 
三,数据库的导入与导出 
导出: 
使用select into outfile 'filename'语句 
使用mysqldump实用程序 
使用select into outfile 'filename'语句 
1.只能处理单个表,输出文件只有数据,没有表结构 
我们要将office,其中有一个表为personal,现在要把personal卸成文本文件out.txt: 
>use office; 
>select * from personal into outfile 'out.txt'; 可以看在/var/lib/mysql/office/目录下有out.txt 
select * from personal into outfile './out.txt'; 可以看在out.txt 在/var/lib/mysql/目录下用out.txt 
2.使用mysqldump实用程序(可以轻松处理多个表) 
# cd /var/lib/mysql 
导出建立相关表的建表命令和插入指令 
# mysqldump bbs >bbs.sql 将数据库bbs导入到bbs.sql中 
如果要将bbs.sql导入数据库可以使用: 
mysql> create database bbstest; 先建立一个名为office 的数据库. 
# mysql bbstest bbscreate.sql 
只想导出插入数据的sql指令: 
# mysqldump -t bbs >bbsinsert.sql 
同时导出数据库中建表指令和表中的数据: 
# mysqldump -T./ bbs cdb_admingroups (其中./表示当前目录,cdb_admingroups为bbs数据库其中的一个表) 
#ls 
cdb_admingroups.sql 导出了建表指令 
cdb_admingroups.txt 导出了表中的数据 
导入: 
从文件中加载数据库: 
mysql>load data infile "/tmp/name.txt" into table names; 
mysql>select * from names; 
四,数据库备份 
1.手动拷贝备份: 
MySQL数据库的文件保存在目录/var/lib/mysql中,数据库为每个库建立一个目录,所有的数据库文件都在这些目录中. 
[root@linuxhero mysql]#ls 
[root@linuxhero mysql]#servcie mysqld stop 先停止数据库
bbs mysql mysql.sock phpbb test office 显示其中的数据库. 
如果我们要将现在的数据库目录备份为mysql.bak . 
[root@linuxhero lib]# cp -rf mysql mysql.bak 
如果数据库遭到了破坏,现在要将数据库恢复: 
[root@linuxhero lib]# cp -rf mysql.bak/* mysql 
恢复数据库以后,var/lib/mysql中的文件已改变了,要更改文件的所属权限必须改变MySQL数据库的用户读写权限。 
所以我们得启动和运行mysql,并登陆数据库: 
[root@linuxhero lib]# /etc/init.d/mysqld start 
[root@linuxhero lib]# mysql 

您正在看的MySQL教程是:MySQL数据库学习笔记。-u root -p 
Enter password:输入密码成功登陆. 
mysql> show databses; 
2.利用mysqldump来备份数据库 
[root@linuxhero mysql]# mysqldump --opt bbs -u root -p > bbs.sql 
Enter password: 
注:--opt添加备份的其它选项,bb为其中一个数据库名, 
上面的意思是:使用重定向输出将备份写入到文件bb.sql中. 
[root@linuxhero mysql] #less bbs.sql 
如果要恢复bb这个数据库,则进行如下操作: 
[root@linuxhero mysql] #mysql bbs -u root -p mysql.bak 
Enetr password:输入密码即可 
恢复所有数据库,不用输入数据库的名字: 
[root@linuxhero mysql] #mysql -u root -p