1.软文推荐

2.软文推荐

3.软文推荐

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学习总结(四):数据的插入删除与修改

当使用的存储引擎(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';

本文来源:www.lxlinux.net/6036.html,若引用不当,请联系修改。

相关文章 8

1

Linux系统绿色文件具体含义 2分钟前

Linux系统中不同的文件类型有不同的表示方法, 其中颜色是一大差异,其中在Linux系统中绿色文件代表什么意思呢?下面良许教程网为大家详...

2

石嘴山云服务器_石嘴山云主机/易探云免备案vps主机租用(云服务器服务) 4分钟前

易探云服务器( 石嘴山云主机 )真正的云计算架构云服务器,配备纯SSD架构打造的高性能存储,旨在为石嘴山企业和个人用户提供优质、高效...

3

10g.biz:香港GIA+VIP线路,超稳,香港GIA云服务器仅$2.75起 7分钟前

10gbiz怎么样? 10gbiz是一家成立于2020年的国外主机服务商,提供包括独立服务器租用和VPS主机等产品,数据中心在美国洛杉矶、弗里蒙特和中...

4

使用 Filebeat 收集 Ubuntu 系统日志 10分钟前

Filebeat是用于转发和集中日志数据的轻量级传送程序。作为服务器上的代理安装,Filebeat监视您指定的日志文件或位置,收集日志事件,并将...

5

Ubuntu中安装Visual Studio Code具体方法 12分钟前

Visual Studio Code是一个轻量级但功能强大的源代码编辑器,可在桌面上运行,适用于Windows,macOS和Linux。 它内置了对JavaScript,TypeScript和Node....

6

2020年阿里云活动服务器特价 1核2G云服务器仅69.86元/年(2020年阿里巴巴) 14分钟前

阿里云每个月都会有活动,活动会推出一些特价优惠的云服务器供大家使用。那么,2020年开年采购季活动又有哪些云服务器优惠呢?此次的...

7

月神科技:香港云服务器,2核2G5M年付200元/年;美国2核2G50M仅500元/年(月神 中国) 15分钟前

月神科技是由江西月神科技有限公司运营的一家自营IDC服务商,成立于2020年,之前一直经营zkeys站(月神云),先如今拓展了业务方向,购置了...

8

Linux下openssl命令行具体使用方法 16分钟前

openssl是一个开源的加密工具箱,实现了SSL和TLS协议,并提供了通用的加密库。除了将libssl.so链接到自己的程序使用,还可以通过命令行使用...