§ 导入测试数据


安装完GreatSQL数据库后,如果是用于教学或测试场景,可以导入几个通用的测试数据集,主要有:

  • Employees sample database
  • world sample database
  • Sakila sample database

§ 下载测试数据集压缩包

上述三个测试数据集下载地址分别是:

分别下载到本地,并解压缩到 /tmp/testdb 目录下:

$ ls -l /tmp/testdb

drwxr-xr-x 2  500  500      100 Aug  1 06:06 sakila-db  #<--sakila 测试数据集
-rw------- 1 root root   732290 Aug  1 06:06 sakila-db.tar.gz
drwx------ 4 root root      460 Aug 29 15:33 test_db    #<--employees 测试数据集
-rw------- 1 root root 35607473 Aug 29 15:32 test_db-1.0.7.tar.gz
drwxr-xr-x 2  500  500       60 Aug  1 06:06 world-db   #<--world 测试数据集
-rw------- 1 root root    92916 Aug  1 06:06 world-db.tar.gz
1
2
3
4
5
6
7
8

§ 导入测试数据集

§ 导入employees数据集

employees测试数据文件包中提供了导入方法说明文档 README.md,基本上照着做就行。

在 Linux 终端命令行模式下,执行下面的命令导入测试数据(在这里,采用具有最高权限的root账户导入,所以略过创建测试账户这个环节,下同):

mysql -f < employees.sql
1
查看运行结果
$ mysql -f < employees.sql

...
INFO
CREATING DATABASE STRUCTURE
INFO
storage engine: InnoDB
INFO
LOADING departments
INFO
LOADING employees
INFO
LOADING dept_emp
INFO
LOADING dept_manager
INFO
LOADING titles
INFO
LOADING salaries
data_load_time_diff
00:02:28
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21

导入完成后,连接 GreatSQL 执行下面的 SQL 命令,完成数据校验,确认导入的结果无误:

SOURCE /tmp/testdb/test_db/test_employees_md5.sql;
1
查看运行结果
greatsql> SOURCE /tmp/testdb/test_db/test_employees_md5.sql;
+----------------------+
| INFO                 |
+----------------------+
| TESTING INSTALLATION |
+----------------------+
...
+--------------+------------------+----------------------------------+
| table_name   | expected_records | expected_crc                     |
+--------------+------------------+----------------------------------+
| departments  |                9 | d1af5e170d2d1591d776d5638d71fc5f |
| dept_emp     |           331603 | ccf6fe516f990bdaa49713fc478701b7 |
| dept_manager |               24 | 8720e2f0853ac9096b689c14664f847e |
| employees    |           300024 | 4ec56ab5ba37218d187cf6ab09ce1aa1 |
| salaries     |          2844047 | fd220654e95aea1b169624ffe3fca934 |
| titles       |           443308 | bfa016c472df68e70a03facafa1bc0a8 |
+--------------+------------------+----------------------------------+
...
+--------------+------------------+----------------------------------+
| table_name   | found_records    | found_crc                        |
+--------------+------------------+----------------------------------+
| departments  |                9 | d1af5e170d2d1591d776d5638d71fc5f |
| dept_emp     |           331603 | ccf6fe516f990bdaa49713fc478701b7 |
| dept_manager |               24 | 8720e2f0853ac9096b689c14664f847e |
| employees    |           300024 | 4ec56ab5ba37218d187cf6ab09ce1aa1 |
| salaries     |          2844047 | fd220654e95aea1b169624ffe3fca934 |
| titles       |           443308 | bfa016c472df68e70a03facafa1bc0a8 |
+--------------+------------------+----------------------------------+
...
+--------------+---------------+-----------+
| table_name   | records_match | crc_match |
+--------------+---------------+-----------+
| departments  | OK            | ok        |
| dept_emp     | OK            | ok        |
| dept_manager | OK            | ok        |
| employees    | OK            | ok        |
| salaries     | OK            | ok        |
| titles       | OK            | ok        |
+--------------+---------------+-----------+
..
+------------------+
| computation_time |
+------------------+
| 00:02:15         |
+------------------+
...
+---------+--------+
| summary | result |
+---------+--------+
| CRC     | OK     |
| count   | OK     |
+---------+--------+
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52

看起来验证无误。

§ 导入world数据集

执行下面的命令导入world数据集:

SOURCE /tmp/testdb/world-db/world.sql;
1
查看运行结果
greatsql> SOURCE /tmp/testdb/world-db/world.sql;
...

greatsql> SELECT COUNT(*) FROM city;
+----------+
| count(*) |
+----------+
|     4079 |
+----------+

greatsql> SELECT COUNT(*) FROM country;
+----------+
| count(*) |
+----------+
|      239 |
+----------+

greatsql> SELECT COUNT(*) FROM countrylanguage;
+----------+
| count(*) |
+----------+
|      984 |
+----------+
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23

导入完毕。

§ 导入Sakila数据集

执行下面的命令初始化Sakila测试数据库:

SOURCE /tmp/testdb/sakila-db/sakila-schema.sql;
SOURCE /tmp/testdb/sakila-db/sakila-data.sql;
1
2
查看运行结果
greatsql> SOURCE /tmp/testdb/sakila-db/sakila-schema.sql;
greatsql> SOURCE /tmp/testdb/sakila-db/sakila-data.sql;

greatsql> SELECT TABLE_SCHEMA, TABLE_NAME, TABLE_TYPE, ENGINE, TABLE_ROWS 
  FROM information_schema.TABLES WHERE table_schema = 'sakila';
+--------------+----------------------------+------------+--------+------------+
| TABLE_SCHEMA | TABLE_NAME                 | TABLE_TYPE | ENGINE | TABLE_ROWS |
+--------------+----------------------------+------------+--------+------------+
| sakila       | actor                      | BASE TABLE | InnoDB |        200 |
| sakila       | actor_info                 | VIEW       | NULL   |       NULL |
| sakila       | address                    | BASE TABLE | InnoDB |        603 |
| sakila       | category                   | BASE TABLE | InnoDB |         16 |
| sakila       | city                       | BASE TABLE | InnoDB |        600 |
| sakila       | country                    | BASE TABLE | InnoDB |        109 |
| sakila       | customer                   | BASE TABLE | InnoDB |        599 |
| sakila       | customer_list              | VIEW       | NULL   |       NULL |
| sakila       | film                       | BASE TABLE | InnoDB |       1000 |
| sakila       | film_actor                 | BASE TABLE | InnoDB |       5462 |
| sakila       | film_category              | BASE TABLE | InnoDB |       1000 |
| sakila       | film_list                  | VIEW       | NULL   |       NULL |
| sakila       | film_text                  | BASE TABLE | InnoDB |       1000 |
| sakila       | inventory                  | BASE TABLE | InnoDB |       4581 |
| sakila       | language                   | BASE TABLE | InnoDB |          6 |
| sakila       | nicer_but_slower_film_list | VIEW       | NULL   |       NULL |
| sakila       | payment                    | BASE TABLE | InnoDB |      16500 |
| sakila       | rental                     | BASE TABLE | InnoDB |      16010 |
| sakila       | sales_by_film_category     | VIEW       | NULL   |       NULL |
| sakila       | sales_by_store             | VIEW       | NULL   |       NULL |
| sakila       | staff                      | BASE TABLE | InnoDB |          2 |
| sakila       | staff_list                 | VIEW       | NULL   |       NULL |
| sakila       | store                      | BASE TABLE | InnoDB |          2 |
+--------------+----------------------------+------------+--------+------------+
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32

导入完毕。

接下来就可以运行查询和测试了。

关于测试数据库的更多详情参考 Other MySQL Documentation (opens new window)

扫码关注微信公众号

greatsql-wx