溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

MySQL特有的SQL語(yǔ)句介紹

發(fā)布時(shí)間:2021-09-14 17:01:01 來源:億速云 閱讀:112 作者:chen 欄目:MySQL數(shù)據(jù)庫(kù)

本篇內(nèi)容介紹了“MySQL特有的SQL語(yǔ)句介紹”的有關(guān)知識(shí),在實(shí)際案例的操作過程中,不少人都會(huì)遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

create語(yǔ)句

如果要復(fù)制表結(jié)構(gòu)信息,下面的語(yǔ)句真是簡(jiǎn)潔有力,會(huì)把表test1的結(jié)構(gòu)復(fù)制出來。

   create table test like test1;

select into語(yǔ)句

  select into語(yǔ)句可以很快的從表里取出數(shù)據(jù),快速構(gòu)造出一個(gè)表來。

SELECT vale1, value2 into Table2 from Table1
   這里會(huì)要求目標(biāo)表Table2不存在,因?yàn)樵诓迦霑r(shí)會(huì)自動(dòng)創(chuàng)建表Table2

insert語(yǔ)句中的表達(dá)式

MySQL里的insert語(yǔ)句還是很豐富的。比如下面的動(dòng)態(tài)值,設(shè)置表達(dá)式的方式,MySQL就有自己的口味。

   INSERT INTO tbl_name (col1,col2) VALUES(15,col1*2);  

 --ok
    INSERT INTO tbl_name (col1,col2) VALUES(col2*2,15);  

--wrong

insert語(yǔ)句

MySQL支持的特有的insert語(yǔ)句,下面的第一種是mysqldump導(dǎo)出的語(yǔ)句格式,這種方式比較清晰,相比多條SQL語(yǔ)句效果要好太多。

   INSERT INTO table (a, b, c) VALUES (1,2,3) ,(2,3,4);

下面的語(yǔ)句看起來比較特別,解析MySQL binlog會(huì)發(fā)現(xiàn),里面的insert語(yǔ)句是這個(gè)樣子的。

  INSERT INTO table SET a=1, b=2, c=3;

drop語(yǔ)句

MySQL里面的drop語(yǔ)句還是蠻有特點(diǎn),它不會(huì)像Oracle那樣可以單獨(dú)刪除索引,刪除是始終要和表關(guān)聯(lián)起來,這樣想來和IOT的特點(diǎn)還是蠻對(duì)味的。

如果你直接刪除一個(gè)索引,就會(huì)拋出如下的錯(cuò)誤。

    ?Drop index ind_account_id2;

    ?ERROR 1064 (42000):

  可以使用如下的方式:

drop index ind_account_id2 on t_user_login_record;

Query OK, 0 rows affected (0.01 sec)

Records: 0  Duplicates: 0  Warnings: 0

  或者是用比較經(jīng)典的寫法:

alter table t_user_login_record drop index account;

級(jí)聯(lián)刪除

MySQL里面支持級(jí)聯(lián)刪除,下面的語(yǔ)句會(huì)級(jí)聯(lián)刪除數(shù)據(jù),這一點(diǎn)Oracle目前還是不支持這種方式的。

delete A, B from A, B where A.id = B.aid

級(jí)聯(lián)更新

update A, B set A.a = a1, B.b = b1 where A.id = B.aid

change modify

change,modify用法有些相似,但是細(xì)究起來還是有自己適合的使用場(chǎng)景,比如與修改字段b的類型或者屬性,change還更適合于修改字段名稱,修改數(shù)據(jù)類型modify更加直接一些。

ALTER TABLE t1 CHANGE b b BIGINT NOT NULL;
ALTER TABLE t1 MODIFY b BIGINT NOT NULL;

replace語(yǔ)句

 MySQL里面的replace語(yǔ)句還是很有特色的,和Oracle里面的merge有一拼,它支持兩種模式,數(shù)據(jù)值和子查詢的方式

replace into x values(...)

或者

replace into x select * from y

renmae語(yǔ)句

 這個(gè)功能很可能被大家忽略,但是實(shí)際上這個(gè)功能很實(shí)用,比如要把一個(gè)表清理表,如果你把它歸檔到一個(gè)歷史數(shù)據(jù)庫(kù)中而暫時(shí)不清理數(shù)據(jù),這種方式就很快捷。

rename table testsync.t_fund_info to test.t_user_login_record;

Query OK, 0 rows affected (0.05 sec)

limit語(yǔ)法

  limit的使用算是MySQL中很經(jīng)典的使用方法了,它也支持多種模式。

比如只返回第2條結(jié)果

select * from x

limit 2

返回第2條到第12條的結(jié)果

or limit 2, 10

order by的妙用

如果下面的數(shù)據(jù)需要排序,

select *from test order by name;
+------+------+
| id   | name |
+------+------+
|    1 | aa1  |
|    3 | aa10 |
|    4 | aa11 |
|    2 | aa2  |
+------+------+
我們希望是按照aa1,aa2,aa10,aa11的順序來顯示,直接這樣寫就可以了。

select *from test order by name+0;
+------+------+
| id   | name |
+------+------+
|    1 | aa1  |
|    2 | aa2  |
|    3 | aa10 |
|    4 | aa11 |
+------+------+

特有的函數(shù)

如果需要截取一下字符串,比如截取出數(shù)字,就有很多種實(shí)現(xiàn)方式。

比如下面的方式就可行。

mysql> select replace('123456G', right('123456G',1), '');

+--------------------------------------------+

| replace('123456G', right('123456G',1), '')

|+--------------------------------------------+

| 123456                                    

|+--------------------------------------------+

或者是使用cast來過濾

> select cast('123124aabc' as unsigned); 

+--------------------------------+

| cast('123124aabc' as unsigned) |

+--------------------------------+

|                         123124 |

+--------------------------------+

1 row in set, 1 warning (0.01 sec)

“MySQL特有的SQL語(yǔ)句介紹”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI