文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

MariaDB中如何实现数据的插入、修改和删除

2023-06-27 17:42

关注

小编给大家分享一下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中如何实现数据的插入、修改和删除”有了一定的了解,如果想了解更多相关知识,欢迎关注编程网行业资讯频道,感谢各位的阅读!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯