Mysql 复制表结构 及其表的内容
顺便转一下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出来,改名字后再导回去或者直接在命令行中运行
mysql 中如何在同一张表中复制记录
例子1 复制完全相同的记录(条件是表结构中没有auto_increment,和uniq字段)
mysql> select * from president;
 +------------+---------------+--------+---------------------+-------+------------+------------+
 | last_name  | first_name    | suffix | city                | state | birth      | death      |
 +------------+---------------+--------+---------------------+-------+------------+------------+
 | Washington | George        | NULL   | Wakefield           | VA    | 1732-02-22 | 1799-12-14 |
 | Adams      | John          | NULL   | Braintree           | MA    | 1735-10-30 | 1826-07-04 |
 | Jefferson  | Thomas        | NULL   | Albemarle County    | VA    | 1743-04-13 | 1826-07-04 |
 | Madison    | James         | NULL   | Port Conway         | VA    | 1751-03-16 | 1836-06-28 |
mysql> desc president;
 +------------+-------------+------+-----+---------+-------+
 | Field      | Type        | Null | Key | Default | Extra |
 +------------+-------------+------+-----+---------+-------+
 | last_name  | varchar(15) | NO   | MUL | NULL    |       |
 | first_name | varchar(15) | NO   |     | NULL    |       |
 | suffix     | varchar(5)  | YES  |     | NULL    |       |
 | city       | varchar(20) | NO   |     | NULL    |       |
 | state      | varchar(2)  | NO   |     | NULL    |       |
 | birth      | date        | NO   |     | NULL    |       |
 | death      | date        | YES  |     | NULL    |       |
 +------------+-------------+------+-----+---------+-------+
在这种情况下要在表中复制一条Washington  George 的记录,输入以下命令即可:
mysql> insert into president select * from president where last_name='Washington';
例子2:新增部分字段相同的记录
mysql> select * from manager;
 +----+-------------+-------+-------------+----------+------------+---------------------+
 | id | enable_flag | types | account     | password | location   | reg_date            |
 +----+-------------+-------+-------------+----------+------------+---------------------+
 |  1 |           1 |     1 | abcd        | 1234567  |            | 0000-00-00 00:00:00 |
 | 13 |           1 |     2 | anonymous   | 654123   | 0100000000 | 2003-06-30 17:29:04 |
其表结构如下:
mysql> desc manager;
 +-------------+-------------+------+-----+---------------------+----------------+
 | Field       | Type        | Null | Key | Default             | Extra          |
 +-------------+-------------+------+-----+---------------------+----------------+
 | id          | int(4)      | NO   | PRI | NULL                | auto_increment |
 | enable_flag | smallint(2) | NO   |     | 0                   |                |
 | types       | smallint(2) | NO   |     | 0                   |                |
 | account     | varchar(50) | NO   | UNI |                     |                |
 | password    | varchar(50) | NO   |     |                     |                |
 | location    | varchar(10) | NO   |     |                     |                |
 | reg_date    | datetime    | NO   |     | 0000-00-00 00:00:00 |                |
 ------------+-------------+------+-----+---------------------+----------------+
若想通过新增一条和manager 表中的anonymous这条记录,其它字段内容相同,但名字不同的记录(account为test)。则得用以下方法:
 因为manager表的 id字段是auto_increment,而且account字段是具有唯一性的(UNI).所以我们得具体指定这两个字段的值。
mysql> insert into manager select '22',enable_flag,types,'test',password, location,reg_date from manager where account='anonymous';
Mysql 复制表结构 及其表的内容的更多相关文章
- mysql复制表结构和表数据
		我们知道,在SQL Server中,如果要复制表结构和表数据的话,可以使用select into语句. select * into yanggb1 from yanggb; 但是在MySQL中是不支持 ... 
- Java连接MySQL数据库。编写一个应用程序,在主类Test_4类中,通过JDBC访问stu数据库,显示t_student表中的内容(表结构见表1),显示效果自己设计。
		题目2:编写一个应用程序,在主类Test_4类中,通过JDBC访问stu数据库,显示t_student表中的内容(表结构见表1),显示效果自己设计.之后,可根据显示的内容进行某条记录的删除(以id为条 ... 
- 【MySQL】MySQL复制表结构、表数据
		平常,复制.备份表,一般都直接操作IDE完成.但有时,一些初始化数据的脚本,在操作数据前,最好备份下操作表的结构.数据,不至于出错了被置于为难的境地. 所以复制表结构.表数据的语句就派上用场. > ... 
- oracle 快速复制表结构、表数据
		1.情景展示 根据现有的表,建一个新的表,要求:新表的结构与原有表的表结构一模一样,如何快速实现? 根据现有的表,建一个新的表,要求:新表的结构.数据与原表一模一样,如何实现快速复制旧表? 2.解 ... 
- SQL复制表结构或表数据
		需求: 软件开发过程中,一般会部署两个数据库:一个测试数据库提供给开发和测试过程使用:一个运维数据库提供上线使用.当需求变化需增加表时,会遇到数据库表结构或表数据同步的问题,这时就要复制表结构或表数据 ... 
- oracle表结构和表内容差异比对
		oracle表结构和表内容差异比对 oracle中有三种集合操作,他们会把左边和右边的select 结果集进行集合操作. union 并集 intersect 交集 minus 差集 假设有如下两张表 ... 
- oracle表结构和表内容差异比对【原】
		oracle表结构和表内容差异比对 oracle中有三种集合操作,他们会把左边和右边的select 结果集进行集合操作. union 并集 intersect 交集 minus 差集 假设有如下两张表 ... 
- Mysql导出(多张表)表结构及表数据 mysqldump用法
		命令行下具体用法如下: mysqldump -u用戶名 -p密码 -d 數據库名 表名 脚本名; 1.导出數據库為dbname的表结构(其中用戶名為root,密码為dbpasswd,生成的脚 ... 
- mysql导出/导入表结构以及表数据
		导出: 命令行下具体用法如下: mysqldump -u用戶名 -p密码 -d 数据库名 表名 脚本名; 1.导出数据库为dbname的表结构(其中用戶名为root,密码为dbpasswd,生成的脚 ... 
随机推荐
- 解析Function.prototype.bind
			简介 对于一个给定的函数,创造一个绑定对象的新函数,这个函数和之前的函数功能一样,this值是它的第一个参数,其它参数,作为新的函数的给定参数. bind的作用 bind最直接的作用就是改变this的 ... 
- extjs folder is lost解决方法 和 FineUI主题切换时 iframe内的内容主题不变的解决方法
			错误原因:extjs包和FineUI版本不一致 或者是 webconfig配置中 没有设置为任何人可访问 解放方法下载和FineUI版本相同的extjs包就ok了 解决方法:FineUI主题切换时 ... 
- 查看kafka的group.id
			kafka/config目录下的consumer.properties中可以看到 
- 使用cocoapods后 三方库的头文件没有代码提示?
			选择Target -> Build Settings 菜单,找到\”User Header Search Paths\”设置项 新增一个值"${SRCROOT}",并且选择\ ... 
- JedisPool操作
			Jedis 使用 commons-pool 完成池化实现. 先做个配置文件(properties文件): #最大分配的对象数 redis.pool.maxActive=1024 #最大能够保持idel ... 
- C/C++中的常成员函数
			代码: #include <iostream> using namespace std; class A{ public: void func1(){ cout<<" ... 
- 线段树练习 codevs 1080
			/* codevs 1080 线段树练习 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题解 查看运行结果 题目描述 Description 一行N个方格,开 ... 
- sql server高效分页控件及c#调用实例
			第一.首先在sqlserver中创建一个存储过程 USE [BZY] GO /****** 对象: StoredProcedure [dbo].[up_ProcCustomPage2005_New] ... 
- window下配置ssh key
			在windows下通过msysGit(Git for windows.Git Bash)配置SSH Keys连接GitHub. 1.检查本机是否有ssh key设置 $ cd ~/.ssh 或cd . ... 
- 开源日志系统 log4c 使用心得+总结
			http://blog.csdn.net/sky_qing/article/details/7208645 一.安装: 我看网上好多人介绍log4c安装的时候都说有两个步骤:先下载expat安装包并安 ... 
