MySQL複製表結構和表資料的SQL語句和時間函數

來源:互聯網
上載者:User

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 語句,在是用在儲存函數中將查詢結果賦值給變數的

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.