首頁 > 系統教程 > Linux > 主體

Mariadb學習總結(四):資料的插入刪除與修改

WBOY
發布: 2024-07-18 19:06:39
原創
1141 人瀏覽過
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學習總結(四):資料的插入刪除與修改

當使用的儲存引擎(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學習總結(四):資料的插入刪除與修改的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:linuxprobe.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板