您好,欢迎访问一九零五行业门户网

MySQL复制表结构和表数据的SQL语句和时间函数

mysql复制表结构和表数据的语句:完成表结构和表数据同时复制(创建表并复制数据)
1、mysql复制表结构和表数据的语句:完成表结构和表数据同时复制(创建表并复制数据)
mysql> create table tmp_table select * from dede_news;
query ok, 628 rows affected (2.04 sec)
records: 628  duplicates: 0  warnings: 0
说明:这种方法的一个最不好的地方就是新表中没有了旧表的primary key、extra(auto_increment)等属性,,需要自己手动添加。
2、mysql复制表结构但不复制表数据的语句:(创建表并复制数据,通过条件语句控制数据为空)
mysql> create table tmp_table select * from dede_news where 1=2;
query ok, 0 rows affected (0.09 sec)
records: 0  duplicates: 0  warnings: 0
说明:通过给定1=2这个where条件,使最终选择到的数据为空,而是只复制表结构。
3、还可以通过下面的方法只复制表结构
mysql> create table tmp_table like dede_news;
query ok, 0 rows affected (0.06 sec)
4、使用insert into 表1 select 字段 from 表2可以将指定的或者全部的表2中的数据插入到表1中(前提是数据类型一致)
mysql> insert into tmp_news select * from dede_news;
query ok, 628 rows affected (0.57 sec)
records: 628  duplicates: 0  warnings: 0
其他:
1)同时删除对个表:
drop table tmp_news,tmp_table;
2)时间函数 date_sub() 和 date_add()
mysql> select now() as now,date_add(now(),interval 5 day) as add5d,date_add(now(),interval 5 month) as add5m,date_add(now(),interval 5 year) as add5y,date_sub(now(),interval 5 day) as sub5d,date_sub(now(),interval 5 month) as sub5m,date_sub(now(),interval 5 year) as sub5y\g
*************************** 1. row ***************************
  now: 2014-03-19 21:35:24
add5d: 2014-03-24 21:35:24
add5m: 2014-08-19 21:35:24
add5y: 2019-03-19 21:35:24
sub5d: 2014-03-14 21:35:24
sub5m: 2013-10-19 21:35:24
sub5y: 2009-03-19 21:35:24
1 row in set (0.00 sec)
update dede_news set createtime=date_sub(createtime,interval 1 year) where createtime > now();
说明:insert xxx into xxx select xxx from xxx  和 select xxx into xxx from xxx 两个语句的对比
在mysql中 insert xxx into xxx select xxx from xxx 语句可以将查询的结果插入到数据库表中
而使用select xxx into xxx from xxx 语句,在是用在存储函数中将查询结果赋值给变量的
其它类似信息

推荐信息