一、mysql 的管理
1
、连接
Mysql
格式: mysql -h主机地址 -u用户名 -p用户密码
例1:连接到本机上的MYSQL。
首先在打开DOS窗口,然后进入目录 mysqlbin,再键入命令mysql -uroot -p,回车后提示你输密码,如果刚安装好MYSQL,超级用户root是没有密码的,故直接回车即可进入到MYSQL中了,MYSQL的提示符是:mysql>
例2:连接到远程主机上的MYSQL。假设远程主机的IP为:110.110.110.110,用户名为root,密码为abcd123。则键入以下命令:
mysql -h110.110.110.110 -uroot -pabcd123
(注:u与root可以不用加空格,其它也一样)
mysql -h110.110.110.110 -uroot -pabcd123
(注:u与root可以不用加空格,其它也一样)
2
、退出MYSQL命令: exit (回车)
3
、
修改密码
格式:mysqladmin -u用户名 -p旧密码 password 新密码
1) mysqladmin -u用户名 -p旧密码 password 新密码
例:mysqladmin -u root password 21century
注:因为开始时root没有密码,所以-p旧密码一项就可以省略了。
2)直接修改user表的root用户口令:
mysql> user mysql;
mysql> update user set pasword=password('21century') where user='root';
mysql> flush privileges;
注:flush privileges的意思是强制刷新内存授权表,否则用的还是缓冲中的口令。
例:mysqladmin -u root password 21century
注:因为开始时root没有密码,所以-p旧密码一项就可以省略了。
2)直接修改user表的root用户口令:
mysql> user mysql;
mysql> update user set pasword=password('21century') where user='root';
mysql> flush privileges;
注:flush privileges的意思是强制刷新内存授权表,否则用的还是缓冲中的口令。
4
、测试密码是否修改成功
1)不用密码登录
[root@test1 local]# mysql
ERROR 1045: Access denied for user: 'root@localhost' (Using password: NO)
显示错误,说明密码已经修改。
2)用修改后的密码登录
[root@test1 local]# mysql -u root -p
Enter password: (输入修改后的密码21century)
Welcome to the MySQL monitor. Commands end with ; or /g.
Your MySQL connection id is 177 to server version: 3.23.48
Type 'help;' or '/h' for help. Type '/c' to clear the buffer.
mysql>
成功!
这是通过mysqladmin命令修改口令,也可通过修改库来更改口令
1)不用密码登录
[root@test1 local]# mysql
ERROR 1045: Access denied for user: 'root@localhost' (Using password: NO)
显示错误,说明密码已经修改。
2)用修改后的密码登录
[root@test1 local]# mysql -u root -p
Enter password: (输入修改后的密码21century)
Welcome to the MySQL monitor. Commands end with ; or /g.
Your MySQL connection id is 177 to server version: 3.23.48
Type 'help;' or '/h' for help. Type '/c' to clear the buffer.
mysql>
成功!
这是通过mysqladmin命令修改口令,也可通过修改库来更改口令
5、
增加新用户
(注意:和上面不同,下面的因为是MYSQL环境中的命令,所以后面都带一个分号作为命令结束符)
格式:grant select on 数据库.* to 用户名@登录主机 identified by "密码"
例1、增加一个用户test1密码为abc,让他可以在任何主机上登录,并对所有数据库有查询、插入、修改、删除的权限。首先用以root用户连入MYSQL,然后键入以下命令:
grant select,insert,update,delete on *.* to test1@"%但例1增加的用户是十分危险的,你想如某个人知道test1的密码,那么他就可以在internet上的任何一台电脑上登录你的mysql数据库并对你的数据可以为所欲为了,解决办法见例2。" Identified by "abc";
grant select,insert,update,delete on *.* to test1@"%但例1增加的用户是十分危险的,你想如某个人知道test1的密码,那么他就可以在internet上的任何一台电脑上登录你的mysql数据库并对你的数据可以为所欲为了,解决办法见例2。" Identified by "abc";
例2、增加一个用户test2密码为abc,让他只可以在localhost上登录,并可以对数据库mydb进行查询、插入、修改、删除的操作(localhost指本地主机,即MYSQL数据库所在的那台主机),这样用户即使用知道test2的密码,他也无法从internet上直接访问数据库,只能通过MYSQL主机上的web页来访问了。
grant select,insert,update,delete on mydb.* to test2@localhost identified by "abc";
如果你不想test2有密码,可以再打一个命令将密码消掉。
grant select,insert,update,delete on mydb.* to test2@localhost identified by "";
如果你不想test2有密码,可以再打一个命令将密码消掉。
grant select,insert,update,delete on mydb.* to test2@localhost identified by "";
6
、
Mysql
的启动和停止
启动:Mysql从3.23.15版本开始作了改动,默认安装后服务要用mysql用户来启动,不允许root用户启动。
如果非要用root用户来启动,必须加上--user=root参数
(./safe_mysqld --user=root &)
停止: mysqladmin -u root -p shutdown
如果非要用root用户来启动,必须加上--user=root参数
(./safe_mysqld --user=root &)
停止: mysqladmin -u root -p shutdown
7
、只需本机使用
Mysql
服务,在启动时还可以加上--skip-networking参数使Mysql不监听任何TCP/IP连接
(./safe_mysqld --skip-networking &),增加安全性。(非常推荐)
8 、忘记 root 密码怎么办?
在启动Mysql服务器时加上参数--skip-grant-tables来跳过授权表的验证
(./safe_mysqld --skip-grant-tables &),这样我们就可以直接登陆Mysql服务器,
然后再修改root用户的口令,重启Mysql就可以用新口令登陆了。
9、操作技巧1、如果你打命令时,回车后发现忘记加分号,你无须重打一遍命令,只要打个分号回车就可以了。也就是说你可以把一个完整的命令分成几行来打,完后用分号作结束标志就OK。
2、你可以使用光标上下键调出以前的命令。但以前我用过的一个MYSQL旧版本不支持。我现在用的是mysql-3.23.27-beta-win。
(./safe_mysqld --skip-networking &),增加安全性。(非常推荐)
8 、忘记 root 密码怎么办?
在启动Mysql服务器时加上参数--skip-grant-tables来跳过授权表的验证
(./safe_mysqld --skip-grant-tables &),这样我们就可以直接登陆Mysql服务器,
然后再修改root用户的口令,重启Mysql就可以用新口令登陆了。
9、操作技巧1、如果你打命令时,回车后发现忘记加分号,你无须重打一遍命令,只要打个分号回车就可以了。也就是说你可以把一个完整的命令分成几行来打,完后用分号作结束标志就OK。
2、你可以使用光标上下键调出以前的命令。但以前我用过的一个MYSQL旧版本不支持。我现在用的是mysql-3.23.27-beta-win。
二、
Mysql
数据库操作
1
、、创建数据库
命令:
create database <数据库名>
例如:建立一个名为xhkdb的数据库
mysql>
create
database xhkdb;
2
、显示所有的数据库
命令:
show databases (注意:最后有个s)
mysql>
show databases;
刚开始时才两个数据库:mysql和test。mysql库很重要它里面有MYSQL的系统信息,我们改密码和新增用户,实际上就是用这个库进行操作。
3
、删除数据库
命令:
drop database <数据库名>
例如:删除名为 xhkdb的数据库
mysql>
drop
database xhkdb;
4
、连接数据库
命令:
use数据库名> <
例如:如果xhkdb数据库存在,尝试存取它:
mysql>
use xhkdb;
屏幕提示:Database changed
5
、当前选择(连接)的数据库
mysql>
select database();
6
、当前数据库包含的表信息:
mysql>
show tables; (注意:最后有个s)
7
、备份数据库:
>
mysqldump --opt school>school.txt
注释:将数据库school备份到school.txt文件,school.txt是一个文本文件,文件名任取,打开看看你会有新发现。
三、
Mysql
表操作,操作之前应连接某个数据库
1
、建表
命令:
create table <表名> ( <字段名1> <类型1> [,..<字段名n> <类型n>]);
例如,建立一个名为MyClass的表,
字段名
|
数字类型
|
数据宽度
|
是否为空
|
是否主键
|
自动增加
|
默认值
|
id
|
int
|
4
|
否
|
primary key
|
auto_increment
|
|
name
|
char
|
20
|
否
|
|
|
|
sex
|
int
|
4
|
否
|
|
|
0
|
degree
|
double
|
16
|
是
|
|
|
|
mysql> create table MyClass(
> id int(4) not null
primary key auto_increment,
> name char(20) not null,
> sex int(4) not null
default '0',
> degree double(16,2));
2
、获取表结构
命令:
desc 表名,或者show columns from 表名
mysql>
desc MyClass;
mysql>
show columns from MyClass;
3
、删除表
命令:
drop table <表名>
例如:删除表名为 MyClass 的表
mysql>
drop
table MyClass;
4
、插入数据
命令:
insert into <表名> [( <字段名1>[,..<字段名n > ])]
values ( 值1 )[, ( 值n )]
例如,往表 MyClass中插入二条记录, 这二条记录表示:编号为1的名为Tom的成绩为96.45, 编号为2 的名为Joan 的成绩为82.99, 编号为3 的名为Wang 的成绩为96.5.
mysql>
insert
into MyClass
values(1,'Tom',96.45),(2,'Joan',82.99), (2,'Wang', 96.59);
5
、查询表中的数据
1)、查询所有行
命令:
select字段1,字段2,...> from < 表名 > where < 表达式 > <
例如:查看表 MyClass 中所有数据
mysql> select * from MyClass;
2)、查询前几行数据
例如:查看表 MyClass 中前2行数据
mysql>
select *
from MyClass
order
by id
limit 0,2;
6
、删除表中数据
命令:
delete from 表名
where表达式
例如:删除表 MyClass中编号为1 的记录
mysql>
delete
from MyClass
where id=1;
7
、修改表中数据:
update
表名
set
字段
=
新值
,… where
条件
mysql>
update MyClass
set name='Mary'
where id=1;
8
、在表中增加字段:
命令:
alter table 表名
add字段 类型 其他;
例如:在表MyClass中添加了一个字段passtest,类型为int(4),默认值为0
mysql>
alter table MyClass
add passtest
int(4
) default '0'
9
、更改表名:
命令:
rename table 原表名
to新表名;
例如:在表MyClass名字更改为YouClass
mysql>
rename table MyClass
to YouClass;
10
、字段类型
1.INT[(M)] 型: 正常大小整数类型
2.DOUBLE[(M,D)] [ZEROFILL] 型: 正常大小(双精密)浮点数字类型
3.DATE 日期类型:支持的范围是1000-01-01到9999-12-31。MySQL以YYYY-MM-DD格式来显示DATE值,但是允许你使用字符串或数字把值赋给DATE列
4.CHAR(M) 型:定长字符串类型,当存储时,总是是用空格填满右边到指定的长度
5.BLOB TEXT类型,最大长度为65535(2^16-1)个字符。
6.VARCHAR型:变长字符串类型
11
、给表改名
RENAME TABLE ztemp TO ztemp4;
12 、修改字段属性 Alter TABLE bbabase CHANGE news_id id VARCHAR(5) NOT NULL;
13、在表中的content后增加一字段 Alter TABLE bbabase ADD leave_time DATETIME NOT NULL AFTER content;
14、将文本数据转到表中(转入之前确保表存在,且字段个数和类型符合)
RENAME TABLE ztemp TO ztemp4;
12 、修改字段属性 Alter TABLE bbabase CHANGE news_id id VARCHAR(5) NOT NULL;
13、在表中的content后增加一字段 Alter TABLE bbabase ADD leave_time DATETIME NOT NULL AFTER content;
14、将文本数据转到表中(转入之前确保表存在,且字段个数和类型符合)
1、文本数据应符合的格式:字段数据之间用tab键隔开,null值用/n来代替. 例:
1 rose二中 1976-10-10
2 mike一中 1975-12-23
2、数据传入命令 load data local infile "文件名" into table 表名;
四、一个建库和建表以及插入数据的实例
drop database if exists school; //
如果存在SCHOOL则删除
create database school; //建立库SCHOOL
use school; //打开库SCHOOL
create table teacher //建立表TEACHER
(
id int(3) auto_increment not null primary key,
name char(10) not null,
address varchar(50) default '深圳',
year date
); //建表结束
//以下为插入字段
insert into teacher values('','glchengang','深圳一中','1976-10-10');
insert into teacher values('','jack','深圳一中','1975-12-23');
create database school; //建立库SCHOOL
use school; //打开库SCHOOL
create table teacher //建立表TEACHER
(
id int(3) auto_increment not null primary key,
name char(10) not null,
address varchar(50) default '深圳',
year date
); //建表结束
//以下为插入字段
insert into teacher values('','glchengang','深圳一中','1976-10-10');
insert into teacher values('','jack','深圳一中','1975-12-23');
注:在建表中(1)将ID设为长度为3的数字字段:int(3)并让它每个记录自动加一:auto_increment并不能为空:not null而且让他成为主字段primary key
(2)将NAME设为长度为10的字符字段
(3)将ADDRESS设为长度50的字符字段,而且缺省值为深圳。varchar和char有什么区别呢,只有等以后的文章再说了。
(4)将YEAR设为日期字段。
(2)将NAME设为长度为10的字符字段
(3)将ADDRESS设为长度50的字符字段,而且缺省值为深圳。varchar和char有什么区别呢,只有等以后的文章再说了。
(4)将YEAR设为日期字段。
如果你在mysql提示符键入上面的命令也可以,但不方便调试。你可以将以上命令原样写入一个文本文件中假设为school.sql,然后复制到c:/下,并在DOS状态进入目录/mysql/bin,然后键入以下命令:
mysql -uroot -p密码 < c:/school.sql
如果成功,空出一行无任何显示;如有错误,会有提示。(以上命令已经调试,你只要将//的注释去掉即可使用)。
mysql -uroot -p密码 < c:/school.sql
如果成功,空出一行无任何显示;如有错误,会有提示。(以上命令已经调试,你只要将//的注释去掉即可使用)。
五、
Mysql
的备份
1
、
使用
mysqldump
进行
Mysql
备份
1.1
、
mysqldump
命令
mysql
数据库导出要用到
MySQL
的
mysqldump
工具,基本用法是:
Shell> mysqldump [OPTIONS] database [tables]
|
如果你不给定任何表,整个数据库将被导出。
通过执行
mysqldump --help
,你能得到你
mysqldump
的版本支持的选项表。
注意,如果你运行
mysqldump
没有
--quick
或
--opt
选项,
mysqldump
将在导出结果前装载整个结果集到内存中,如果你正在导出一个大的数据库,这将可能是一个问题。
1.2
、
mysqldump
支持下列选项:
--add-locks
在每个表导出之前增加
LOCK TABLES
并且之后
UNLOCK TABLE
。
(
为了使得更快地插入到
MySQL)
。
--add-drop-table
在每个
create
语句之前增加一个
drop table
。
--allow-keywords
允许创建是关键词的列名字。这由表名前缀于每个列名做到。
-c, --complete-insert
使用完整的
insert
语句
(
用列名字
)
。
-C, --compress
如果客户和服务器均支持压缩,压缩两者间所有的信息。
--delayed
用
Insert DELAYED
命令插入行。
-e, --extended-insert
使用全新多行
Insert
语法。(给出更紧缩并且更快的插入语句)
-#, --debug[=option_string]
跟踪程序的使用
(
为了调试
)
。
--help
显示一条帮助消息并且退出。
LOAD DATA INFILE
--fields-terminated-by=...
--fields-enclosed-by=...
--fields-optionally-enclosed-by=...
--fields-escaped-by=...
--fields-terminated-by=...
这些选择与
-T
选择一起使用,并且有相应的
LOAD DATA INFILE
子句相同的含义。
LOAD DATA INFILE
语法。
-F, --flush-logs
在开始导出前,洗掉在
MySQL
服务器中的日志文件。
-f, --force,
即使我们在一个表导出期间得到一个
SQL
错误,继续。
-h, --host=..
从命名的主机上的
MySQL
服务器导出数据。缺省主机是
localhost
。
-l, --lock-tables.
为开始导出锁定所有表。
-t, --no-create-info
不写入表创建信息
(Create TABLE
语句)
-d, --no-data
不写入表的任何行信息。如果你只想得到一个表的结构的导出,这是很有用的!
--opt
同
--quick --add-drop-table --add-locks --extended-insert --lock-tables
。
应该给你为读入一个
MySQL
服务器的尽可能最快的导出。
-pyour_pass, --password[=your_pass]
与服务器连接时使用的口令。如果你不指定“
=your_pass
”部分,
mysqldump
需要来自终端的口令。
-P port_num, --port=port_num
与一台主机连接时使用的
TCP/IP
端口号。(这用于连接到
localhost
以外的主机,因为它使用
Unix
套接字。)
-q, --quick
不缓冲查询,直接导出至
stdout
;使用
mysql_use_result()
做它。
-S /path/to/socket, --socket=/path/to/socket
与
localhost
连接时(它是缺省主机
)
使用的套接字文件。
-T, --tab=path-to-some-directory
对于每个给定的表,创建一个
table_name.sql
文件,它包含
SQL Create
命令,和一个
table_name.txt
文件,它包含数据。
注意:这只有在
mysqldump
运行在
mysqld
守护进程运行的同一台机器上的时候才工作。
.txt
文件的格式根据
--fields-xxx
和
--lines--xxx
选项来定。
-u user_name, --user=user_name
与服务器连接时,
MySQL
使用的用户名。缺省值是你的
Unix
登录名。
-O var=option, --set-variable var=option
设置一个变量的值。可能的变量被列在下面。
-v, --verbose
冗长模式。打印出程序所做的更多的信息。
-V, --version
打印版本信息并且退出。
-w, --where='where-condition'
只导出被选择了的记录;注意引号是强制的!
"--where=user='jimf'" "-wuserid>1" "-wuserid<1"
1.3
、
最常见的
mysqldump
的一个备份:
虽然
mysqldump
支持的命令有很多,对于大多数人而言,我们只需要使用
-opt
这个命令就已经足够了,为你的数据库做一个完整的备份:
mysqldump --opt database > backup-file.sql
|
但是它对用来自于一个数据库的信息充实另外一个
MySQL
数据库也是有用的:
mysqldump --opt database | mysql --host=remote-host -C database
|
1.4
、使用
mysqldump
导出的文件恢复数据库
由于
mysqldump
导出的是完整的
SQL
语句,所以用
mysql
客户程序很容易就能把数据导入了:
shell> mysqladmin create target_db_name
shell> mysql target_db_name < backup-file.sql
|
就是
shell> mysql
库名
<
文件名
2
、
使用
mysqldump
定时备份数据库的脚本
2.1
、备份脚本
使用脚本每天定期执行数据库备份操作,对每个使用
mysql
数据库的人来说都很有必要,这样的脚本网上有很多,这里摘抄一个朋友的脚本
dbbackup
:
这个脚本每天最多只执行一次,而且只保留最近五天的备份在服务器上。
dbbackup
代码
:
#!/bin/bash
#This is a ShellScript For Auto DB Backup
#Powered by aspbiz
#2004-09
#Setting
#
设置数据库名,数据库登录名,密码,备份路径,日志路径,数据文件位置,以及备份方式
#
默认情况下备份方式是
tar
,还可以是
mysqldump,mysqldotcopy
#
默认情况下,用
root(
空
)
登录
mysql
数据库,备份至
/root/dbxxxxx.tgz
DBName=mysql
DBUser=root
DBPasswd=
BackupPath=/root/
LogFile=/root/db.log
DBPath=/var/lib/mysql/
#BackupMethod=mysqldump
#BackupMethod=mysqlhotcopy
#BackupMethod=tar
#Setting End
NewFile="$BackupPath"db$(date +%y%m%d).tgz
DumpFile="$BackupPath"db$(date +%y%m%d)
OldFile="$BackupPath"db$(date +%y%m%d --date='5 days ago').tgz
echo "-------------------------------------------" >> $LogFile
echo $(date +"%y-%m-%d %H:%M:%S") >> $LogFile
echo "--------------------------" >> $LogFile
#Delete Old File
if [ -f $OldFile ]
then
rm -f $OldFile >> $LogFile 2>&1
echo "[$OldFile]Delete Old File Success!" >> $LogFile
else
echo "[$OldFile]No Old Backup File!" >> $LogFile
fi
if [ -f $NewFile ]
then
echo "[$NewFile]The Backup File is exists,Can't Backup!" >> $LogFile
else
case $BackupMethod in
mysqldump)
if [ -z $DBPasswd ]
then
mysqldump -u $DBUser --opt $DBName > $DumpFile
else
mysqldump -u $DBUser -p$DBPasswd --opt $DBName > $DumpFile
fi
tar czvf $NewFile $DumpFile >> $LogFile 2>&1
echo "[$NewFile]Backup Success!" >> $LogFile
rm -rf $DumpFile
;;
mysqlhotcopy)
rm -rf $DumpFile
mkdir $DumpFile
if [ -z $DBPasswd ]
then
mysqlhotcopy -u $DBUser $DBName $DumpFile >> $LogFile 2>&1
else
mysqlhotcopy -u $DBUser -p $DBPasswd $DBName $DumpFile >>$LogFile 2>&1
fi
tar czvf $NewFile $DumpFile >> $LogFile 2>&1
echo "[$NewFile]Backup Success!" >> $LogFile
rm -rf $DumpFile
;;
*)
/etc/init.d/mysqld stop >/dev/null 2>&1
tar czvf $NewFile $DBPath$DBName >> $LogFile 2>&1
/etc/init.d/mysqld start >/dev/null 2>&1
echo "[$NewFile]Backup Success!" >> $LogFile
;;
esac
fi
echo "-------------------------------------------" >> $LogFile
|
2.2
、放入
crontab
定期执行
dbbackup
假定
dbbackup
在
/root
目录下。我们通过使用
crontab
命令,设置每天
0
点
10
分执行
/root/dbbakup
脚本。
1、
使用
crontab –e
编辑
crontab
2、
在
crontab
中加入:
#back for mysql database
10 0 * * * /root/dbbackup
|
新增:
1)、把远程mysql服务器上的选定表的指定数据导入到本地的文本文件中: [hello@localhost hello]$ mysqldump -hhostname -uusername -p -w "last>'2007-01-01'" dbname tablename > ./filename Enter password: 2)、把远程mysql服务器上的选定数据库的全部数据导入到本地的文本文件中: [hello@localhost hello]$ mysqldump -hhostname -uusername -p dbname > ./filename Enter password: 3)、把远程mysql服务器上的选定表的指定数据导入到服务器的文本文件中(所以在本地不能操作如下): mysql> use dbname; mysql> select fieldname into outfile '/home/hello/a.txt' from tablename where last>"2007-1-1"; ERROR 1045: Access denied for user: 'hello@%' (Using password: YES) mysql> 4)、把远程mysql服务器上的选定表的指定数据导入到本地的文本文件中: [hello@localhost hello]$ mysql -e "select fieldname from tablename where last>'2007-1-1'" -hhostname -uusername -p dbname > ./filename Enter password: |
引用通告地址: http://www.x-boy.com/trackback.asp?tbID=37