首页 文章

如何在phpmyadmin中为现有表生成创建表脚本?

提问于
浏览
171

如何在phpmyadmin中为现有表生成创建表脚本?

8 回答

  • 28

    在sql选项卡中使用以下查询:

    SHOW CREATE TABLE tablename
    

    查看完整查询上面有一个名为Options的超链接,选择全文

  • 0

    运行 SHOW CREATE TABLE <table name> 查询 .

  • 15

    Mysqladmin可以完成保存create table脚本的工作 .

    Step 1, create a table, insert some rows:

    create table penguins (id int primary key, myval varchar(50))
    insert into penguins values(2, 'werrhhrrhrh')
    insert into penguins values(25, 'weeehehehehe')
    select * from penguins
    

    Step 2, use mysql dump command:

    mysqldump --no-data --skip-comments --host=your_database_hostname_or_ip.com -u your_username --password=your_password your_database_name penguins > penguins.sql
    

    Step 3, observe the output in penguins.sql:

    /*!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 */;
    DROP TABLE IF EXISTS `penguins`;
    /*!40101 SET @saved_cs_client     = @@character_set_client */;
    /*!40101 SET character_set_client = utf8 */;
    CREATE TABLE `penguins` (
      `id` int(11) NOT NULL,
      `myval` varchar(50) DEFAULT NULL,
      PRIMARY KEY (`id`)
    ) ENGINE=InnoDB DEFAULT CHARSET=latin1;
    /*!40101 SET character_set_client = @saved_cs_client */;
    /*!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 */;
    

    输出被上面和下面的许多执行条件令牌混乱 . 如果您在下一步中不需要它们,可以将它们过滤掉 .

    Step 4 (Optional), filter out those extra executional-condition tokens this way:

    mysqldump --no-data --skip-comments --compact --host=your_database_hostname_or_ip.com -u your_username --password=your_password your_database_name penguins > penguins.sql
    

    Which produces final output:

    eric@dev /home/el $ cat penguins.sql
    
    DROP TABLE IF EXISTS `penguins`;
    CREATE TABLE `penguins` (
      `id` int(11) NOT NULL,
      `myval` varchar(50) DEFAULT NULL,
      PRIMARY KEY (`id`)
    ) ENGINE=InnoDB DEFAULT CHARSET=latin1;
    
  • 7

    直接查询information_schema.columns:

    select * from information_schema.columns 
    where table_name = 'your_table' and table_schema = 'your_database'
    
  • -2

    这可能是迟到的回复 . 但它可能会帮助别人 . 在MY SQL Workbench中非常简单(我正在使用Workbench版本6.3和My SQL版本5.1社区版):右键单击要为其创建脚本的表,选择“复制到剪贴板 - >创建语句”选项 . 只需粘贴您想要获取创建脚本的任何文本编辑器 .

  • 2

    运行查询是sql选项卡

    SHOW CREATE TABLE tableName

    点击

    选项 - >选择全文 - >单击“开始”

    复制Create Table查询并粘贴要创建新表的位置 .

  • 361

    使用PHP函数 .

    当然查询功能($ this-> model)你必须改为自己的 .

    /**
     * Creating a copy table based on the current one
     * 
     * @param type $table_to_copy
     * @param type $new_table_name
     * @return type
     * @throws Exception
     */
    public function create($table_to_copy, $new_table_name)
    {
        $sql = "SHOW CREATE TABLE ".$table_to_copy;
    
        $res = $this->model->queryRow($sql, PDO::FETCH_ASSOC);
    
        if(!filled($res['Create Table']))
            throw new Exception('Could not get the create code for '.$table_to_copy);
    
        $newCreateSql = preg_replace(array(
            '@CREATE TABLE `'.$table_to_copy.'`@',
            '@KEY `'.$table_to_copy.'(.*?)`@',
            '@CONSTRAINT `'.$table_to_copy.'(.*?)`@',
            '@AUTO_INCREMENT=(.*?) @',
        ), array(
            'CREATE TABLE `'.$new_table_name.'`',
            'KEY `'.$new_table_name.'$1`',
            'CONSTRAINT `'.$new_table_name.'$1`',
            'AUTO_INCREMENT=1 ',
        ), $res['Create Table']);
    
        return $this->model->exec($newCreateSql);
    }
    
  • 1

    还有一种方法 . 在phpMyAdmin的左侧面板中选择目标表,单击Export选项卡,取消选择Data block并单击Go按钮 .

相关问题