您好,登錄后才能下訂單哦!
這篇文章主要講解了“Mariadb數據的插入、刪除與修改方法”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“Mariadb數據的插入、刪除與修改方法”吧!
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] ... ]
表結構如下:
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)
MariaDB [mydb]> INSERT INTO user VALUES(1,'test','test',NOW(),NOW(),'127.0.0.1');
因為在很多時候有些值是默認的,所以我們可以指定為哪些列插入數據,而其他列則使用默認值,如下:
MariaDB [mydb]> INSERT INTO user(username,password) VALUES('test2','test2');
同樣的,插入特定列數據還可以這樣寫:
MariaDB [mydb]> INSERT INTO user SET username='test3',password='test3';
這樣就僅僅插入了用戶名和密碼,其他值則使用默認。
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)
很多時候我們會有使用一條INSERT語句向數據表插入多條記錄的需求,就可以這樣寫:
MariaDB [mydb]> INSERT INTO user(username,password) VALUES('test4','test4'),('test5', -> 'test5');
當使用的存儲引擎(MyISAM, MEMORY, MERGE)使用表級鎖的時候,可以使用LOW_PRIORITY| HIGH_PRIORITY這兩個關鍵字: 當使用LOW_PRIORITY關鍵字時,當沒有客戶端再讀取該表時才寫入數據。 當使用HIGH_PRIORITY時,INSERT語句具有同SELECT語句一樣的優先級。(默認策略)
所以,當INSERT語句執行前有SELECT語句執行時,INSERT阻塞并等待SELECT讀取完畢,但此時,如果有SELECT再次進入調度,則SELECT被阻塞(按理讀鎖可以直接讀)但此時因為INSERT語句跟SELECT語句有同樣的優先級,所以SELECT要等INSERT結束才能執行,所以INSERT可以加LOW_PRIORITY來優化讀取速度。
這里慢慢看吧,對鎖這個東西懂的不是很多。
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]
當不使用WHERE子句約束選擇條件的時候,則更新所有數據,例如,修改user表所有記錄的登陸時間為現在:
MariaDB [mydb]> UPDATE user SET logtime=NOW(); Query OK, 5 rows affected (0.01 sec) Rows matched: 5 Changed: 5 Warnings: 0
MariaDB [mydb]> UPDATE user SET logip='127.0.0.1' ORDER BY regtime LIMIT 3;
ORDER BY語句可以用于SELECT UPDATE DELETE等,是指示該表輸出、刪除、更新時遵循該表哪個字段排列。 例如以上,ORDER BY regtime就是根據注冊時間來正序排列更新,并且配合LIMIT語句只更新了前三行。
再使用DESC來指定倒敘排列,例如:ORDER BY regtime DESC
LIMIT語句:用于限制查詢結果的條數。 用法:
LIMIT[位置偏移量,]行數
第一行從0開始,所以以下:
SELECT * FROM user LIMIT 2,2; //從第3行開始,取兩行,即取第3、4條記錄。
MariaDB [mydb]> UPDATE user SET logip='192.168.1.2' WHERE username='test2';
因為WHERE子句也有很多東西,這里就不過多貼內容了。
LOW_PRIORITY:這個跟INSERT的LOW_PRIORITY是一樣的。
MariaDB [mydb]> REPLACE INTO user VALUES(1,'test111','test111',NOW(),NOW(),'192.168.1.1');
以上這條語句是MariaDB的擴展SQL,相當于刪除重復(主鍵或唯一索引)的記錄再添加新的記錄。
好像有點雞肋?….
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 ...]]
不使用WHERE語句來約束條件時,則刪除所有數據,如下:
MariaDB [mydb]> DELETE FROM user;
MariaDB [mydb]> DELETE FROM user WHERE username='test1';
感謝各位的閱讀,以上就是“Mariadb數據的插入、刪除與修改方法”的內容了,經過本文的學習后,相信大家對Mariadb數據的插入、刪除與修改方法這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。