中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MariaDB中如何實現數據的插入、修改和刪除

發布時間:2022-02-19 11:15:34 來源:億速云 閱讀:209 作者:小新 欄目:開發技術

小編給大家分享一下MariaDB中如何實現數據的插入、修改和刪除,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!

MariaDB數據庫管理系統是 MySQL 的一個分支,主要由開源社區在維護,采用GPL授權許可 MariaDB的目的是完全兼容MySQL,包括API和命令行,使之能輕松成為MySQL的代替品。

MariaDB中如何實現數據的插入、修改和刪除

INSERT插入數據

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');

莫名其妙的優先級?

MariaDB中如何實現數據的插入、修改和刪除
Mariadb學習總結(四):數據的插入刪除與修改Mariadb學習總結(四):數據的插入刪除與修改

當使用的存儲引擎(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

更新最早注冊的三個人的登錄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等,是指示該表輸出、刪除、更新時遵循該表哪個字段排列。 例如以上,ORDER BY regtime就是根據注冊時間來正序排列更新,并且配合LIMIT語句只更新了前三行。

再使用DESC來指定倒敘排列,例如:ORDER BY regtime DESC

LIMIT語句:用于限制查詢結果的條數。 用法:

LIMIT[位置偏移量,]行數

第一行從0開始,所以以下:

SELECT * FROM user LIMIT 2,2;  //從第3行開始,取兩行,即取第3、4條記錄。

使用WHERE語句選中特定行更新

MariaDB [mydb]> UPDATE user SET logip='192.168.1.2' WHERE username='test2';

因為WHERE子句也有很多東西,這里就不過多貼內容了。

LOW_PRIORITY:這個跟INSERT的LOW_PRIORITY是一樣的。

REPLACE語句

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;

使用WHERE語句約束選中行

MariaDB [mydb]> DELETE FROM user WHERE username='test1';

看完了這篇文章,相信你對“MariaDB中如何實現數據的插入、修改和刪除”有了一定的了解,如果想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

墨脱县| 宁明县| 隆昌县| 清水县| 庄河市| 西充县| 建平县| 沐川县| 铁岭县| 固始县| 澎湖县| 东丰县| 大邑县| 柳林县| 长丰县| 阳春市| 荔浦县| 仁寿县| 郸城县| 鄄城县| 塔河县| 湖州市| 搜索| 罗平县| 洛宁县| 太仓市| 陵川县| 平山县| 博罗县| 铁岭市| 师宗县| 富川| 双峰县| 高平市| 灵璧县| 贵南县| 奈曼旗| 长沙市| 衡东县| 南澳县| 南华县|