mysql复制表以及复制数据库
(一)将旧表复制到新表
1、CREATE TABLE新表 SELECT* FROM旧表;
该语句只是复制表结构以及数据,它不会复制与表关联的其他数据库对象,如索引,主键约束,外键约束,触发器等。
CREATE TABLE if not exists new_tableSELECT col1, col2, col3FROMexisting_tableWHEREconditions;
2、MySQL 数据库不支持 SELECT ... INTO 语句,但支持 INSERT
INTO ... SELECT
其中在使用select into 语句与insert into select 语句时,新表要提前建立,并且新表与旧表的字段属性要一样才可以。
create table 新表 like 旧表;
新表建立之后才可以使用下面的两个语句:
SELECT * INTO 新表 FROM 旧表;
INSERT INTO 新表 SELECT * FROM 旧表;
只复制希望的列插入到另一个已存在的表中:
INSERT INTO 新表 (column_name(s))
SELECT column_name(s) FROM 旧表;
实例:INSERT
INTO Websites (name, country) SELECT app_name, country FROM apps;
(二)复制相同表结构
对于mysql的复制相同表结构方法,有create
table as 和create table like 两种
create
table 新表 like 旧表;
create
table 新表 as select * from 旧表 limit 0;
二者的区别:
as用来创建相同表结构并复制源表数据
like用来创建完整表结构和全部索引
oracle支持as,也是只有表结构没有索引
oracle不支持like。
(三)MySQL复制表到另一个数据库
访问不同数据库中的表:数据库名.表名 ,采用点 的形式。
有时,您要将表复制到其他数据库。 在这种情况下,可使用以下语句:
CREATE TABLE destination_db.new_tableLIKE source_db.existing_table;INSERT destination_db.new_tableSELECT *FROM source_db.existing_table;
具体流程:
CREATE DATABASE IF NOT EXISTS testdb;
其次,通过将其结构从示例数据库(yiibaidb)中的offices表复制出来,在testdb中创建了offices表。
CREATE TABLE testdb.offices LIKE yiibaidb.offices;
第三,我们将数据从yiibaidb.offices表复制到testdb.offices表中。
INSERT testdb.officesSELECT *FROM yiibaidb.offices;
(四)MySQL数据库导入导出
1、使用mysqldump工具将数据库导出并转储到sql文件:mysqldump -u 用户名 -p 数据库名 > 导出的文件名
mysqldump -h IP -u 用户名 -p 数据库名 > 导出的文件名
2 :(导出某张表的表结构不含数据)
mysqldump -h localhost -u root -p -d test pollution > G:\arcgisworkspace\zypdoc\test.sql
3:(导出某张表的表结构和数据,不加-d)
mysqldump -h 127.0.0.1 -u root -p test pollution > G:\arcgisworkspace\zypdoc\test.sql
mysqldump-u root
-p yiibaidb >d:\database_bak\yiibaidb.sql
其中>表示导出。
2、导入sql文件
在MySQL中新建数据库,这时是空数据库,如新建一个名为news的目标数据库
create database if not exists news;
use news;
导入文件:
source 路径+导入的文件名;
source d:\mysql.sql;
要复制一个MySQL数据库,您需要执行以下步骤:
- 首先,使用CREATE
DATABASE语句创建一个新的数据库。 - 其次,使用
mysqldump工具导出要复制的数据库的所有数据库对象和数据。 - 第三,将SQL转储文件导入新的数据库。
作为一个演示,假设要把yiibaidb数据库复制到yiibaidb_backup数据库:
步骤1, 创建yiibaidb_backup数据库:
首先,登录到MySQL数据库服务器:
C:\Users\Administrator> mysql -u root -p
Enter password: **********
然后,使用CREATE DATABASE语句如下:
CREATE DATABASE yiibaidb_backup;
第三,使用SHOW DATABASES命令验证:
SHOW DATABASES
步骤2
使用mysqldump工具将数据库对象和数据转储到SQL文件中。
假设要将数据库对象和数据库转储到位于D:\database_bak文件夹的SQL文件中,这里是以下命令:
C:\Users\Administrator> mysqldump -u root -p yiibaidb > d:\database_bak\yiibaidb.sqlEnter password: **********
基本上,此命令指示mysqldump使用具有密码的root用户帐户登录到MySQL服务器,并将数据库对象和yiibaidb数据库的数据导出到d:\database_bak\yiibaidb.sql。 请注意,运算符(>)表示导出。
步骤2
将d:\database_bak\yiibaidb.sql文件导入到yiibaidb_backup数据库。
C:\Users\Administrator> mysql -u root -p yiibaidb_backup < d:\database_bak\yiibaidb.sql
Enter password: **********
请注意,运算符(<)表示导入。
要验证导入,可以使用SHOW TABLES命令快速检查。
mysql> SHOW TABLES FROM yiibaidb_backup;
mysql复制表以及复制数据库的更多相关文章
- sql server 复制表从一个数据库到另一个数据库
sql server 复制表从一个数据库到另一个数据库 /*不同服务器数据库之间的数据操作*/ --创建链接服务器 exec sp_addlinkedserver 'ITSV ', ' ', 'SQL ...
- SQLSERVER 复制表--和复制有关的系统表
主数据库中的复制表 表名 说明 MSreplication_options 表存储供复制在内部使用的元数据. 此表存储在 master 数据库中. msdb 数据库中的复制表 表名 说明 MSagen ...
- oracle 复制表结构 复制表数据 sql 语句
1. 复制表结构及其数据: create table table_name_new as select * from table_name_old 2. 只复制表结构: create table ta ...
- mysql关联表的复制
1. 复制被参照的表: CREATE TABLE clone_product_1 LIKE product_1; INSERT INTO clone_product_1 SELECT * FROM p ...
- mysql建表和建数据库语句
一.数据库操作语言 数据库在操作时,需要使用专门的数据库操作规则和语法,这个语法就是 SQL(Structured Query Language) 结构化查询语言. SQL 的主要功能是和数据库建立连 ...
- mysql查看表使用的数据库引擎
看某个使用的引擎,在显示结果里参数engine后面的就表示该表当前用的存储引擎: mysql> show create table 表名; 看mysql支持哪些存储引擎: mysql> s ...
- 复制表结构和数据SQL语句(转)
http://www.cnblogs.com/zhengxu/articles/2206894.html 1.复制表结构及数据到新表 CREATE TABLE 新表 SELECT * FROM 旧表 ...
- 【MySQL】表的操作
" 目录 #. 表操作 1. 创建数据库 2. 进入指定库 3. 创建表 4. 添加记录 5. 查询表的数据和结构 /. 查指定表中的存储数据 /. 查指定表的结构 6. 复制表 /. 即复 ...
- Mysql数据库表的迁移和表的复制
同一台服务器上的,数据库之间的表的迁移: create table db.tablename as select * from db2.tablename; 此sql使用于mysql,从一台服务器上的 ...
随机推荐
- Julia - 字符串
字符 字符使用单引号括起来,字符是 32 位整数 julia> 'a' 'a': ASCII/Unicode U+0061 (category Ll: Letter, lowercase) ju ...
- Julia - 数学运算
算术运算符 算术运算符适用于所有的基本数值类型 +x,一元加法,就是 x 本身 -x,一元减法,x 的相反数 x + y,二元加法,做加法运算 x - y,二元减法,做减法运算 x * y,乘法,做乘 ...
- python+selenium+Firefox+pycharm版本匹配
window(2018-05-29)最新 python:3.6.1 地址https://www.python.org/downloads/release/python-361/ selenium ...
- linux中awk工具
awk sed以行为单位处理文件,awk比sed强的地方在于不仅能以行为单位还能以列为单位处理文件.awk缺省的行分隔符是换行,缺省的列分隔符是连续的空格和Tab,但是行分隔符和列分隔符都可以自定义, ...
- 核主成分分析(Kernel Principal Component Analysis, KPCA)的公式推导过程
KPCA,中文名称”核主成分分析“,是对PCA算法的非线性扩展,言外之意,PCA是线性的,其对于非线性数据往往显得无能为力,例如,不同人之间的人脸图像,肯定存在非线性关系,自己做的基于ORL数据集的实 ...
- Django xadmin的使用 (一)
Django xadmin的使用 xadmin是django的一个第三方的管理后台实现,它的功能比自带的admin功能更加强大. xadmin项目在github上的地址为:https://githu ...
- freeswitch由于ext-sip-ip地址填写错误导致32秒拆线问题
通话32秒左右就断掉 检查 profile 的 ext-sip-ip 设置ext-rtp-ip和ext-sip-ip 可以直接设置为外网IP 自建stun-server, 更新后, 过了好几个小时出现 ...
- Python遍历一个文件夹下有几个Excel文件及每个Excel文件有几个Sheet
一. 解决问题: 工作中常会遇到合并Excel文件的需求,Excel文件数量不确定,里面的Sheet 数量是可变的,Sheet Name是可变的,所以,需要用到遍历一个文件夹下有几个Excel文件,判 ...
- T-sql GroupBy语句常见问题处理
1.问题描述 现在有一张course表(含课程编号和名称)和一张sc表(含学生学号,选修课程的编号以及考试成绩),如下:现在想要查询所有课程编号.对应的课程名称以及选修该课程的所有学生的平均成绩.一开 ...
- "分辨率"到底是个什么概念?它和DPI之间是什么关系?
"分辨率"到底是个什么概念?它和DPI之间是什么关系? 分辨率:显示分辨率(屏幕分辨率)是屏幕图像的精密度,是指显示器所能显示的像素有多少.由于屏幕上的点.线和面都是由像素组成的, ...