mysql复制表和复制数据库

发布时间:2018-11-15  栏目:MySQL  评论:0 Comments

SQL

mysql表之间的复制,同数据库及见仁见智数据库

Mysql的语句

俺们好事先将test下之t1表的组织导出来,然后新建立一个test1.t1发明。

实践下语句

insert into test1.t1 select * from test.t1 limit 2 (limit限制条数)

假设当一个数据库中不怕是

insert into t1 select * from t2 limit 2

假使表结构不同等的蝇头摆设表,可以设想、、参考下面的语句

 

INSERT into db_ds_edu.t_exam_student(stu_id,stu_number,stu_name,school_id,campus_id,grade_id,class_id,xuebu_id) 
  SELECT stu.id 
     , stu.student_num 
    ,person.name 
     , stu.school_id 
     , stu.campus_id 
     , stu.grade_id 
     , stu.clas_id 
     , stu.xuebu_id 
FROM 
  db_ds.t_stu_info AS stu 
    ,db_ds.t_p_person_info as person 
    WHERE stu.person_id = person.id 

 

 

insert into test1.t1 select * from test.t1 limit 2

http://www.bkjia.com/Mysql/924603.htmlwww.bkjia.comtruehttp://www.bkjia.com/Mysql/924603.htmlTechArticlemysql表之间的复制,同数据库和不同数据库
Mysql的语句
我们可优先将test下之t1表的构造导出来,然后新成立一个test1.t1发明。
执行下语句…

  1. INSERT testdb.offices

  2. SELECT *

  3. FROM yiibaidb.offices;

个中于运用select
 into 语句子与insert into select
语句时,新表要提早立,并且新表与旧表的字段属性要一致才可以。

as用来创造相同表结构并复制源表数据

实例:INSERT INTO Websites (name,
country) SELECT
app_name, country FROM
apps;

(四)MySQL数据库导入导出

 

  1. CREATE TABLE if not exists new_table

  2. SELECT col1, col2, col3

  3. FROM

  4. existing_table

  5. WHERE

  6. conditions;

其次,通过以那个组织于示例数据库(yiibaidb)中的offices申复制出来,在testdb蒙创造了offices表。

1、CREATE
TABLE新表
SELECT*
FROM旧表;

SELECT * INTO 新表   FROM  旧表;

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: **********

Shell

然后,使用CREATE DATABASE语词如下:

  1. CREATE DATABASE yiibaidb_backup;

SQL

第三,使用SHOW
DATABASES指令验证:

  1. SHOW DATABASES

SQL

 

步骤2

 

使用mysqldump工具将数据库对象及多少转储到SQL文件中。

若是要拿数据库对象和数据库转储到在D:\database_bak文件夹的SQL文件中,这里是以下命令:

  1. C:\Users\Administrator> mysqldump -u root -p yiibaidb > d:\database_bak\yiibaidb.sql

  2. Enter password: **********

SQL

差不多,此命令指示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: **********

Shell

请注意,运算符(<)表示导入。

一旦验证导入,可以用SHOW TABLES命快速检查。

mysql> SHOW TABLES FROM yiibaidb_backup;

INSERT INTO  新表  (column_name(s))
 SELECT   column_name(s)  FROM  旧表;

双方的分别:

拜不同数据库中的申:数据库名.表名 ,采用点
的形式。

create table 新表 as select
* from 旧表 limit 0;

新表建立以后才堪应用下的鲜独告知词:

 

(三)MySQL复制表到其它一个数据库

like用来创造完整表结构及一切目录

  1. CREATE TABLE destination_db.new_table

  2. LIKE source_db.existing_table;

  3.  

  4. INSERT destination_db.new_table

  5. SELECT *

  6. FROM source_db.existing_table;

其三,我们将数据由yiibaidb.offices发明复制到testdb.offices表中。

(一)将旧表复制到新表

(二)复制相同表结构

create table 新表 like
旧表;

SQL

create
table 新表 like 旧表;

 

  1. CREATE TABLE testdb.offices LIKE yiibaidb.offices;

 

对此mysql的复制相同表结构方式,有create
table as 和create table like 两种

该语句只是复制表结构以及数,它不见面复制和申关联的其他数据库对象,如索引,主键约束,外键约束,触发器等。

SQL

oracle支持as,也是只有表结构没有索引
oracle不支持like。

2、MySQL 数据库不支持 SELECT … INTO
语句,但支撑 INSERT INTO …
SELECT 

现实流程:

奇迹,您要拿表复制到外数据库。 在这种景象下,可采取以下语句:

INSERT INTO  新表  SELECT * FROM  旧表;

 

  1. CREATE DATABASE IF NOT EXISTS testdb;

唯有复制希望之列插入到另外一个早就存在的发明中:

 

留下评论

网站地图xml地图