Heim >System-Tutorial >LINUX >Zusammenfassung des Mariadb-Lernens (4): Einfügen, Löschen und Ändern von Daten
INSERT-Anweisungsformat:
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] ... ]
Die Tabellenstruktur ist wie folgt:
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');
Da einige Werte in vielen Fällen Standardwerte sind, können wir wie folgt angeben, für welche Spalten Daten eingefügt werden sollen, während andere Spalten Standardwerte verwenden:
MariaDB [mydb]> INSERT INTO user(username,password) VALUES('test2','test2');
Ähnlich kann das Einfügen spezifischer Spaltendaten auch so geschrieben werden:
MariaDB [mydb]> INSERT INTO user SET username='test3',password='test3';
Dadurch werden nur der Benutzername und das Passwort eingefügt und die Standardwerte für andere Werte verwendet.
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)
Oft müssen wir eine INSERT-Anweisung verwenden, um mehrere Datensätze in die Datentabelle einzufügen. Wir können es so schreiben:
MariaDB [mydb]> INSERT INTO user(username,password) VALUES('test4','test4'),('test5', -> 'test5');
Wenn die verwendete Speicher-Engine (MyISAM, MEMORY, MERGE) Sperren auf Tabellenebene verwendet, können Sie die beiden Schlüsselwörter LOW_PRIORITY | verwenden
Bei Verwendung des Schlüsselworts LOW_PRIORITY werden Daten geschrieben, wenn kein Client die Tabelle erneut liest.
Bei Verwendung von HIGH_PRIORITY hat die INSERT-Anweisung dieselbe Priorität wie die SELECT-Anweisung. (Standardrichtlinie)
Lesen Sie es hier langsam, ich weiß nicht viel über Schlösser.
UPDATE [LOW_PRIORITY] [IGNORE] table_reference [PARTITION (partition_list)] SET col1={expr1|DEFAULT} [,col2={expr2|DEFAULT}] ... [WHERE where_condition] [ORDER BY ...] [LIMIT row_count]
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;
Im obigen Beispiel dient ORDER BY regtime zum Sortieren und Aktualisieren in der Reihenfolge nach der Registrierungszeit, und nur die ersten drei Zeilen werden mit der LIMIT-Anweisung aktualisiert.
LIMIT-Anweisung: Wird verwendet, um die Anzahl der Abfrageergebnisse zu begrenzen.
Verwendung:
LIMIT[位置偏移量,]行数Die erste Zeile beginnt bei 0, also Folgendes:
SELECT * FROM user LIMIT 2,2; //从第3行开始,取两行,即取第3、4条记录。
MariaDB [mydb]> UPDATE user SET logip='192.168.1.2' WHERE username='test2';
LOW_PRIORITY: Dies ist dasselbe wie LOW_PRIORITY von INSERT.
MariaDB [mydb]> REPLACE INTO user VALUES(1,'test111','test111',NOW(),NOW(),'192.168.1.1');
Es scheint ein bisschen geschmacklos zu sein? ....
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';
那么?这篇文章就简单写到这吧~~
Das obige ist der detaillierte Inhalt vonZusammenfassung des Mariadb-Lernens (4): Einfügen, Löschen und Ändern von Daten. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!