新聞中心
MariaDB數(shù)據(jù)庫管理系統(tǒng)是 MySQL 的一個(gè)分支,主要由開源社區(qū)在維護(hù),采用GPL授權(quán)許可 MariaDB的目的是完全兼容MySQL,包括API和命令行,使之能輕松成為MySQL的代替品,下面為大家詳細(xì)講解一下MariaDB中數(shù)據(jù)的插入、修改和刪除。

創(chuàng)新互聯(lián)執(zhí)著的堅(jiān)持網(wǎng)站建設(shè),微信小程序開發(fā);我們不會(huì)轉(zhuǎn)行,已經(jīng)持續(xù)穩(wěn)定運(yùn)營10余年。專業(yè)的技術(shù),豐富的成功經(jīng)驗(yàn)和創(chuàng)作思維,提供一站式互聯(lián)網(wǎng)解決方案,以客戶的口碑塑造品牌,攜手廣大客戶,共同發(fā)展進(jìn)步。
INSERT插入數(shù)據(jù)
INSERT語句格式:
INSERT [LOW_PRIORITY | DELAYED | HIGH_PRIORITY] [IGNORE]
[INTO] tbl_name [PARTITION (partition_list)] [(col,...)]
{VALUES | VALUE} ({expr | DEFAULT},...),(...),...
[ ON DUPLICATE KEY UPDATE
col=expr
[, col=expr] ... ]
表結(jié)構(gòu)如下:
MariaDB [mydb]> DESC user;
+----------+-------------+------+-----+---------------------+----------------+
| Field | Type | Null | Key | Default | Extra |
+----------+-------------+------+-----+---------------------+----------------+
| id | int(11) | NO | PRI | NULL | auto_increment |
| username | varchar(10) | NO | | NULL | |
| password | varchar(10) | NO | | NULL | |
| regtime | timestamp | NO | | CURRENT_TIMESTAMP | |
| logtime | timestamp | NO | | 0000-00-00 00:00:00 | |
| logip | varchar(20) | YES | | NULL | |
+----------+-------------+------+-----+---------------------+----------------+
6 rows in set (0.01 sec)
插入單條數(shù)據(jù)
MariaDB [mydb]> INSERT INTO user VALUES(1,'test','test',NOW(),NOW(),'127.0.0.1');
因?yàn)樵诤芏鄷r(shí)候有些值是默認(rèn)的,所以我們可以指定為哪些列插入數(shù)據(jù),而其他列則使用默認(rèn)值,如下:
MariaDB [mydb]> INSERT INTO user(username,password) VALUES('test2','test2');
同樣的,插入特定列數(shù)據(jù)還可以這樣寫:
MariaDB [mydb]> INSERT INTO user SET username='test3',password='test3';
這樣就僅僅插入了用戶名和密碼,其他值則使用默認(rèn)。
MariaDB [mydb]> SELECT * FROM user;
+----+----------+----------+---------------------+---------------------+-----------+
| id | username | password | regtime | logtime | logip |
+----+----------+----------+---------------------+---------------------+-----------+
| 1 | test | test | 2018-02-24 15:43:41 | 2018-02-24 15:43:41 | 127.0.0.1 |
| 2 | test2 | test2 | 2018-02-24 15:45:16 | 0000-00-00 00:00:00 | NULL |
| 3 | test3 | test3 | 2018-02-24 15:46:56 | 0000-00-00 00:00:00 | NULL |
+----+----------+----------+---------------------+---------------------+-----------+
3 rows in set (0.00 sec)
插入多行數(shù)據(jù)
很多時(shí)候我們會(huì)有使用一條INSERT語句向數(shù)據(jù)表插入多條記錄的需求,就可以這樣寫:
MariaDB [mydb]> INSERT INTO user(username,password) VALUES('test4','test4'),('test5',
-> 'test5');
莫名其妙的優(yōu)先級(jí)?
Mariadb學(xué)習(xí)總結(jié)(四):數(shù)據(jù)的插入刪除與修改Mariadb學(xué)習(xí)總結(jié)(四):數(shù)據(jù)的插入刪除與修改
當(dāng)使用的存儲(chǔ)引擎(MyISAM, MEMORY, MERGE)使用表級(jí)鎖的時(shí)候,可以使用LOW_PRIORITY| HIGH_PRIORITY這兩個(gè)關(guān)鍵字: 當(dāng)使用LOW_PRIORITY關(guān)鍵字時(shí),當(dāng)沒有客戶端再讀取該表時(shí)才寫入數(shù)據(jù)。 當(dāng)使用HIGH_PRIORITY時(shí),INSERT語句具有同SELECT語句一樣的優(yōu)先級(jí)。(默認(rèn)策略)
所以,當(dāng)INSERT語句執(zhí)行前有SELECT語句執(zhí)行時(shí),INSERT阻塞并等待SELECT讀取完畢,但此時(shí),如果有SELECT再次進(jìn)入調(diào)度,則SELECT被阻塞(按理讀鎖可以直接讀)但此時(shí)因?yàn)镮NSERT語句跟SELECT語句有同樣的優(yōu)先級(jí),所以SELECT要等INSERT結(jié)束才能執(zhí)行,所以INSERT可以加LOW_PRIORITY來優(yōu)化讀取速度。
這里慢慢看吧,對(duì)鎖這個(gè)東西懂的不是很多。
修改數(shù)據(jù)
UPDATE語句語法如下:
UPDATE [LOW_PRIORITY] [IGNORE] table_reference
[PARTITION (partition_list)]
SET col1={expr1|DEFAULT} [,col2={expr2|DEFAULT}] ...
[WHERE where_condition]
[ORDER BY ...]
[LIMIT row_count]
更新所有
當(dāng)不使用WHERE子句約束選擇條件的時(shí)候,則更新所有數(shù)據(jù),例如,修改user表所有記錄的登陸時(shí)間為現(xiàn)在:
MariaDB [mydb]> UPDATE user SET logtime=NOW();
Query OK, 5 rows affected (0.01 sec)
Rows matched: 5 Changed: 5 Warnings: 0
更新最早注冊(cè)的三個(gè)人的登錄IP為127.0.0.1
MariaDB [mydb]> UPDATE user SET logip='127.0.0.1' ORDER BY regtime LIMIT 3;
ORDER BY語句可以用于SELECT UPDATE DELETE等,是指示該表輸出、刪除、更新時(shí)遵循該表哪個(gè)字段排列。 例如以上,ORDER BY regtime就是根據(jù)注冊(cè)時(shí)間來正序排列更新,并且配合LIMIT語句只更新了前三行。
再使用DESC來指定倒敘排列,例如:ORDER BY regtime DESC
LIMIT語句:用于限制查詢結(jié)果的條數(shù)。 用法:
LIMIT[位置偏移量,]行數(shù)
第一行從0開始,所以以下:
SELECT * FROM user LIMIT 2,2; //從第3行開始,取兩行,即取第3、4條記錄。
使用WHERE語句選中特定行更新
MariaDB [mydb]> UPDATE user SET logip='192.168.1.2' WHERE username='test2';
因?yàn)閃HERE子句也有很多東西,這里就不過多貼內(nèi)容了。
LOW_PRIORITY:這個(gè)跟INSERT的LOW_PRIORITY是一樣的。
REPLACE語句
MariaDB [mydb]> REPLACE INTO user VALUES(1,'test111','test111',NOW(),NOW(),'192.168.1.1');
以上這條語句是MariaDB的擴(kuò)展SQL,相當(dāng)于刪除重復(fù)(主鍵或唯一索引)的記錄再添加新的記錄。
好像有點(diǎn)雞肋?….
刪除數(shù)據(jù)
DELETE語語法:
DELETE [LOW_PRIORITY] [QUICK] [IGNORE]
FROM tbl_name [PARTITION (partition_list)]
[WHERE where_condition]
[ORDER BY ...]
[LIMIT row_count]
[RETURNING select_expr
[, select_expr ...]]
刪除所有數(shù)據(jù)
不使用WHERE語句來約束條件時(shí),則刪除所有數(shù)據(jù),如下:
MariaDB [mydb]> DELETE FROM user;
使用WHERE語句約束選中行
MariaDB [mydb]> DELETE FROM user WHERE username='test1';
新聞標(biāo)題:MariaDB中數(shù)據(jù)的插入、修改和刪除
文章來源:http://www.fisionsoft.com.cn/article/cdosdgo.html


咨詢
建站咨詢
