【MySQL】数据库 ⑤

news2024/11/20 7:20:28

✍导出数据

1、使用 SELECT ... INTO OUTFILE 语句导出数据

  •  SELECT...INTO OUTFILE 是 MySQL 用于导出数据的语句,它允许将查询结果保存到指定的文件中。

该语句的基本语法如下:
 

SELECT column1, column2, ...  
INTO OUTFILE 'file_path'  
FIELDS TERMINATED BY 'field_separator'  
ENCLOSED BY 'field_encloser'  
LINES TERMINATED BY 'line_separator'  
FROM table_name;
  1. column1, column2, ...:要导出的列名。
  2. INTO OUTFILE 'file_path':指定导出数据时要保存到的文件路径。
  3. FIELDS TERMINATED BY 'field_separator':指定字段之间的分隔符,默认为逗号(,)。
  4. ENCLOSED BY 'field_encloser':指定字段的包围字符,默认为双引号(")。
  5. LINES TERMINATED BY 'line_separator':指定行之间的分隔符,默认为换行符(\n)。
  6. table_name:要导出数据的表名。

以下是一个示例:

SELECT id, name, email  
INTO OUTFILE '/tmp/users.txt'  
FIELDS TERMINATED BY ','  
ENCLOSED BY '"'  
LINES TERMINATED BY '\n'  
FROM users;

从名为 users 的表中选择 id、name 和 email 列,并将结果保存到 /tmp/users.txt 文件中。文件中的每一行都包含一个记录,记录中的字段以逗号分隔,并用双引号包围。行之间用换行符分隔。

注意:

  •  执行 SELECT ... INTO OUTFILE 语句导出数据,可能回报一下错误
ERROR 1290 (HY000): The MySQL server is running with the --secure-file-priv option so it cannot execute this statement

原因:

  • 执行语句
show global variables like '%secure_file_priv%';
  • 查看结果 
+------------------+-----------------------------------------+
| Variable_name    | Value                                   |
+------------------+-----------------------------------------+
| secure_file_priv | D:\work\mysql\MySQL-Server-8.0\Uploads\ |
+------------------+-----------------------------------------+
  1.  secure_file_priv参数用于限制LOAD DATA, SELECT …OUTFILE, LOAD_FILE()传到哪个指定目录。
  2. secure_file_priv 为 NULL 时,表示限制mysqld不允许导入或导出。
  3. secure_file_priv 为 /tmp 时,表示限制mysqld只能在/tmp目录中执行导入导出,其他目录不能执行。
  4. secure_file_priv 没有值时,表示不限制mysqld在任意目录的导入导出。
  5. secure_file_priv 参数是只读参数,不能使用set global命令修改。

解决:

  • 查看MySQL服务器的配置文件(通常是my.cnf或my.ini),确保--secure-file-priv选项被设置。
  • 如果以上选项未被设置,可以将secure_file_priv参数添加到MySQL服务器的配置文件中,并重新启动MySQL服务器。

 演示:

  • 执行语句
mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| product            |
| sys                |
| xj                 |
+--------------------+
6 rows in set (0.00 sec)


mysql> use product;
Database changed


mysql> show tables;
+-------------------+
| Tables_in_product |
+-------------------+
| emp               |
| emp_log           |
| goods             |
| order_for_goods   |
| person_table      |
| sequence          |
| test_transaction  |
| text_alter        |
| text_copy         |
| text_null         |
| text_table        |
| text_table2       |
| users             |
+-------------------+
13 rows in set (0.00 sec)


mysql> SELECT *
    -> INTO OUTFILE 'D:/work/mysql/MySQL-Server-8.0/Uploads/emp.sql'
    -> FIELDS TERMINATED BY ','
    -> ENCLOSED BY '"'
    -> LINES TERMINATED BY '\n'
    -> FROM emp;
Query OK, 15 rows affected (0.00 sec)
  •  查看结果

2、导出 SQL 格式的数据(用于实现数据库的备份策略)

  • 这是一个在命令行下执行的MySQL数据库备份命令。该命令使用mysqldump工具将名为product的数据库备份到一个名为product.sql的文件中。
mysqldump -uxiaojian -proot product > D:\work\mysql\MySQL-Server-8.0\Uploads\product.sql

  1. mysqldump: 这是一个用于创建MySQL数据库备份的工具。
  2. -u: 用于指定数据库用户名,这里为xiaojian。
  3. -p: 用于提示输入数据库密码,这里为root。
  4. product: 这是要备份的数据库名。
  5. >: 将输出重定向到D:\work\mysql\MySQL-Server-8.0\Uploads\product.sql文件中。
  6. 注意执行这个命令需要在MySQL服务器上执行,并且执行者需要具有对product数据库的读取权限。

  • 演示执行命令

  •  查看导出的备份文件

  •  整个数据库(product)的数据内容
-- MySQL dump 10.13  Distrib 5.7.28, for Win64 (x86_64)
--
-- Host: localhost    Database: product
-- ------------------------------------------------------
-- Server version	8.0.33

/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;
/*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;
/*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */;
/*!40101 SET NAMES utf8 */;
/*!40103 SET @OLD_TIME_ZONE=@@TIME_ZONE */;
/*!40103 SET TIME_ZONE='+00:00' */;
/*!40014 SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0 */;
/*!40014 SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0 */;
/*!40101 SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='NO_AUTO_VALUE_ON_ZERO' */;
/*!40111 SET @OLD_SQL_NOTES=@@SQL_NOTES, SQL_NOTES=0 */;

--
-- Table structure for table `emp`
--

DROP TABLE IF EXISTS `emp`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `emp` (
  `id` int NOT NULL AUTO_INCREMENT,
  `sex` int DEFAULT NULL,
  `user_name` varchar(15) CHARACTER SET utf8mb3 COLLATE utf8mb3_general_ci DEFAULT NULL,
  `salary` decimal(10,2) DEFAULT NULL,
  `join_time` datetime DEFAULT NULL,
  `department` int DEFAULT NULL,
  `address` varchar(255) DEFAULT NULL,
  `text` char(255) DEFAULT NULL,
  PRIMARY KEY (`id`) USING BTREE,
  KEY `idx_name_salary` (`user_name`,`salary`)
) ENGINE=InnoDB AUTO_INCREMENT=23 DEFAULT CHARSET=utf8mb3 ROW_FORMAT=DYNAMIC;
/*!40101 SET character_set_client = @saved_cs_client */;

--
-- Dumping data for table `emp`
--

LOCK TABLES `emp` WRITE;
/*!40000 ALTER TABLE `emp` DISABLE KEYS */;
INSERT INTO `emp` VALUES (1,1,'郭成龙',1800.90,'2023-06-07 00:00:00',1,NULL,NULL),(2,1,'小王',3600.89,'2023-05-02 00:00:00',2,NULL,NULL),(3,0,'马成虫',1000.10,'2023-01-08 00:00:00',2,NULL,NULL),(4,1,'老狗',1100.90,'2023-04-07 00:00:00',3,NULL,NULL),(5,0,'臭弟弟',4500.99,'2023-03-14 00:00:00',1,NULL,NULL),(6,1,'小李',2500.10,'2023-03-14 00:00:00',1,NULL,NULL),(7,0,'陈二狗',2500.90,'2023-03-14 00:00:00',3,NULL,NULL),(15,1,'郭成龙',1800.90,'2023-06-07 00:00:00',1,NULL,NULL),(16,1,'小王',3600.89,'2023-05-02 00:00:00',2,NULL,NULL),(17,0,'马成虫',1000.10,'2023-01-08 00:00:00',2,NULL,NULL),(18,1,'老狗',1100.90,'2023-04-07 00:00:00',3,NULL,NULL),(19,0,'臭弟弟',4500.99,'2023-03-14 00:00:00',1,NULL,NULL),(20,1,'小李',2500.10,'2023-03-14 00:00:00',1,NULL,NULL),(21,0,'陈二狗',2500.90,'2023-03-14 00:00:00',3,NULL,NULL),(22,0,'二狗',NULL,'2023-06-09 11:18:55',NULL,NULL,' CSDN');
/*!40000 ALTER TABLE `emp` ENABLE KEYS */;
UNLOCK TABLES;

--
-- Table structure for table `emp_log`
--

DROP TABLE IF EXISTS `emp_log`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `emp_log` (
  `id` int NOT NULL,
  `name` char(10) NOT NULL DEFAULT '',
  `date` datetime NOT NULL,
  `signin` tinyint NOT NULL DEFAULT '0' COMMENT '登录次数',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb3;
/*!40101 SET character_set_client = @saved_cs_client */;

--
-- Dumping data for table `emp_log`
--

LOCK TABLES `emp_log` WRITE;
/*!40000 ALTER TABLE `emp_log` DISABLE KEYS */;
INSERT INTO `emp_log` VALUES (1,'张三','2023-06-22 15:25:33',1),(2,'张三','2023-06-20 15:25:47',3),(3,'王五','2023-06-19 15:26:02',2),(4,'弟弟','2023-06-07 15:26:14',4),(5,'二狗','2023-06-11 15:26:40',4),(6,'二狗','2023-06-04 15:26:54',2);
/*!40000 ALTER TABLE `emp_log` ENABLE KEYS */;
UNLOCK TABLES;

--
-- Table structure for table `goods`
--

DROP TABLE IF EXISTS `goods`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `goods` (
  `id` int NOT NULL AUTO_INCREMENT,
  `category_id` int DEFAULT NULL,
  `category` varchar(15) CHARACTER SET utf8mb3 COLLATE utf8mb3_general_ci DEFAULT NULL,
  `name` varchar(50) CHARACTER SET utf8mb3 COLLATE utf8mb3_general_ci DEFAULT NULL,
  `price` decimal(10,2) DEFAULT NULL,
  `stock` int DEFAULT NULL,
  `upper_time` datetime DEFAULT NULL,
  PRIMARY KEY (`id`) USING BTREE
) ENGINE=InnoDB AUTO_INCREMENT=16 DEFAULT CHARSET=utf8mb3 ROW_FORMAT=DYNAMIC;
/*!40101 SET character_set_client = @saved_cs_client */;

--
-- Dumping data for table `goods`
--

LOCK TABLES `goods` WRITE;
/*!40000 ALTER TABLE `goods` DISABLE KEYS */;
INSERT INTO `goods` VALUES (1,1,'女装/女士精品','T恤',39.90,1000,'2020-11-10 00:00:00'),(2,1,'女装/女士精品','连衣裙',79.90,2500,'2020-11-10 00:00:00'),(3,1,'女装/女士精品','卫衣',89.90,1500,'2020-11-10 00:00:00'),(4,1,'女装/女士精品','牛仔裤',89.90,3500,'2020-11-10 00:00:00'),(5,1,'女装/女士精品','百褶裙',29.90,500,'2020-11-10 00:00:00'),(6,1,'女装/女士精品','呢绒外套',399.90,1200,'2020-11-10 00:00:00'),(7,2,'户外运动','自行车',399.90,1000,'2020-11-10 00:00:00'),(8,2,'户外运动','山地自行车',1399.90,2500,'2020-11-10 00:00:00'),(9,2,'户外运动','登山杖',59.90,1500,'2020-11-10 00:00:00'),(10,2,'户外运动','骑行装备',399.90,3500,'2020-11-10 00:00:00'),(11,2,'户外运动','运动外套',799.90,500,'2020-11-10 00:00:00'),(12,2,'户外运动','滑板',499.90,1200,'2020-11-10 00:00:00'),(15,1,'女装/女士精品1','连衣裙1',40.90,2500,'2020-11-10 00:00:00');
/*!40000 ALTER TABLE `goods` ENABLE KEYS */;
UNLOCK TABLES;

--
-- Table structure for table `order_for_goods`
--

DROP TABLE IF EXISTS `order_for_goods`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `order_for_goods` (
  `order_id` int NOT NULL AUTO_INCREMENT,
  `user_id` int DEFAULT NULL,
  `money` decimal(10,2) DEFAULT NULL,
  `quantity` int DEFAULT NULL,
  `join_time` datetime DEFAULT NULL,
  PRIMARY KEY (`order_id`) USING BTREE
) ENGINE=InnoDB AUTO_INCREMENT=75 DEFAULT CHARSET=utf8mb3 ROW_FORMAT=DYNAMIC;
/*!40101 SET character_set_client = @saved_cs_client */;

--
-- Dumping data for table `order_for_goods`
--

LOCK TABLES `order_for_goods` WRITE;
/*!40000 ALTER TABLE `order_for_goods` DISABLE KEYS */;
INSERT INTO `order_for_goods` VALUES (65,1001,1800.90,1,'2023-06-07 00:00:00'),(66,1001,3600.89,5,'2023-05-02 00:00:00'),(67,1001,1000.10,6,'2023-01-08 00:00:00'),(68,1002,1100.90,9,'2023-04-07 00:00:00'),(69,1002,4500.99,1,'2023-03-14 00:00:00'),(70,1003,2500.10,3,'2023-02-14 00:00:00'),(71,1002,2500.90,1,'2023-03-14 00:00:00'),(72,1003,2500.90,1,'2022-12-12 00:00:00'),(73,1003,2500.90,2,'2022-09-08 00:00:00'),(74,1003,6000.90,8,'2023-01-10 00:00:00');
/*!40000 ALTER TABLE `order_for_goods` ENABLE KEYS */;
UNLOCK TABLES;

--
-- Table structure for table `person_table`
--

DROP TABLE IF EXISTS `person_table`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `person_table` (
  `first_name` char(20) COLLATE utf8mb4_unicode_ci NOT NULL,
  `last_name` char(20) COLLATE utf8mb4_unicode_ci NOT NULL,
  `sex` char(10) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
  PRIMARY KEY (`last_name`,`first_name`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
/*!40101 SET character_set_client = @saved_cs_client */;

--
-- Dumping data for table `person_table`
--

LOCK TABLES `person_table` WRITE;
/*!40000 ALTER TABLE `person_table` DISABLE KEYS */;
INSERT INTO `person_table` VALUES ('Thomas','Jay',NULL),('csdn','mr.xiao',NULL);
/*!40000 ALTER TABLE `person_table` ENABLE KEYS */;
UNLOCK TABLES;

--
-- Table structure for table `sequence`
--

DROP TABLE IF EXISTS `sequence`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `sequence` (
  `name` varchar(50) COLLATE utf8mb4_unicode_ci NOT NULL,
  `current_value` int NOT NULL,
  `increment` int NOT NULL DEFAULT '1',
  PRIMARY KEY (`name`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
/*!40101 SET character_set_client = @saved_cs_client */;

--
-- Dumping data for table `sequence`
--

LOCK TABLES `sequence` WRITE;
/*!40000 ALTER TABLE `sequence` DISABLE KEYS */;
INSERT INTO `sequence` VALUES ('seq_buz_engineering_task',1,1),('seq_buz_tender_info',2,1),('TestSeq',0,1);
/*!40000 ALTER TABLE `sequence` ENABLE KEYS */;
UNLOCK TABLES;

--
-- Table structure for table `test_transaction`
--

DROP TABLE IF EXISTS `test_transaction`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `test_transaction` (
  `id` int DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
/*!40101 SET character_set_client = @saved_cs_client */;

--
-- Dumping data for table `test_transaction`
--

LOCK TABLES `test_transaction` WRITE;
/*!40000 ALTER TABLE `test_transaction` DISABLE KEYS */;
INSERT INTO `test_transaction` VALUES (5),(6);
/*!40000 ALTER TABLE `test_transaction` ENABLE KEYS */;
UNLOCK TABLES;

--
-- Table structure for table `text_alter`
--

DROP TABLE IF EXISTS `text_alter`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `text_alter` (
  `ids` int DEFAULT NULL,
  `prices` int NOT NULL
) ENGINE=MyISAM DEFAULT CHARSET=utf8mb3;
/*!40101 SET character_set_client = @saved_cs_client */;

--
-- Dumping data for table `text_alter`
--

LOCK TABLES `text_alter` WRITE;
/*!40000 ALTER TABLE `text_alter` DISABLE KEYS */;
/*!40000 ALTER TABLE `text_alter` ENABLE KEYS */;
UNLOCK TABLES;

--
-- Table structure for table `text_copy`
--

DROP TABLE IF EXISTS `text_copy`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `text_copy` (
  `text_id` int unsigned NOT NULL AUTO_INCREMENT,
  `text_title` varchar(100) NOT NULL,
  `text_author` varchar(40) NOT NULL,
  `submission_date` date DEFAULT NULL,
  PRIMARY KEY (`text_id`)
) ENGINE=InnoDB AUTO_INCREMENT=10 DEFAULT CHARSET=utf8mb3;
/*!40101 SET character_set_client = @saved_cs_client */;

--
-- Dumping data for table `text_copy`
--

LOCK TABLES `text_copy` WRITE;
/*!40000 ALTER TABLE `text_copy` DISABLE KEYS */;
INSERT INTO `text_copy` VALUES (1,'安徒生童话','臭弟弟','2023-06-16'),(2,'小天鹅与丑小鸭','你才是臭弟弟','2023-06-16'),(3,'西游记','我不是臭弟弟','2023-06-16'),(5,'csdn','作者','2023-06-19'),(6,'测试','text','2023-06-19');
/*!40000 ALTER TABLE `text_copy` ENABLE KEYS */;
UNLOCK TABLES;

--
-- Table structure for table `text_null`
--

DROP TABLE IF EXISTS `text_null`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `text_null` (
  `id` int NOT NULL,
  `text_title` char(10) DEFAULT NULL COMMENT '书名',
  `text_author` char(10) DEFAULT NULL COMMENT '作者',
  `price` double DEFAULT NULL COMMENT '价格',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb3;
/*!40101 SET character_set_client = @saved_cs_client */;

--
-- Dumping data for table `text_null`
--

LOCK TABLES `text_null` WRITE;
/*!40000 ALTER TABLE `text_null` DISABLE KEYS */;
INSERT INTO `text_null` VALUES (1,'百科全书解决空值','火爆的后槽牙儿',6.66),(2,'这是一本书','小王',NULL),(3,'西游记','作者',NULL);
/*!40000 ALTER TABLE `text_null` ENABLE KEYS */;
UNLOCK TABLES;

--
-- Table structure for table `text_table`
--

DROP TABLE IF EXISTS `text_table`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `text_table` (
  `text_id` int unsigned NOT NULL AUTO_INCREMENT,
  `text_title` varchar(100) NOT NULL,
  `text_author` varchar(40) NOT NULL,
  `submission_date` date DEFAULT NULL,
  PRIMARY KEY (`text_id`)
) ENGINE=InnoDB AUTO_INCREMENT=10 DEFAULT CHARSET=utf8mb3;
/*!40101 SET character_set_client = @saved_cs_client */;

--
-- Dumping data for table `text_table`
--

LOCK TABLES `text_table` WRITE;
/*!40000 ALTER TABLE `text_table` DISABLE KEYS */;
INSERT INTO `text_table` VALUES (1,'安徒生童话','臭弟弟','2023-06-16'),(2,'小天鹅与丑小鸭','你才是臭弟弟','2023-06-16'),(3,'西游记','我不是臭弟弟','2023-06-16'),(5,'csdn','作者','2023-06-19'),(6,'测试','text','2023-06-19');
/*!40000 ALTER TABLE `text_table` ENABLE KEYS */;
UNLOCK TABLES;

--
-- Table structure for table `text_table2`
--

DROP TABLE IF EXISTS `text_table2`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `text_table2` (
  `text_id` int unsigned NOT NULL AUTO_INCREMENT,
  `text_title` varchar(100) NOT NULL,
  `text_author` varchar(40) NOT NULL,
  `submission_date` date DEFAULT NULL,
  PRIMARY KEY (`text_id`)
) ENGINE=InnoDB AUTO_INCREMENT=9 DEFAULT CHARSET=utf8mb3;
/*!40101 SET character_set_client = @saved_cs_client */;

--
-- Dumping data for table `text_table2`
--

LOCK TABLES `text_table2` WRITE;
/*!40000 ALTER TABLE `text_table2` DISABLE KEYS */;
INSERT INTO `text_table2` VALUES (1,'安徒生童话','臭弟弟','2023-06-19'),(2,'小天鹅与丑小鸭','你才是臭弟弟','2023-06-19'),(3,'HPH调用','你才是臭弟弟','2023-06-19'),(4,'JAVA入门','我不是臭弟弟','2023-06-19'),(5,'水浒传','你才是臭弟弟','2023-06-19'),(6,'红楼梦','我不是臭弟弟','2023-06-19'),(7,'事实上d','d','2023-06-20'),(8,'鸟','a','2023-06-20');
/*!40000 ALTER TABLE `text_table2` ENABLE KEYS */;
UNLOCK TABLES;

--
-- Table structure for table `users`
--

DROP TABLE IF EXISTS `users`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `users` (
  `id` bigint unsigned NOT NULL AUTO_INCREMENT,
  `name` varchar(50) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
  `email` varchar(100) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
  PRIMARY KEY (`id`),
  UNIQUE KEY `id` (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
/*!40101 SET character_set_client = @saved_cs_client */;

--
-- Dumping data for table `users`
--

LOCK TABLES `users` WRITE;
/*!40000 ALTER TABLE `users` DISABLE KEYS */;
INSERT INTO `users` VALUES (1,'1',NULL),(2,'2',NULL);
/*!40000 ALTER TABLE `users` ENABLE KEYS */;
UNLOCK TABLES;
/*!40103 SET TIME_ZONE=@OLD_TIME_ZONE */;

/*!40101 SET SQL_MODE=@OLD_SQL_MODE */;
/*!40014 SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS */;
/*!40014 SET UNIQUE_CHECKS=@OLD_UNIQUE_CHECKS */;
/*!40101 SET CHARACTER_SET_CLIENT=@OLD_CHARACTER_SET_CLIENT */;
/*!40101 SET CHARACTER_SET_RESULTS=@OLD_CHARACTER_SET_RESULTS */;
/*!40101 SET COLLATION_CONNECTION=@OLD_COLLATION_CONNECTION */;
/*!40111 SET SQL_NOTES=@OLD_SQL_NOTES */;

-- Dump completed on 2023-06-23 10:25:27

如果你需要导出整个数据的数据,可以使用以下命令:

mysqldump -uroot -proot product > D:\work\mysql\MySQL-Server-8.0\Uploads\product.sql

如果需要备份所有数据,可以使用以下命令:

mysqldump -u root -p --all-databases > D:\work\mysql\MySQL-Server-8.0\Uploads\database_dump.sql

3、将数据表及数据库拷贝至其他主机

说明:

       要将MySQL数据表和数据库复制到另一个主机上,可以遵循以下步骤

1、在源主机上备份数据:使用以下命令备份整个数据库或特定的数据表:

mysqldump -u username -p dbname > backupfile.sql

其中,username是数据库用户名,dbname是要备份的数据库名称,backupfile.sql是备份文件的名称。

也可以使用--all-databases选项备份所有数据库:

mysqldump -u username -p --all-databases > backupfile.sql

2、将备份文件传输到目标主机:也可以使用任何文件传输工具,将备份文件传输到目标主机上。

3、在目标主机上恢复数据:使用以下命令将备份文件恢复到目标主机上:

mysql -u username -p dbname < backupfile.sql

其中,username是数据库用户名,dbname是要恢复数据的数据库名称,backupfile.sql是备份文件的名称。如果备份文件中包含多个数据库,您需要逐个恢复它们。
 

也可以使用以下命令将导出的数据直接导入到远程的服务器上,但请确保两台服务器是相通的,是可以相互访问的:

mysqldump -u root -p database_name \
| mysql -h other-host.com database_name

mysqldump是一个用于备份MySQL数据库的工具,而mysql是用于恢复或导入数据到MySQL数据库的工具。在这个命令中,我们将使用mysqldump备份数据库,然后将备份文件通过管道符号|发送给mysql命令,以便在另一个主机上恢复数据库。

具体来命令的参数解释如下:

  • mysqldump -u root -p database_name: 备份名为database_name的数据库,使用root用户登录,并在备份时提示输入密码。
  • |: 管道符号,将前面的输出作为后面的输入。
  • mysql -h other-host.com database_name: 在名为other-host.com的主机上恢复名为database_name的数据库。

综上所述,这个命令将在源主机上备份名为database_name的数据库,然后将备份文件通过管道发送给目标主机上的mysql命令,以便在该主机上恢复相同的数据库。

✍导入数据

1、mysql  命令导入

  • 使用 MySQL 命令导入语法格式
mysql -u用户名  -p密码   数据库名称 < 要导入的数据库数据(product.sql)
  •  举例如:有一个名为 product.sql 的文件,将 product.sql 中的建表语句和数据,导入到名为 xj 的数据库中。可以使用以下命令导入数据。
mysql -u xiaojian -p  xj < D:/work/mysql/MySQL-Server-8.0/Uploads/product.sql

  以上命令会将备份的整个数据库 product.sql 导入。

  • 执行结果

2、source 命令导入

  • 确保您已经将数据保存在一个 SQL 文件中,例如 product.sql。
  • 打开一个 MySQL 命令行客户端,并连接到相应的 MySQL 服务器。
  • 在 MySQL 命令行客户端中,使用 USE 命令选择要导入数据的数据库
mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| product            |
| sys                |
| xj                 |
+--------------------+
6 rows in set (0.00 sec)

mysql> use xj;
Database changed

mysql> show tables;
Empty set (0.00 sec)
  • 执行导入语句 
source D:/work/mysql/MySQL-Server-8.0/Uploads/product.sql
  • 查看结果

 

3、使用 LOAD DATA 导入数据

  • 将本地文件D:/work/mysql/MySQL-Server-8.0/Uploads/goods.txt中的数据导入到MySQL数据库中的goods表
  • MySQL中提供了LOAD DATA INFILE语句来插入数据。 从目录中读取文件 goods.txt ,将该文件中的数据插入到当前数据库的 goods 表中。
  • 如果指定LOCAL关键词,则表明从客户主机上按路径读取文件。如果没有指定,则文件在服务器上按路径读取文件。
LOAD DATA LOCAL INFILE 'D:/work/mysql/MySQL-Server-8.0/Uploads/goods.txt' INTO TABLE goods
FIELDS TERMINATED BY ',' 
ENCLOSED BY '"'
LINES TERMINATED BY '\n';
  1. LOAD DATA LOCAL INFILE 'D:/work/mysql/MySQL-Server-8.0/Uploads/goods.txt': 这部分指定了要导入的文件的路径和文件名。
  2. INTO TABLE goods: 这部分指定了要将数据导入到哪个表中,这里是goods表。
  3. FIELDS TERMINATED BY ',': 这部分指定了字段之间的分隔符,这里使用逗号作为分隔符。
  4. ENCLOSED BY '"': 这部分指定了字段值的引用符,这里使用双引号作为引用符。
  5. LINES TERMINATED BY '\n': 这部分指定了行之间的分隔符,这里使用回车换行符作为分隔符。
  • 导入的数据文本goods.txt格式
"1","1","女装/女士精品","T恤","39.90","1000","2020-11-10 00:00:00"
"3","1","女装/女士精品","卫衣","89.90","1500","2020-11-10 00:00:00"
"5","1","女装/女士精品","百褶裙","29.90","500","2020-11-10 00:00:00"
"7","2","户外运动","自行车","399.90","1000","2020-11-10 00:00:00"
"9","2","户外运动","登山杖","59.90","1500","2020-11-10 00:00:00"
"11","2","户外运动","运动外套","799.90","500","2020-11-10 00:00:00"
"15","1","女装/女士精品1","连衣裙1","40.90","2500","0000-00-00 00:00:00"

错误:

  • 这个错误提示意味着正在尝试加载本地数据,但是 MySQL 服务器禁用了这个功能。
ERROR 3948 (42000): Loading local data is disabled; this must be enabled on both the client and server sides

 ERROR 3948(42000):加载本地数据已被禁用;必须在客户端和服务器端同时启用此功能。

解决:

  • 确保 MySQL 服务器已经启动并且可以访问。
  • 打开一个 MySQL 命令行客户端,并连接到相应的 MySQL 服务器。
  • 在 MySQL 命令行客户端中,执行以下命令来启用加载本地数据的功能。
SET GLOBAL local_infile = ON;
  • 重新运行您的 SQL 脚本,应该能够成功导入本地数据。

4、使用 mysqlimport 导入数据

  • 基本语法
mysqlimport [options] db_name file_name

db_name是要导入数据的数据库名称,file_name是包含数据的文件名。options是可选的参数,用于指定一些导入选项。

  • 使用mysqlimport 命令指定选项来设置指定格式导入
mysqlimport -u xiaojian -p --local --fields-terminated-by="," --lines-terminated-by="\n"  xj D:/work/mysql/MySQL-Server-8.0/Uploads/goods.txt

  • 导入的数据文本goods.txt格式
1,1,女装/女士精品,T恤,39.90,1000,2020-11-10 00:00:00
3,1,女装/女士精品,卫衣,89.90,1500,2020-11-10 00:00:00
5,1,女装/女士精品,百褶裙,29.90,500,2020-11-10 00:00:00
7,2,户外运动,自行车,399.90,1000,2020-11-10 00:00:00
9,2,户外运动,登山杖,59.90,1500,2020-11-10 00:00:00
11,2,户外运动,运动外套,799.90,500,2020-11-10 00:00:00
15,1,女装/女士精品1,连衣裙1,40.90,2500,0000-00-00 00:00:00

  • 关于MySQL导入选项说明。
  1. --print-defaults:打印程序参数列表并退出。
  2. --no-defaults:除了登录文件外,不要从任何选项文件中读取默认选项。
  3. --defaults-file=#:只从给定的文件#中读取默认选项。
  4. --defaults-extra-file=#:在全局文件读取之后读取该文件。
  5. --defaults-group-suffix=#:同时从带有连接组和后缀的组中读取。
  6. --login-path=#:从登录文件中读取此路径。
  7. --bind-address=name:绑定到IP地址。
  8. --character-sets-dir=name:字符集文件目录。
  9. --default-character-set=name:设置默认字符集。
  10. -c--columns=name:只使用这些列将数据导入。以逗号分隔列名列表。
  11. -C--compress:在服务器/客户端协议中使用压缩。
  12. -#--debug[=#]:非调试版本。捕获并退出。
  13. --debug-check:非调试版本。捕获并退出。
  14. --debug-info:非调试版本。捕获并退出。
  15. --default-auth=name:默认的客户端侧身份验证插件。
  16. -d--delete:首先删除表中的所有行。
  17. --enable-cleartext-plugin:启用/禁用明文身份验证插件。
  18. --fields-terminated-by=name:输入文件中的字段以给定字符串终止。
  19. --fields-enclosed-by=name:导入文件中的字段由给定字符封闭。
  20. --fields-optionally-enclosed-by=name:输入文件中的字段可选择地由给定字符封闭。
  21. --fields-escaped-by=name:字段在输入文件中由给定字符转义。
  22. -f 和 --force:即使遇到 SQL 错误,也要继续执行。
  23. -? 和 --help:显示帮助信息并退出。
  24. -h 和 --host=name:连接到的主机名。
  25. -i 和 --ignore:如果发现重复的唯一键,则保留旧行。
  26. --ignore-lines=#:忽略数据文件中的前 n 行。
  27. --lines-terminated-by=name:输入文件中的行以给定字符串终止。
  28. -L 和 --local:通过客户端读取所有文件。
  29. -l 和 --lock-tables:锁定所有表以进行写入(这将禁用线程)。
  30. --low-priority:使用 LOW_PRIORITY 更新表时使用。
  31. -p 和 --password[=name]:连接服务器时使用的密码。如果未指定密码,则从终端询问。
  32. -W 和 --pipe:使用命名管道连接到服务器。
  33. --plugin-dir=name:客户端插件的目录。
  34. -P 和 --port=#:用于连接的端口号,或者优先顺序为 my.cnf、$MYSQL_TCP_PORT、/etc/services 和内置默认值(3306)中的默认端口号。
  35. --protocol=name:用于连接的协议(tcp、socket、pipe、memory)。
  36. -r 和 --replace:如果发现重复的唯一键,则替换旧行。
  37. --secure-auth:如果客户端使用旧版(4.1.1 之前)协议,则拒绝连接到服务器。已过时。始终为 TRUE。
  38. --shared-memory-base-name=name:共享内存的基名称。
  39. -s 和 --silent:更加沉默。
  40. -S 和 --socket=name:用于连接的套接字文件。
  41. --ssl-mode=name:SSL 连接模式。
  42. --ssl:已过时。请使用 --ssl-mode 代替。
  43. --ssl-verify-server-cert:已过时。请使用 --ssl-mode=VERIFY_IDENTITY 代替。
  44. --ssl-ca=name:CA 文件,以 PEM 格式。
  45. --ssl-capath=name:CA 目录。
  46. --ssl-cert=name:X509 证书,以 PEM 格式。
  47. --ssl-cipher=name:要使用的SSL密码。
  48. --ssl-key=name:X509密钥,以PEM格式。
  49. --ssl-crl=name:证书撤销列表。
  50. --ssl-crlpath=name:证书撤销列表路径。
  51. --tls-version=name:要使用的TLS版本,允许的值有:TLSv1、TLSv1.1、TLSv1.2。
  52. --server-public-key-path=name:服务器公共RSA密钥的文件路径,以PEM格式。
  53. --get-server-public-key:获取服务器公共密钥。
  54. --use-threads=#:并行加载文件的线程数。
  55. -u,--user=name:用于登录的用户,如果不是当前用户。
  56. -v,--verbose:打印各个阶段的信息。
  57. -V,--version:输出版本信息并退出。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/694102.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

你知道什么是大语言模型吗

在自然语言处理领域&#xff0c;大语言模型是一类十分重要的技术。顾名思义&#xff0c;大语言模型指的是比较“大”的&#xff08;神经网络&#xff09;语言模型&#xff0c;它们以自上文推理词语概率为核心任务。随着机器学习和深度学习技术的不断发展&#xff0c;人工智能的…

【样式静态】创建地址 省市区,详细地址,姓名,联系方式,电话

效果图 uview 2.0 <template><view class"addbox"><view class"order bgf common_p u-border-t"><view class"common_title"><text></text> 客户信息</view><view class"flex_align_cente…

再见Navicat,dbeaver才是真爱

数据库连接工具&#xff0c;后端程序员必须要用到工具&#xff0c;常用的是 Navicat&#xff0c;Navicat是收费工具&#xff0c;如果使用破解的方式可能会收到律师函&#xff0c;今天了不起给大家推荐一款开源免费的数据库连接工具 -- dbeaver。 功能特性 1、几乎支持所有数据…

百度内容审核接口测试

百度内容审核接口测试 1、成为开发者 三步完成账号的基本注册与认证&#xff1a; STEP1&#xff1a;点击百度AI开放平台导航右侧的控制台&#xff0c;选择需要使用的AI服务项。若为未登录状态&#xff0c;将跳转至登录界面&#xff0c;请您使用百度账号登录。如还未持有百度…

Hbase之获取表的Region分布

其实就是获取上图的start key和end key 代码: object HbaseRegions {def main(args: Array[String]): Unit {val hconf: Configuration HBaseConfiguration.create()hconf.set("hbase.zookeeper.property.clientPort", "2181")hconf.set("hbase.zo…

macOS编译开源全景拼接库OpenPano

1. 准备工具 clang与cmake 如果要处理png文件要下载安装libjpeg 安装相当依赖: brew install gnu-sed brew install libjpeg brew install eigen brew install libomp2.克隆源码 git clone --recursive https://github.com/ppwwyyxx/OpenPano.git 3.编译 mkdir build cd …

Pycharm如何完全卸载干净

卸载软件 打开 控制面板->程序和功能->右键卸载 清理缓存 删除本地缓存 删除用户目录下的jetbrains缓存&#xff0c;一般在AppData目录下&#xff0c;如图所示 删除注册表信息 WinR输入regedit&#xff0c;打开注册表&#xff0c;删除如下目录jetbrains文件夹 计算机…

微信小程序,PC端打开时,设置页面最大化和恢复功能

小程序根目录下的 app.json 文件用来对微信小程序进行全局配置&#xff1a;新增属性 "resizable": true, 1.代码示范&#xff1a; 2.官方文档属性

Java集合-HashMap-源码分析

目录 HashMap源码分析 HashMap内部定义的常量与Node节点 HashMap成员变量分析 构造方法 静态工具方法 hash方法 如何计算索引值 tableSizeFor方法 还有没有其他方法得到2的n次幂? 为什么HashMap的数组长度一定是2的n次幂? HashMap核心方法 put方法 将链表转换为…

Excel VBA 多列合并到一列中

有10列&#xff0c;13行数据&#xff0c;按列合并到新建工作表中&#xff0c;空值不添加 Sub 多列合并到同一列() Dim k As Integer Dim ws As Worksheet On Error Resume Next 如遇错误继续运行 Application.ScreenUpdating False 关闭屏幕刷新 Application.DisplayAlerts F…

Java实现布隆过滤器的几种方式

目录 一、前言二、什么是布隆过滤器&#xff1f;三、布隆过滤器原理四、布隆过滤器使用场景五、空间占用估计六、实际元素超出时&#xff0c;误判率会怎样变化七、布隆过滤器实现方式1、手动硬编码实现2、引入 Guava 实现3、引入 hutool 实现4、通过redis实现布隆过滤器 八、使…

【Linux】MySQL 进阶语句

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 MySQL 进阶语句 算排名算中位数算累积总计算总合百分比算累积总合百分比 use zs; CREATE TABLE ikun (Name char(10),Sales int(5)); INSERT INTO ikun VALUES (cx,10); INSE…

服务器内存爆炸

我在122服务器上测试了FullMouseBrain的数据集&#xff0c;发现内存爆炸 print("................................................import package ....................................") import os import sys ###############################################…

Objective-C 父元素和子元素的点击事件

场景&#xff1a; &#xff08;需求1&#xff09;pageA一开始是【默认模式】&#xff0c;点击父元素view&#xff08;包括【搜索】文字&#xff09;&#xff0c;进入【搜索模式】&#xff1b; &#xff08;需求2&#xff09;在pageA中&#xff0c;点击【取消】文字时&#xff…

YUM搭建LNMP

配置在线源 安装Nginx 检查安装版本 开启服务设置开机自启 安装MySQL 连接MySQL 开启服务设置开机自启 在日志中查看MySQL用户原始密码 登录MySQL 关闭自动更新 安装 php7.2 开启服务设置开机自启查看版本号 配置 nginx 支持 PHP 解析 测试MySQL是否能成功登录

IDEA下Logback.xml自动提示功能配置

首先打开logback的配置文件&#xff0c;在configuration标签中加入xsd的配置 <configuration xmlns"http://ch.qos.logback/xml/ns/logback"xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation"http://ch.qos.logback/xml…

python 视频转字符视频 bate

只需要在最后一行括号填入视频路径即可 import os from PIL import Image, ImageDraw, ImageFont import cv2 import time from tqdm import tqdm import threading if __name__ __main__:# path rimg\sportball\0.jpgdef cv2_pit_imgchar(path,save_path):def create_i…

Flutter系列(十)实现个人中心页

基础工程&#xff1a; Flutter系列&#xff08;四&#xff09;底部导航顶部导航图文列表完整代码_摸金青年v的博客-CSDN博客 一、前言 本文用flutter实现个人中心页布局&#xff0c;效果如下图&#xff1a; 二、使用的组件 1.颜色渐变&#xff1a;LinearGradient 线性渐变组…

ChatGLM-6B第二代模型开源,拿下LLM模型中文能力评估榜单第一名

ChatGLM-6B 自3月14日发布以来&#xff0c;深受广大开发者喜爱。截至 6 月24日&#xff0c;来自 Huggingface 上的下载量已经超过 300w。 为了更进一步促进大模型开源社区的发展&#xff0c;我们再次升级 ChatGLM-6B&#xff0c;发布 ChatGLM2-6B 。在主要评估LLM模型中文能力…

【SWAT水文模型】ArcSWAT各种报错总结

1 Error Number :-2147467259&#xff1b; 对 COM 组件的调用返回了错误 HRESULT E_FAIL 1.1 报错内容 Error Number :-2147467259 Eror Message: Eror HRESULTE FAIL has been retuned froma alltoa a COM component. Module:mAnalysis Function:dissolve Procedurure:1 随后…