导入测试数据集
安装完GreatSQL数据库后,如果是用于教学或测试场景,可以导入几个通用的测试数据集,主要有:
- Employees sample database,一个模拟
- world sample database
- Sakila sample database
1. 下载测试数据集压缩包
上述三个测试数据集下载地址分别是:
- https://github.com/datacharmer/test\_db
- https://downloads.mysql.com/docs/world-db.tar.gz
- https://downloads.mysql.com/docs/sakila-db.tar.gz
分别下载到本地,并解压缩到 /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
2. 导入测试数据集
2.1 导入employees数据集
employees测试数据文件包中提供了导入方法说明,基本上照着做就行:
$ cd /tmp/testdb/test_db
$ cat README.md
...
开始导入(在这里,采用具有最高权限的root账户导入,所以略过创建测试账户这个环节,下同):
$ 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
导入完成后,还可以执行校验程序,确认导入的结果无误:
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 |
+---------+--------+
看起来验证无误。
2.2 导入world数据集
执行下面的命令导入world数据集:
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 |
+----------+
导入完毕。
2.3 导入Sakila数据集
执行下面的命令初始化Sakila测试数据库:
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 |
+--------------+----------------------------+------------+--------+------------+
导入完毕。
接下来就可以运行查询和测试了。
关于测试数据库的更多详情参考 Other MySQL Documentation (opens new window)。
问题反馈
联系我们
扫码关注微信公众号