文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

MySQL数据导入导出(用于个人学习与回顾)

2024-04-02 19:55

关注

该实例将练习MySQL的导入导出操作


实例:

  1. 将/etc/passwd文件导入userdb库user表并给每条记录加编号

  2. 将userdb库user表中UID小于100的前10条记录导出,存为/mydata/user1.txt文件


mysql> create database userdb;
Query OK, 1 row affected (0.00 sec)
mysql> use userdb;
Database changed
mysql> create table user(
    -> username varchar(24) not null,
    -> password varchar(48) default 'x',
    -> uid int(5) not null,
    -> gid int(5) not null,
    -> fullname varchar(48),
    -> homedir varchar(64) not null,
    -> shell varchar(24) not null
    -> );
Query OK, 0 rows affected (0.01 sec)
mysql> desc user;
+----------+-------------+------+-----+---------+-------+
| Field    | Type        | Null | Key | Default | Extra |
+----------+-------------+------+-----+---------+-------+
| username | varchar(24) | NO   |     | NULL    |       |
| password | varchar(48) | YES  |     | x       |       |
| uid      | int(5)      | NO   |     | NULL    |       |
| gid      | int(5)      | NO   |     | NULL    |       |
| fullname | varchar(48) | YES  |     | NULL    |       |
| homedir  | varchar(64) | NO   |     | NULL    |       |
| shell    | varchar(24) | NO   |     | NULL    |       |
+----------+-------------+------+-----+---------+-------+
7 rows in set (0.01 sec)


mysql> load data infile '/etc/passwd' into table user fields terminated by ':';
ERROR 1290 (HY000): The MySQL server is running with the --secure-file-priv option so it cannot execute this statement
mysql> show variables like '%secure%';
+--------------------------+-----------------------+
| Variable_name            | Value                 |
+--------------------------+-----------------------+
| require_secure_transport | OFF                   |
| secure_auth              | ON                    |
| secure_file_priv         | /var/lib/mysql-files/ |
+--------------------------+-----------------------+
3 rows in set (0.00 sec)

-将/etc/passwd文件复制到/var/lib/mysql-files/目录下,

-读取/var/lib/mysql-files/passwd文件内容,以“:”为分隔,导入到user表中:

[root@host50 ~]#cp /etc/passwd /var/lib/mysql-files/
mysql> LOAD DATA INFILE '/var/lib/mysql-files/passwd'
-> INTO TABLE user
-> FIELDS TERMINATED BY ':';
Query OK, 42 rows affected (0.11 sec)
Records: 42  Deleted: 0  Skipped: 0  Warnings: 0

注:上述操作中省略了行分隔 LINES TERMINATED BY '\n',因为这是默认的情况(每行一条原始记录),除非需要以其他字符分割行,才需要用到这个。


mysql> select count(*) from user;
+----------+
| count(*) |
+----------+
|       42 |
+----------+
1 row in set (0.00 sec)

mysql> select * from user limit 10;
+----------+----------+-----+-----+----------+-----------------+----------------+
| username | password | uid | gid | fullname | homedir         | shell          |
+----------+----------+-----+-----+----------+-----------------+----------------+
| root     | x        |   0 |   0 | root     | /root           | /bin/bash      |
| bin      | x        |   1 |   1 | bin      | /bin            | /sbin/nologin  |
| daemon   | x        |   2 |   2 | daemon   | /sbin           | /sbin/nologin  |
| adm      | x        |   3 |   4 | adm      | /var/adm        | /sbin/nologin  |
| lp       | x        |   4 |   7 | lp       | /var/spool/lpd  | /sbin/nologin  |
| sync     | x        |   5 |   0 | sync     | /sbin           | /bin/sync      |
| shutdown | x        |   6 |   0 | shutdown | /sbin           | /sbin/shutdown |
| halt     | x        |   7 |   0 | halt     | /sbin           | /sbin/halt     |
| mail     | x        |   8 |  12 | mail     | /var/spool/mail | /sbin/nologin  |
| operator | x        |  11 |   0 | operator | /root           | /sbin/nologin  |
+----------+----------+-----+-----+----------+-----------------+----------------+
10 rows in set (0.00 sec)
mysql> alter table user add sn int(4) auto_increment primary key first;
Query OK, 0 rows affected (0.03 sec)
Records: 0  Duplicates: 0  Warnings: 0

mysql> select * from user limit 10;
+----+----------+----------+-----+-----+----------+-----------------+----------------+
| sn | username | password | uid | gid | fullname | homedir         | shell          |
+----+----------+----------+-----+-----+----------+-----------------+----------------+
|  1 | root     | x        |   0 |   0 | root     | /root           | /bin/bash      |
|  2 | bin      | x        |   1 |   1 | bin      | /bin            | /sbin/nologin  |
|  3 | daemon   | x        |   2 |   2 | daemon   | /sbin           | /sbin/nologin  |
|  4 | adm      | x        |   3 |   4 | adm      | /var/adm        | /sbin/nologin  |
|  5 | lp       | x        |   4 |   7 | lp       | /var/spool/lpd  | /sbin/nologin  |
|  6 | sync     | x        |   5 |   0 | sync     | /sbin           | /bin/sync      |
|  7 | shutdown | x        |   6 |   0 | shutdown | /sbin           | /sbin/shutdown |
|  8 | halt     | x        |   7 |   0 | halt     | /sbin           | /sbin/halt     |
|  9 | mail     | x        |   8 |  12 | mail     | /var/spool/mail | /sbin/nologin  |
| 10 | operator | x        |  11 |   0 | operator | /root           | /sbin/nologin  |
+----+----------+----------+-----+-----+----------+-----------------+----------------+
10 rows in set (0.00 sec)

         -以将userdb库user表中UID小于100的前10条记录导出为/myload/user2.txt文件为例

       首先,修改配置文件中存放导出导入目录及查看修改结果

[root@host50 ~]# mkdir  /myload  ;  chown  mysql  /myload
[root@host50 ~]# vim  /etc/my.cnf
[mysqld]
secure_file_priv="/myload"
[root@dbsvr1 ~]# systemctl  restart mysqld
mysql> show variables like "secure_file_priv";
+------------------+----------+
| Variable_name    | Value       |
+------------------+----------+
| secure_file_priv   | /myload/ |

      导出user表中UID小于100的前十条记录

mysql> select * from userdb.user where uid<100
    -> into outfile '/myload/user.txt'
    -> fields terminated by ":";
Query OK, 26 rows affected (0.00 sec)

      确认导出结果

[root@host50 ~]# wc -l /myload/user.txt
26 /myload/user.txt
[root@host50 ~]# tail /myload/user.txt 
25:tss:x:59:59:Account used by the trousers package to sandbox the tcsd daemon:/dev/null:/sbin/nologin
29:rpcuser:x:29:29:RPC Service User:/var/lib/nfs:/sbin/nologin
33:gdm:x:42:42::/var/lib/gdm:/sbin/nologin
35:sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin
36:avahi:x:70:70:Avahi mDNS/DNS-SD Stack:/var/run/avahi-daemon:/sbin/nologin
37:postfix:x:89:89::/var/spool/postfix:/sbin/nologin
38:ntp:x:38:38::/etc/ntp:/sbin/nologin
39:tcpdump:x:72:72::/:/sbin/nologin
41:apache:x:48:48:Apache:/usr/share/httpd:/sbin/nologin
42:mysql:x:27:27:MySQL Server:/var/lib/mysql:/bin/false











阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯