Chinaunix首页 | 论坛 | 博客
  • 博客访问: 713277
  • 博文数量: 98
  • 博客积分: 3145
  • 博客等级: 中校
  • 技术积分: 1902
  • 用 户 组: 普通用户
  • 注册时间: 2008-12-15 12:52
文章分类
文章存档

2021年(1)

2020年(1)

2016年(8)

2015年(3)

2014年(1)

2013年(5)

2012年(4)

2011年(9)

2010年(12)

2009年(42)

2008年(12)

我的朋友

分类: Mysql/postgreSQL

2009-03-18 14:28:52

mysql常用操作
1.进入mysql
#mysql -u用户名 -p用户密码
可选参数:
-s mysqlsocktid
-p端口
2.针对数据库操作
mysql>show databases; 显示所有登陆用户能操作的数据库
mysql>use 数据库名; 使用数据库
mysql>create database; 数据库名;创建数据库
mysql>exit; 退出数据库
mysql>select * from 表名;查看数据库表结构
myslq>create table 表名(表结构);创建数据库表(注意要先使用要创建表的数据库)
mysql>
3.针对用户操作
修改密码:
方1:
#mysqladmin -u root -p oldpassword newpasswd
方2:
mysql>INSERT INTO mysql.user (Host,User,Password) VALUES
  ('%','system', PASSWORD('manager'));
mysql> FLUSH PRIVILEGES;  
添加了一个用户名为system的用户,密码为manager;
方3:
mysql>SET PASSWORD FOR " = PASSWORD('manager');  
方4:
mysql> REPLACE INTO mysql.user (Host,User,Password)
VALUES('%','system',PASSWORD('manager'));
mysql> FLUSH PRIVILEGES;
方5:
mysql> GRANT USAGE ON *.* TO " IDENTIFIED BY 'manager';
用户授权
方1:
mysql>GRANT ALL PRIVILEGES ON *.* TO IDENTIFIED BY
  'manager' WITH GRANT OPTION;   将mysql中所有数据库操作权限给新创建用户system密码为manger,连接方式为本地
方2:
mysql>INSERT INTO user
  VALUES('localhost','system',PASSWORD('manager'),
  'Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y');
权限 表列名称 相应解释 使用范围
select  Select_priv 只有在真正从一个表中检索时才需要select权限 表
insert  Insert_priv 允许您把新行插入到一个存在的表中 表
update  Update_priv 允许你用新值更新现存表中行的列 表
delete  Delete_priv 允许你删除满足条件的行 表
create  Create_priv 允许你创建新的数据库和表 数据库、表或索引
drop  Drop_priv 抛弃(删除)现存的数据库和表 数据库或表
reload  Reload_priv 允许您告诉服务器再读入授权表 服务器管理
shutdown  Shutdown_priv 可能被滥用(通过终止服务器拒绝为其他用户服务) 服务器管理
process  Process_priv 允许您察看当前执行的查询的普通文本,包括设定或改变口令查询 服务器管理
file  File_priv 权限可以被滥用在服务器上读取任何可读的文件到数据库表 服务器上的文件存取
grant  Grant_priv 允许你把你自己拥有的那些权限授给其他的用户 数据库或表
references  References_priv 允许你打开和关闭记录文件 数据库或表
index  Index_priv 允许你创建或抛弃(删除)索引 表
alter  Alter_priv 允许您改变表格,可以用于通过重新命名表来推翻权限系统 表  
如果创建用户时只有select、insert、update和delete权限,则允许用户只能在一个数据库现有的表上实施操作
忘记root用户处理办法
方法一
1   下载MySQL源码分发包,不用区分操作系统,我们需要的东西是一样的;
2   重命名自己的mysql的data目录下的mysql文件夹为oldmysql;
3   将源码包中data目录下的mysql目录复制到你的mysql的data目录下;
4   重新启动mysql,现在mysql的授权关系同全新安装的一样,空密码登陆,然后自行调整授权;
5   打开oldmysql这个库检查到底出现了什么问题 ;
6   如果有备份对系统中原有的数据库进行完整性检测,以免被人修改。
方法二
1. 向mysqld server发送kill命令关掉mysqld server(不是 kill -9),存放进程ID的文件通常在MYSQL的数据库所在的目录中。
      kill `cat /mysql-data-directory/hostname.pid`,你必须是Linux的root用户或者是你所运行的SERVER上的同等用户,才能执行这个操作;
#killall -TERM mysqld
2. 使用`--skip-grant-tables’ 参数来启动 mysqld;
#mysqld_safe --skip-grant-tables &
#/ bin/safe_mysqld --skip-grant-tables &
3. 使用`mysql -h hostname mysql’命令登录到mysqld server ,用grant命令改变口令。你也可以这样做:
`mysqladmin -h hostname -u user password ’new password’’。其实也可以用
use mysql; update user set password =password(’yourpass’) where user=’root’ 来做到;
#mysqladmin -u root flush-privileges password "newpassword"
mysql>use mysql
mysql>update user set password=password("new_pass") where user="root";
mysql>flush privileges;
4.针对debian APT安装的mysql
cat /etc/mysql/my.cnf
用显示的用户和密码登陆,再重置密码
4.载入权限表:`mysqladmin -h hostname flush-privileges’ ,或者使用 SQL 命令`FLUSH PRIVILEGES’。当然,在这里,你也可以重启mysqld。
数据库导入导出
1.用语句导出
使用select into outfile "filename"语句
  可以在mysql的命令行下或在php程序中执行它。我下面以在mysql命令行下为例。在php中使用时,将其改成相应的查询进行处理即可。不过在使用这个命令时,要求用户拥有file的权限。如我们有一个库为phptest,其中有一个表为driver。现在要把driver卸成文件。执行命令:
  mysql> use phptest;
  Database Changed
  mysql> select * from driver into outfile "a.txt";
  Query OK, 22 rows affected (0.05 sec)
  上面就可以完成将表driver从数据库中卸到a.txt文件中。注意文件名要加单引号。那么这个文件在哪呢?在mysql目录下有一个 data目录,它即是数据库文件所放的地方。每个库在单独占一个子目录,所以phptest的目录为c:\mysql\data\phptest(注意:我的mysql安装在c:\mysql下)。好,现在我们进去,a.txt就是它。打开这个文件,可能是:
  1 Mika Hakinnen 1
  2 David Coulthard 1
  3 Michael Schumacher 2
  4 Rubens Barrichello 2
  ...
可能还有很多记录。每个字段之间是用制表符分开的(\t)。那么我们可以修改输出文件名的目录,以便放在指定的位置。如"a.txt"可以改成"./a.txt"或"/a.txt"。其中"./a.txt"放在c:\mysql\data目录下了,
而"/a.txt"文件则放在c:\目录下了。所以select命令认为的当前目录是数据库的存放目录,这里是
c:\mysql\data。
  使用select命令还可以指定卸出文件时,字段之间的分隔字符,转义字符,包括字符,及记录行分隔字符。列在下面:
  FIELDS
  TERMINATED BY "\t"
  [OPTIONALLY] ENCLOSED BY ""
  ESCAPED BY "\\"
  LINES
  TERMINATED BY "\n"
  TERMINATED 表示字段分隔
  [OPTIONALLY] ENCLOSED 表示字段用什么字符包括起来,如果使用了OPTIONALLY则只有CHAR和VERCHAR被包括ESCAPED 表示当需要转义时用什么作为转义字符LINES TERMINATED 表示每行记录之间用什么分隔
  上面列的是缺省值,而且这些项都是可选的,不选则使用缺省值。可以根据需要进行修改。给出一个例子如下:
  mysql> select * from driver into outfile "a.txt" fields terminated by "," enclosed by """;
  Query OK, 22 rows affected (0.06 sec)
  结果可能如下:
  "1","Mika","Hakinnen","1"
  "2","David","Coulthard","1"
  "3","Michael","Schumacher","2"
  "4","Rubens","Barrichello","2"
  ...
  可以看到每个字段都用","进行了分隔,且每个字段都用"""包括了起来。注意,行记录分隔符可以是一个字符串,请大家自行测试。不过,如果输出文件在指定目录下如果存在的话就会报错,先删除再测试即可。
2.用mysqldump导出
  从上面的select方法可以看出,输出的文件只有数据,而没有表结构。而且,一次只能处理一个表,要处理多个表则不是很容易的。不过可以将select命令写入一个sql 文件(复制文本应该是很容易的吧),然后在命令行下执行即可:mysql 库名
  先来个最简单的吧:
mysqldump phptest > a.sql
  可能结果如下:
  # MySQL dump 7.1
  #
  # Host: localhost Database: phptest
  #--------------------------------------------------------
  # Server version 3.22.32-shareware-debug
  #
  # Table structure for table "driver"
  #
  CREATE TABLE driver (
  drv_id int(11) DEFAULT "0" NOT NULL auto_increment,
  drv_forename varchar(15) DEFAULT "" NOT NULL,
  drv_surname varchar(25) DEFAULT "" NOT NULL,
  drv_team int(11) DEFAULT "0" NOT NULL,
  PRIMARY KEY (drv_id)
  );
  #
  # Dumping data for table "driver"
  #
  INSERT INTO driver VALUES (1,"Mika","Hakinnen",1);
  INSERT INTO driver VALUES (2,"David","Coulthard",1);
  INSERT INTO driver VALUES (3,"Michael","Schumacher",2);
  INSERT INTO driver VALUES (4,"Rubens","Barrichello",2);
  ...
  如果有多表,则分别列在下面。可以看到这个文件是一个完整的sql文件,如果要将其导入到其它的数据库中可以通过命令行方式,很方便:mysql phptest < a.sql。如果将数据从本地传到服务器上,则可以将这个文件上传,然后在服务器通过命令行方式装入数据。
  如果只想卸出建表指令,则命令如下:
  mysqldump -d phptest > a.sql
  如果只想卸出插入数据的sql命令,而不需要建表命令,则命令如下:
  mysqldump -t phptest > a.sql
  那么如果我只想要数据,而不想要什么sql命令时,应该如何操作呢?
  mysqldump -T./ phptest driver
  其中,只有指定了-T参数才可以卸出纯文本文件,表示卸出数据的目录,./表示当前目录,即与
mysqldump同一目录。如果不指定driver表,则将卸出整个数据库的数据。每个表会生成两个文件,一个为.sql文件,包含建表执行。另一个为.txt文件,只包含数据,且没有sql指令。
  对卸出的数据文件,也可以同select方法一样,指定字段分隔符,包括字符,转义字段,行记录分隔符。参数列在下面:
  --fields-terminated-by= 字段分隔符
  --fields-enclosed-by= 字段包括符
  --fields-optionally-enclosed-by= 字段包括符,只用在CHAR和VERCHAR字段上
  --fields-escaped-by= 转义字符
  --lines-terminated-by= 行记录分隔符
我想大家应该明白这些参数的意思了吧。一个例子如下:
  mysqldump -T./ --fields-terminated-by=, --fields-enclosed-by=\" phptest driver
  输出结果为:
  "1","Mika","Hakinnen","1"
  "2","David","Coulthard","1"
  "3","Michael","Schumacher","2"
  "4","Rubens","Barrichello","2"
  ...
  请注意字符的使用。
导入
  同导出相类似,导入也有两种方法:
  1)使用LOAD DATA INFILE "filename"命令
  2)使用mysqlimport实用程序
  3)使用sql文件
  由于前两个处理与导出处理相似,只不过是它们的逆操作,故只给出几种命令使用的例子,不再解释了,大家可以自行查阅手册。
  使用load命令:
  load data infile "driver.txt" into table driver fields terminated by "," enclosed by """;
  使用mysqlimport实用程序:
  mysqlimport --fields-terminated-by=, --fields-enclosed-by=\" phptest driver.txt
  对于第三种,则可以使用由mysqldump导出的sql文件,在命令行下执行: mysq  l库名
1.MySQLimport的语法介绍:
  MySQLimport位于MySQL/bin目录中,是MySQL的一个载入(或者说导入)数据的一个非常有效的工具。这是一个命令行工具。有两个参数以及大量的选项可供选择。这个工具把一个文本文件(text file)导入到你指定的数据库和表中。比方说我们要从文件Customers.txt中把数据导入到数据库Meet_A_Geek中的表 Custermers中:
  MySQLimport Meet_A_Geek Customers.txt
  注意:这里Customers.txt是我们要导入数据的文本文件,而Meet_A_Geek是我们要操作的数据库,数据库中的表名是Customers,这里文本文件的数据格式必须与Customers表中的记录格式一致,否则MySQLimport命令将会出错。
  其中表的名字是导入文件的第一个句号(.)前面文件字符串,另外一个例子:MySQLimport Meet_A_Geek Cus.to.mers.txt
  那么我们将把文件中的内容导入到数据库Meet_A_Geek 中的Cus表中。
  上面的例子中,都只用到两个参数,并没有用到更多的选项,下面介绍MySQLimport的选项
2.MySQLimport的常用选项介绍:
  选项 功能
  -d or --delete 新数据导入数据表中之前删除数据数据表中的所有信息
  -f or --force 不管是否遇到错误,MySQLimport将强制继续插入数据
  -i or --ignore MySQLimport跳过或者忽略那些有相同唯一关键字的行, 导入文件中的数据将被忽略。
  -l or -lock-tables 数据被插入之前锁住表,这样就防止了,你在更新数据库时,用户的查询和更新受到影响。
  -r or -replace 这个选项与-i选项的作用相反;此选项将替代表中有相同唯一关键字的记录。
  --fields-enclosed- by= char 指定文本文件中数据的记录时以什么括起的, 很多情况下数据以双引号括起。 默认的情况下数据是没有被字符括起的。
  --fields-terminated- by=char 指定各个数据的值之间的分隔符,在句号分隔的文件中,分隔符是句号。您可以用此选项指定数据之间的分隔符。
  默认的分隔符是跳格符(Tab)
  --lines-terminated- by=str 此选项指定文本文件中行与行之间数据的分隔字符串或者字符。 默认的情况下MySQLimport以newline为行分隔符。
  您可以选择用一个字符串来替代一个单个的字符:
  一个新行或者一个回车。
  MySQLimport命令常用的选项还有-v 显示版本(version),-p 提示输入密码(password)等。
3.例子:导入一个以逗号为分隔符的文件
  文件中行的记录格式是这样的:
  "1", "ORD89876", "1 Dozen Roses", "19991226"
  我们的任务是要把这个文件里面的数据导入到数据库Meet_A_Geek中的表格Orders中,我们使用这个命令:
  bin/MySQLimport –prl –fields-enclosed-by=" –fields-terminated-by=, Meet_A_Geek Orders.txt
  这个命令可能看起来很不爽,不过当你熟悉了之后,这是非常简单的。第一部分,bin/MySQLimport ,告诉操作系统你要运行的命令是MySQL/bin目录下的MySQLimport,选项p是要求输入密码,这样就要求你在改动数据库之前输入密码,操作起来会更安全。我们用了r选项是因为我们想要把表中的唯一关键字与文件记录中有重复唯一关键字的记录替换成文件中的数据。我们表单中的数据不是最新的,需要用文件中的数据去更新,因而就用r这个选项,替代数据库中已经有的记录。l选项的作用是在我们插入数据的时候锁住表,这样就阻止了用户在我们更新表的时候对表进行查询或者更改的操作。
批处理是一种非交互式运行MySQL程序的方法,如同您在MySQL中使用的命令一样,你仍然将使用这些命令。
  为了实现批处理,您重定向一个文件到MySQL程序中,首先我们需要一个文本文件,这个文本文件包含有与我们在MySQL中输入的命令相同的文本。
  比如我们要插入一些数据,使用包含下面文本的文件(文件名为New_Data.sql,当然我们也可以取名为New_Data.txt及任何其他的合法名字,并不一定要以后缀sql结尾):
  USE Meet_A_Geek;
  INSERT INTO Customers (Customer_ID, Last_Name) VALUES(NULL, "Block");
  INSERT INTO Customers (Customer_ID, Last_Name) VALUES(NULL, "Newton");
  INSERT INTO Customers (Customer_ID, Last_Name) VALUES(NULL, "Simmons");
  注意上面的这些句子的语法都必须是正确的,并且每个句子以分号结束。
  上面的USE命令选择数据库,INSERT命令插入数据。
  下面我们要把上面的文件导入到数据库中,导入之前要确认数据库已经在运行,即是MySQLd进程(或者说服务,Windows NT下面称为”服务“,unix下面为”进程“)已经在运行。
  然后运行下面的命令:
  bin/MySQL –p < /home/mark/New_Data.sql
  接着按提示输入密码,如果上面的文件中的语句没有错误,那么这些数据就被导入到了数据库中。
  命令行中使用LOAD DATA INFILE 从文件中导入数据到数据库:
  现在您可能会问自己,"究竟为什么我要输入所有的这些SQL语句到文件中,然后通过程序运行它们呢?”
这样看起来好像需要大量的工作。很好,你这样想很可能就对了。但是假如你有从所有这些命令中产生的log记录呢?现在这样就很棒,嗯,大多数数据库都会自动产生数据库中的事件记录的 log。而大部分log都包含有用过的原始的SQL命令。因此,如果您不能从您现在的数据库中导出数据到新的MySQL数据库中使用,那么您可以使用 log和MySQL的批处理特性,来快速且方便地导入您地数据。当然,这样就省去了打字的麻烦。
  LOAD DATA INFILE
  这是我们要介绍的最后一个导入数据到MySQL数据库中的方法。这个命令与MySQLimport非常相似,但这个方法可以在MySQL命令行中使用。也就是说您可以在所有使用API的程序中使用这个命令。使用这种方法,您就可以在应用程序中导入您想要导入的数据。
  使用这个命令之前,MySQLd进程(服务)必须已经在运行。
  启动MySQL命令行:
  bin/MySQL –p
  按提示输入密码,成功进入MySQL命令行之后,输入下面的命令:
  USE Meet_A_Geek;
  LOAD DATA INFILE "/home/mark/data.sql" INTO TABLE Orders;
  简单的讲,这样将会把文件data.sql中的内容导入到表Orders中,如MySQLimport工具一样,这个命令也有一些可以选择的参数。比如您需要把自己的电脑上的数据导入到远程的数据库服务器中,您可以使用下面的命令:
  LOAD DATA LOCAL INFILE "C:\MyDocs\SQL.txt" INTO TABLE Orders;
上面的LOCAL参数表示文件是本地的文件,服务器是您所登陆的服务器。
  这样就省去了使用ftp来上传文件到服务器,MySQL替你完成了.
  您也可以设置插入语句的优先级,如果您要把它标记为低优先级(LOW_PRIORITY),那么MySQL将会等到没有其他人读这个表的时候,才把插入数据。可以使用如下的命令:
  LOAD DATA LOW_PRIORITY INFILE "/home/mark/data.sql" INTO TABLE Orders;
  您也可以指定是否在插入数据的时候,取代或者忽略文件与数据表中重复的键值。替代重复的键值的语法:
  LOAD DATA LOW_PRIORITY INFILE "/home/mark/data.sql" REPLACE INTO TABLE Orders;
  上面的句子看起来有点笨拙,但却把关键字放在了让您的剖析器可以理解的地方。
  下面的一对选项描述了文件的记录格式,这些选项也是在MySQLimport工具中可以用的。他们在这里看起来有点不同。首先,要用到FIELDS关键字,如果用到这个关键字,MySQL剖析器希望看到至少有下面的一个选项:
  TERMINATED BY character
  ENCLOSED BY character
  ESCAPED BY caracter
  这些关键字与它们的参数跟MySQLimport中的用法是一样的. The
  TERMINATED BY 描述字段的分隔符,默认情况下是tab字符(\t)
  ENCLOSED BY描述的是字段的括起字符。比方以引号括起每一个字段。
  ESCAPED BY 描述的转义字符。默认的是反些杠(backslash:\ ).
  下面仍然使用前面的MySQLimport命令的例子,用LOAD DATA INFILE语句把同样的文件导入到数据库中:
  LOAD DATA INFILE "/home/mark/Orders.txt" REPLACE INTO TABLE Orders FIELDS TERMINATED BY ','   ENCLOSED BY '"';
  LOAD DATA INFILE语句中有一个MySQLimport工具中没有特点:
  LOAD DATA INFILE 可以按指定的列把文件导入到数据库中。
  当我们要把数据的一部分内容导入的时候,这个特点就很重要。比方说,我们要从Access数据库升级到MySQL数据库的时候,需要加入一些栏目(列/字段/field)到MySQL数据库中,以适应一些额外的需要。
  这个时候,我们的Access数据库中的数据仍然是可用的,但是因为这些数据的栏目(field)与MySQL中的不再匹配,因此而无法再使用 MySQLimport工具。尽管如此,我们仍然可以使用LOAD DATA INFILE,下面的例子显示了如何向指定的栏目(field)中导入数据:
  LOAD DATA INFILE "/home/Order.txt" INTO TABLE Orders(Order_Number, Order_Date, Customer_ID);
  如您所见,我们可以指定需要的栏目(fields)。这些指定的字段依然是以括号括起,由逗号分隔的,如果您遗漏了其中任何一个,MySQL将会提醒您^_^
  Importing Data from Microsoft Access (从Access中导入数据,略)
  您可以看到MySQL有很多可以导入数据的方法,然而这些只是数据传输中的一半。另外的一般是从MySQL数据库中导出数据。有许多的原因我们需要导出数据。一个重要的原因是用于备份数据库。数据的造价常常是昂贵的,需要谨慎处理它们。经常地备份可以帮助防止宝贵数据地丢失;另外一个原因是,也许您希望导出数据来共享。 在这个信息技术不断成长的世界中,共享数据变得越来越常见。
  比方说Macmillan USA维护护着一个将要出版的书籍的大型数据库。这个数据库在许多书店之间共享,这样他们就知道哪些书将会很快出版。医院越来越走向采用无纸病历记录,这样这些病历可以随时跟着你。世界变得越来越小,信息也被共享得越来越多。有很多中导出数据得方法,它们都跟导入数据很相似。因为,毕竟,这些都只是一种透视得方式。从数据库导出的数据就是从另一端导入的数据。这里我们并不讨论其他的数据库各种各样的导出数据的方法,您将学会如何用MySQL来实现数据导出。
备份
因为MySQL表作为文件存储,做一个备份是容易的。为了得到一个一致的备份,在相关的表上做一个LOCK TABLES。你只需一个读锁定;当你在数据库目录中做文件的一个拷贝时,这允许其他线程继续查询该表。如果你想要做一个SQL级的备份,你可以SELECT INTO OUTFILE。
备份一个数据库的另一个方法是使用mysqldump程序:
为你的数据库做一个完整的备份:
shell> mysqldump --tab=/path/to/some/dir --opt --full你也可以简单地拷贝所有的表文件(“*.frm”、“*.MYD”和“*.MYI”文件),只要服务器不在更新任何东西。(frame,data,index)
停止mysqld如果它正在运行,然后以--log-update选项启动它。你将得到一个名为“hostname.n”形式的日志文件, 这里n是随着你每次执行mysqladmin refresh或mysqladmin flush-logs、FLUSH LOGS语句、或重启服务器而递增的一个数字。这些日志文件向你提供了在你执行mysqldump处后面进行的复制数据库改变的所需信息。
如果你必须恢复一些东西,尝试首先用myisamchk -r恢复你的表。这应该处理所有情况的99.9%。如果myisamchk失败,尝试下列过程:
恢复原来的mysqldump备份。
执行下列命令以再次运行更新日志中的更改:
shell> ls -1 -t -r hostname.[0-9]* | xargs cat | mysqlls被用来以正确的顺序得到所有的日志文件。
你也可以与SELECT * INTO OUTFILE 'file_name' FROM tbl_name做有选择的备份并且用LOAD DATA INFILE 'file_name' REPLACE ...恢复。为了避免重复记录,在表中你需要一个PRIMARY KEY或UNIQUE键。当在唯一键值上一个新记录与一个老记录重复时,REPLACE关键词使得老记录用一个新记录替代。
使用MySQLdump:
  MySQLdump工具很多方面类似相反作用的工具MySQLimport。它们有一些同样的选项。但MySQLdump能够做更多的事情。它可以把整个数据库装载到一个单独的文本文件中。这个文件包含有所有重建您的数据库所需要的SQL命令。这个命令取得所有的模式(Schema,后面有解释)并且将其转换成DDL语法(CREATE语句,即数据库定义语句),取得所有的数据,并且从这些数据中创建INSERT语句。这个工具将您的数据库中所有的设计倒转。因为所有的东西都被包含到了一个文本文件中。这个文本文件可以用一个简单的批处理和一个合适SQL语句导回到MySQL中。这个工具令人难以置信地简单而快速。决不会有半点让人头疼地地方。
  因此,如果您像装载整个数据库Meet_A_Geek的内容到一个文件中,可以使用下面的命令:
  bin/MySQLdump –p Meet_A_Geek > MeetAGeek_Dump_File.txt
  这个语句也允许您指定一个表进行dump(备份/导出/装载?)。如果您只是希望把数据库Meet_A_Geek中的表Orders中的整个内容导出到一个文件,可以使用下面的命令:
  bin/MySQLdump –p Meet_A_Geek Orders >MeetAGeek_Orders.txt
  这个非常的灵活,您甚至可以使用WHERE从句来选择您需要的记录导出到文件中。要达到这样的目的,可以使用类似于下面的命令:
  bin/MySQLdump –p –where="Order_ID > 2000" Meet_A_Geek Orders > Special_Dump.txt
  MySQLdump工具有大量的选项,部分选项如下表:
  选项/Option 作用/Action Performed
  --add-drop-table
  这个选项将会在每一个表的前面加上DROP TABLE IF EXISTS语句,这样可以保证导回MySQL数据库的时候不会出错,因为每次导回的时候,都会首先检查表是否存在,存在就删除
  --add-locks
  这个选项会在INSERT语句中捆上一个LOCK TABLE和UNLOCK TABLE语句。这就防止在这些记录被再次导入数据库时其他用户对表进行的操作
  -c or - complete_insert
  这个选项使得MySQLdump命令给每一个产生INSERT语句加上列(field)的名字。当把数据导出导另外一个数据库时这个选项很有用。
  --delayed-insert 在INSERT命令中加入DELAY选项
  -F or -flush-logs 使用这个选项,在执行导出之前将会刷新MySQL服务器的log.
  -f or -force 使用这个选项,即使有错误发生,仍然继续导出
  --full 这个选项把附加信息也加到CREATE TABLE的语句中
  -l or -lock-tables 使用这个选项,导出表的时候服务器将会给表加锁。
  -t or -no-create- info
  这个选项使的MySQLdump命令不创建CREATE TABLE语句,这个选项在您只需要数据而不需要DDL(数据库定义语句)时很方便。
  -d or -no-data 这个选项使的MySQLdump命令不创建INSERT语句。
  在您只需要DDL语句时,可以使用这个选项。
  --opt 此选项将打开所有会提高文件导出速度和创造一个可以更快导入的文件的选项。
  -q or -quick 这个选项使得MySQL不会把整个导出的内容读入内存再执行导出,而是在读到的时候就写入导文件中。
  -T path or -tab = path 这个选项将会创建两个文件,一个文件包含DDL语句或者表创建语句,另一个文件包含数据。DDL文件被命名为table_name.sql,数据文件被命名为table_name.txt.路径名是存放这两个文件的目录。目录必须已经存在,并且命令的使用者有对文件的特权。
  -w "WHERE Clause" or -where = "Where clause "
  如前面所讲的,您可以使用这一选项来过筛选将要放到导出文件的数据。
  假定您需要为一个表单中要用到的帐号建立一个文件,经理要看今年(2004年)所有的订单(Orders),它们并不对DDL感兴趣,并且需要文件有逗号分隔,因为这样就很容易导入到Excel中。 为了完成这个人物,您可以使用下面的句子:
  bin/MySQLdump –p –where "Order_Date >='2000-01-01'"
  –tab = /home/mark –no-create-info –fields-terminated-by=, Meet_A_Geek Orders
  这将会得到您想要的结果。
  schema:模式The set of statements, expressed in data definition language, that completely describe the structure of a data base.
  一组以数据定义语言来表达的语句集,该语句集完整地描述了数据库的结构。
SELECT INTO OUTFILE :
  如果您觉得MySQLdump工具不够酷,就使用SELECT INTO OUTFILE吧, MySQL同样提供一个跟LOAD DATA INFILE命令有相反作用的命令,这就是SELECT INTO OUTFILE 命令,这两个命令有很多的相似之处。首先,它们有所有的选项几乎相同。现在您需要完成前面用MySQLdump完成的功能,可以依照下面的步骤进行操作:
  1. 确保MySQLd进程(服务)已经在运行
  2. cd /usr/local/MySQL
  3. bin/MySQLadmin ping ;// 如果这个句子通不过,可以用这个:MySQLadmin -u root -p ping
MySQLadmin ping用于检测MySQLd的状态,is alive说明正在运行,出错则可能需要用户名和密码。
  4. 启动MySQL 监听程序.
  5. bin/MySQL –p Meet_A_Geek;// 进入MySQL命令行,并且打开数据库Meet_A_Geek,需要输入密码
  6. 在命令行中,输入一下命令:
  SELECT * INTO OUTFILE '/home/mark/Orders.txt'
  FIELDS
  TERMINATED BY = ','
  FROM Orders
  WHERE Order_Date >= '2000-01-01'
  在你按了Return(回车)之后,文件就创建了。这个句子就像一个规则的SELECT语句,只是把想屏幕的输出重定向到了文件中。这意味这您可以使用JOIN来实现多表的高级查询。这个特点也可以被用作一个报表产生器。
  比方说,您可以组合这一章中讨论的方法来产生一个非常有趣的查询,试试这个:
  在MySQL目录建立一个名为Report_G.rpt 的文本文件,加入下面的行:
  USE Meet_A_Geek;
  INSERT INTO Customers (Customer_ID, Last_Name, First_Name)
  VALUES (NULL, "Kinnard", "Vicky");
  INSERT INTO Customers (Customer_ID, Last_Name, First_Name)
  VALUES (NULL, "Kinnard", "Steven");
  INSERT INTO Customers (Customer_ID, Last_Name, First_Name)
  VALUES (NULL, "Brown", "Sam");
  SELECT Last_Name INTO OUTFILE '/home/mark/Report.rpt'
  FROM Customers WHERE Customer_ID > 1;
  然后确认 MySQL进程在运行,并且您在MySQL目录中, 输入下面的命令:
  bin/MySQL < Report_G.rpt检查您命名作为输出的文件,这个文件将会包含所有您在Customers表中输入的顾客的姓。 如您所见,您可以使用今天学到的导入/导出(import/export)的方法来帮助得到报表。
阅读(1557) | 评论(1) | 转发(0) |
给主人留下些什么吧!~~

chinaunix网友2009-07-31 10:49:02

喜欢你.........的笔记。因此你补缺了我的另一份,谢谢!