zoukankan      html  css  js  c++  java
  • MySQL 复制表

    步骤一:

    获取数据表的完整结构。

    mysql> SHOW CREATE TABLE runoob_tbl G;
    *************************** 1. row ***************************
           Table: runoob_tbl
    Create Table: CREATE TABLE `runoob_tbl` (
      `runoob_id` int(11) NOT NULL auto_increment,
      `runoob_title` varchar(100) NOT NULL default '',
      `runoob_author` varchar(40) NOT NULL default '',
      `submission_date` date default NULL,
      PRIMARY KEY  (`runoob_id`),
      UNIQUE KEY `AUTHOR_INDEX` (`runoob_author`)
    ) ENGINE=InnoDB 
    1 row in set (0.00 sec)
    
    ERROR:
    No query specified

    步骤二:

    修改SQL语句的数据表名,并执行SQL语句。

    mysql> CREATE TABLE `clone_tbl` (
      -> `runoob_id` int(11) NOT NULL auto_increment,
      -> `runoob_title` varchar(100) NOT NULL default '',
      -> `runoob_author` varchar(40) NOT NULL default '',
      -> `submission_date` date default NULL,
      -> PRIMARY KEY  (`runoob_id`),
      -> UNIQUE KEY `AUTHOR_INDEX` (`runoob_author`)
    -> ) ENGINE=InnoDB;
    Query OK, 0 rows affected (1.80 sec)

    步骤三:

    执行完第二步骤后,你将在数据库中创建新的克隆表 clone_tbl。 如果你想拷贝数据表的数据你可以使用 INSERT INTO... SELECT 语句来实现。

    mysql> INSERT INTO clone_tbl (runoob_id,
        ->                        runoob_title,
        ->                        runoob_author,
        ->                        submission_date)
        -> SELECT runoob_id,runoob_title,
        ->        runoob_author,submission_date
        -> FROM runoob_tbl;
    Query OK, 3 rows affected (0.07 sec)
    Records: 3  Duplicates: 0  Warnings: 0

    执行以上步骤后,你将完整的复制表,包括表结构及表数据。

    另一种方法:

    CREATE TABLE targetTable LIKE sourceTable;
    INSERT INTO targetTable SELECT * FROM sourceTable;
    

      

    可以拷贝一个表中其中的一些字段:

    CREATE TABLE newadmin AS
    (
        SELECT username, password FROM admin
    )

    可以将新建的表的字段改名:

    CREATE TABLE newadmin AS
    (  
        SELECT id, username AS uname, password AS pass FROM admin
    )

    可以拷贝一部分数据:

    CREATE TABLE newadmin AS
    (
        SELECT * FROM admin WHERE LEFT(username,1) = 's'
    )

    可以在创建表的同时定义表中的字段信息:

    CREATE TABLE newadmin
    (
        id INTEGER NOT NULL AUTO_INCREMENT PRIMARY KEY
    )
    AS
    (
        SELECT * FROM admin
    )
  • 相关阅读:
    C# WebApi 获取客户端ip地址
    C# 构造函数快捷键
    2 .SHELL 5~10节
    Spring项目集成apidoc生成api接口文档
    根据域名查找对应的ip及端口
    高质量SQL的30条建议
    1 .shell编程1~5
    CentOS7安装mysql8
    编译安Apache2.4.43报错checking for APR... no configure: error: APR not found. Please read the documentation.
    rm -rf * 的正确用法
  • 原文地址:https://www.cnblogs.com/zhoujunok/p/12849353.html
Copyright © 2011-2022 走看看