您好,登錄后才能下訂單哦!
本篇內(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í)用文章!
免責(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)容。