阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Mariadb学习总结(四):数据的插入删除与修改

34次阅读
没有评论

共计 3451 个字符,预计需要花费 9 分钟才能阅读完成。

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

那么?这篇文章就简单写到这吧~~

阿里云 2 核 2G 服务器 3M 带宽 61 元 1 年,有高配

腾讯云新客低至 82 元 / 年,老客户 99 元 / 年

代金券:在阿里云专用满减优惠券

正文完
星哥说事-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2024-07-24发表,共计3451字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中