广告
返回顶部
首页 > 资讯 > 数据库 >mysql复制表的几种方式
  • 238
分享到

mysql复制表的几种方式

数据库sqlmysql 2023-09-03 18:09:38 238人浏览 泡泡鱼
摘要

mysql复制表的几种方式  所描述的方法还请实际测试一下再使用. 1、复制表结构及数据到新表 CREATE TABLE 新表SELECT * FROM 旧表 这种方法会将oldtable中所有的内容都拷贝过来,当然我们可以用del

mysql复制表的几种方式 

所描述的方法还请实际测试一下再使用.

1、复制表结构及数据到新表

CREATE TABLE 新表SELECT * FROM 旧表

这种方法会将oldtable中所有的内容都拷贝过来,当然我们可以用delete from newtable;来删除。

 新表中没有了旧表的primary key、Extra(auto_increment)等属性。需要自己用"alter"添加,而且容易搞错。

2、只复制表结构到新表

CREATE TABLE 新表SELECT * FROM 旧表WHERE 1=2

或CREATE TABLE 新表LIKE 旧表

3、复制旧表的数据到新表(假设两个表结构一样)

INSERT INTO 新表SELECT * FROM 旧表

4、复制旧表的数据到新表(假设两个表结构不一样)

INSERT INTO 新表(字段1,字段2,.......) SELECT 字段1,字段2,...... FROM 旧表

5、可以将表1结构复制到表2

SELECT * INTO 表2 FROM 表1 WHERE 1=2

6、可以将表1内容全部复制到表2

SELECT * INTO 表2 FROM 表1

7、 show create table 旧表;

这样会将旧表的创建命令列出。我们只需要将该命令拷贝出来,更改table的名字,就可以建立一个完全一样的表

8、mysqldump

Mysqldump将表dump出来,改名字后再导回去或者直接在命令行中运行

9、复制旧数据库到新数据库(复制全部表结构并且复制全部表数据)

#mysql -u root -ppassWord
>CREATE DATABASE new_db;
#mysqldump old_db -u root -ppassword--skip-extended-insert --add-drop-table | mysql new_db -u root -ppassword


10、表不在同一数据库中(如,db1 table1, db2 table2)
sql: insert into db1.table1 select * from db2.table2 (完全复制)
insert into db1.table1 select distinct * from db2.table2(不复制重复纪录)
insert into tdb1.able1 select top 5 * from db2.table2 (前五条纪录)

MySQL拷贝表的几种方式

拷贝结构-添加数据
## 拷贝结构
CREATE TABLE newTable LIKE oldTable;
## 添加数据
INSERT INTO newTable SELECT * FROM oldTable;


2、拷贝结构和数据

CREATE TABLE newTable SELECT * FROM oldTable;
注:新表中没有了旧表的primary key、Extra(auto_increment)等属性。需要自己用"alter"添加,而且容易搞错。

拷贝部分字段和部分数据

## 拷贝部分字段
CREATE TABLE newTable AS  
(  
    SELECT 字段1, 字段2,... FROM oldTable
)
## 拷贝部分数据
CREATE TABLE 新表 AS

SELECT * FROM 旧表 WHERE id='1'


4、不同数据库拷贝表

CREATE TABLE newTable LIKE base1.oldTable;  
CREATE TABLE base1.newTable LIKE base2.oldTable;

表复制/合并查询/外连接

1. 表复制

自我复制数据(蠕虫复制)
有时,为了对某个sql语句进行效率测试,我们需要海量的数据时,可以使用此法为表创建海量数据

演示如何自我复制

思考:如何去掉一张表中的重复数据
思路:

  1. 先创建一张临时表 my_tmp,该表的结构和 my_tab02 一样
  2. 把 my_tmp 的记录,通过 distinct 关键字 处理后 , 把记录复制到 my_tmp
  3. 清除 my_tab02 中的所有记录
  4. 把 my_tmp 中的记录 复制到 my_tab02 中
  5. drop 掉临时表 my_tmp

2. 合并查询

有时在实际应用中,为了合并多个 select 语句的结果,可以使用集合操作符号 uNIOn,union all

  1. union all
    该操作符用于取得两个结果集的并集,当使用该操作符时,不会取消重复行
  2. union
    该操作符用于取得两个结果集的并集,当使用该操作符时,会取消重复行

3. 外连接

  1. 左外连接:如果左侧的表完全显示我们就说是左外连接
  2. 右外连接:如果右侧的表完全显示我们就说是右外连接

举例说明:

  • 创建两张表,一张存放名字,一张存放分数
    要求:显示所有人的成绩,如果没有成绩,也要显示该人的姓名和id号,成绩显示为空
  • 若用多表查询的方式,则无法查询到成绩为空的人的结果
  • 用左外连接的方式来查找,就可以将成绩为空的人的名字也显示出来
    说明:左外连接就是左侧表完全显示,所以会把stu的内容全部显示出来
  • 用右外连接的方式来查找,就可以将成绩为空的人的名字也显示出来
    说明:右外连接就是右侧表完全显示,即使和左表没有匹配的记录,也会把exam的内容全部显示出来

问题:列出部门名称和这些部门的员工名称和工作,同时要求显示出那些没有员工的部门

在实际开发中,我们绝大多数情况下使用的是内连接

来源地址:https://blog.csdn.net/eagle89/article/details/128478692

您可能感兴趣的文档:

--结束END--

本文标题: mysql复制表的几种方式

本文链接: https://www.lsjlt.com/news/392625.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • mysql复制表的几种方式
    mysql复制表的几种方式  所描述的方法还请实际测试一下再使用. 1、复制表结构及数据到新表 CREATE TABLE 新表SELECT * FROM 旧表 这种方法会将oldtable中所有的内容都拷贝过来,当然我们可以用del...
    99+
    2023-09-03
    数据库 sql mysql
  • mysql复制表的几种常用方式总结
    目录mysql复制表的几种方式 1、复制表结构及数据到新表2、只复制表结构到新表3、复制旧表的数据到新表(假设两个表结构一样)4、复制旧表的数据到新表(假设两个表结构不一样)5、可以将表1结构复制到表26、可以...
    99+
    2023-04-10
    mysql复制表语句 mysql如何复制表 mysql数据表复制
  • MySQL中复制表的方式你知道几种
    mysql 想必大家比较熟悉了, 我们常见的crud  sql 想必大家也是手到拈来。 但是我在今儿上数据库课的时候,我好像连mysql中复制表的基础写法 都不会。 可能工作中不常用,但作为基础 还是想写出来分享给大家。 这里 我介绍四种常...
    99+
    2023-09-05
    mysql 数据库 sql
  • Mysql复制表结构、表数据的主要几种方法
    下文主要给大家带来Mysql复制表结构、表数据的主要几种方法,希望这些内容能够带给大家实际用处,这也是我编辑Mysql复制表结构、表数据的主要几种方法这篇文章的主要目的。好了,废话不多说,大家直接看下文吧。...
    99+
    2022-10-18
  • MySQL复制表的三种方式(小结)
    复制表结构及其数据 下面这个语句会拷贝数据到新表中。 注意:这个语句其实只是把select语句的结果建一个表,所以新表不会有主键,索引。 create table table_name_new as ...
    99+
    2022-05-12
    MySQL 复制表
  • MySQL分库分表的几种方式
    目录一、为什么要分库分表二、什么是分库分表三、分库分表的几种方式1.垂直拆分2. 水平拆分四、分库分表带来的问题五、分库分表技术如何选型一、为什么要分库分表 如果一个网站业务快速发展...
    99+
    2022-11-13
  • MySQL表关联的常用方式有哪几种
    本文主要给大家介绍MySQL表关联的常用方式有哪几种,文章内容都是笔者用心摘选和编辑的,具有一定的针对性,对大家的参考意义还是比较大的,下面跟笔者一起了解下MySQL表关联的常用方式有哪几种吧。建表及插入数...
    99+
    2022-10-18
  • mysql表级锁的模式有几种
    本篇内容介绍了“mysql表级锁的模式有几种”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1、表共享读锁,添加共享读锁的表不会阻塞其他ses...
    99+
    2023-06-20
  • ORACLE表与表联接的几种方式
       三大表与表联接方式 NESTED LOOPS 嵌套循环 HASH JOIN 哈希联接 SORT MERGE 排序合并联接       NESTED LOOPS  嵌套循环   嵌套循环的本质是将外部数据集连接到内部数据集,对于外部数据...
    99+
    2021-06-19
    ORACLE表与表联接的几种方式 数据库入门 数据库基础教程 数据库 mysql
  • PostgreSQL 复制表的 5 种方式详解
    目录CREATE TABLE AS SELECT 语句CREATE TABLE LIKE 语句CREATE TABLE AS TABLE 语句SELECT INTO 语句CREATE TABLE INHERITS...
    99+
    2023-01-18
    PostgreSQL复制表 PostgreSQL复制表方式
  • PostgreSQL复制表的5种方式详解
    目录CREATE TABLE AS SELECT 语句CREATE TABLE LIKE 语句CREATE TABLE AS TABLE 语句SELECT INTO 语句CR...
    99+
    2023-01-18
    PostgreSQL 复制表 PostgreSQL 复制表方式
  • mysql数据库删除表数据的方式有几种
    这篇文章将为大家详细讲解有关mysql数据库删除表数据的方式,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。在MySQL中删除数据有两种方式:1、truncate(截短)属...
    99+
    2022-10-18
  • MySql添加索引的几种方式
    添加索引 添加primary key(主键索引) alter table 表名 add primary key(列名); 添加unique(唯一索引) alter table 表名 add unique(列名); 添加普通索引index...
    99+
    2023-09-03
    mysql 数据库 sql
  • MySQL几种创建索引的方式
    一、创建表时创建索引 key 索引名 (column); 二、表创建好后创建索引 通过Alter创建索引 ①PRIMARY  KEY(主键索引)         mysql > ALTER  TABLE  `table_name`  A...
    99+
    2023-09-01
    mysql
  • MySQL 实现FULL JOIN的几种方式
    MySQL中没有full join 但我我们可以通过以下几种方式来实现 注意:UNION 和 UNION ALL 的区别, UNION 会自动去重而UNION ALL不...
    99+
    2023-09-05
    mysql
  • MySQL修改密码的几种方式
    前言: 在日常使用数据库的过程中,难免会遇到需要修改账号密码的情景,比如密码太简单需要修改、密码过期需要修改、忘记密码需要修改等。本篇文章将会介绍需要修改密码的场景及修改密码的几种方式。 1.忘记 root 密码 ...
    99+
    2022-05-24
    MySQL 密码 MySQL 修改密码
  • python中list列表复制的几种方法(赋值、切片、copy(),deepcopy())
    目录1、浅拷贝和深拷贝2、直接赋值3、for循环4、切片5、copy()方法(1)list.copy()方法(2)copy.copy()方法6、deepcopy()方法1、浅拷贝和深...
    99+
    2022-11-11
  • MySQL 复制表的方法
    1、mysqldump 执行过程: 一、将数据导出为 sql 文件。 mysqldump -h$host -P$port -u$user --add-locks=0 --no-create-info...
    99+
    2022-05-31
    MySQL MySQL 复制表
  • Mysql关联查询的几种方式(详解)
    在关系型数据库中,要进行多表查询,一般都会使用join连接。join连接的本质其实类似与集合的交并操作,Mysql实现关联查询常见的几种方式如下; 目录 1、左连接 2、右连接 3、内连接 4、全连接 5、左外连接 6、右外连接 7、全外连...
    99+
    2023-09-25
    mysql关联查询
  • Mysql去重的几种方式分步讲解
    目录前言准备创建表测试数据目标探索distinct 去重group by去重实现方案方案一方案二方案三前言 我们做数据分析的时候经常会遇到去重问题,下面总结 sql 去重的几种方式,后续如果还有再补充,大数据分析层面包括...
    99+
    2022-12-06
    Mysql去重 Mysql去重语句 Mysql去重查询
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作