一、表的复制

    1、语法格式

            create  table  表名  select  查询命令;

    2、示例

# 假设userinfo已存在,包含username,password,uid字段
1、复制userinfo表中的全部记录,userinfo2
create table userinfo2 select * from userinfo;
2复制userinfo表中username,password,uid三个字段的第2-10条记录,userinfo3
create table userinfo3 select username,password,uid from userinfo limit 1,9;

    3、复制表结构

where  false;

    4、注意

            复制表的时候不会把原有表的key属性复制过来

二、数据导入

    1、作用

            把文件系统内容导入到数据的表中

    2、命令格式(mysql交互)

            load data infile "文件名"
            into table 表名
            fileds terminated by "分隔符"
            lines terminated by "\n"

    3、示例

            把 /etc/passwd 文件中的内容导入到db2库下的userinfo表。

passwd文件数据分析:
hilqiqi0 :   x  :      1000 :  1000 :   hilqiqi0,,, :  /home/hilqiqi0 :    /bin/bash
用户名      密码    UID号   GID号  用户描述      用户主目录             登录权限

    4、操作步骤

        a、在数据库中创建对应的表
create table userinfo(
username char(20),
password char(1),
uid int,
gid int,
comment varchar(50),
homedir varchar(50),
shell varchar(50)
);
        b、将要导入的文件拷贝到数据库的默认搜索路径中

                1)查看数据库的默认搜索路径
                        show variables like "%secure_file_priv%";
                            默认:/var/lib/mysql-files/
                2)Linux命令行输入:
                        sudo cp /etc/passwd /var/lib/mysql-files/

        c、执行数据导入语句
load  data  infile  "/var/lib/mysql-files/passwd"
into  table  userinfo  
fields  terminated  by  ":"
lines  terminated  by  "\n";

三、数据导出

    1、作用

            将数据库表中的记录保存到系统文件里


    2、语法格式

            select  ...  from  表名


            into  outfile  “文件名”


            fields  terminated  by  “分隔符”


            lines  terminated  by “\n”;


    3、示例

            把userinfo表中的username、password和uid导出到文件user.txt


select username,password,uid from userinfo
into outfile "/var/lib/mysql-files/user.txt"
fields terminated by ","
lines terminated by "\n";

    4、注意

            导出的内容有SQL查询语句决定


            执行导出命令时

路径必须指定对应的数据库搜索路径


四、数据备

        mysqldump,在Linux终端中操作

  1、命令格式

        mysqldump -u用户名 -p 源库名 > 路径/XXX.sql

  2、源库名的表示方式

        --all-databases   备份所有库
        库名              备份单个库
        -B 库1 库2 ...    备份多个库
        库名 表1 表2 ...  备份指定表

  3、示例

0、备份db2库
mysqldump -uroot -p db2 > db2.sql
1、备份所有库为 all.sql , /home/tarena/mydata/
mysqldump -uroot -p --all-databases > all.sql
2、备份MOSHOU库中 sheng、city、xian三张表 MOSHOUscx.sql
mysqldump -uroot -p MOSHOU sheng city xian > MOSHOUscx.sql
3、备份2个库
mysqldump -uroot -p -B MOSHOU db4 > MSdb4.sql

五、数据恢复

    1、命令格式

            mysql  -u用户名  -p  目标库名  <  路径/xxx.sql


    2、示例

            a、先备份库


                    mysqldump -uroot -p db2 > db2.sql;


            b、删除库


                    drop database db2;


            c、先创建空库


                    create database db2 default charset=utf8;


            d、恢复命令


                    mysql -uroot -p da2 < db2.sql;


    3、两种备份

            完全备份:mysqldump


            增量备份:binlog日志、xbackup工具


    4、从所有库的备份文件中恢复某一个库(--one-database)

        mysql  -u用户名  -p  --one-database  目标库名  <  所有备份.sql


                eg:mysql -uroot -p --one-database db2 < all.sql


    5、注意

            

恢复库时,库中新增的表不会删除

            恢复时必须先创建空库