MariaDB中如何实现数据的插入、修改和删除
小编给大家分享一下MariaDB中如何实现数据的插入、修改和删除,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!
MariaDB数据库管理系统是 MySQL 的一个分支,主要由开源社区在维护,采用GPL授权许可 MariaDB的目的是完全兼容MySQL,包括API和命令行,使之能轻松成为MySQL的代替品。
INSERT语句格式:
INSERT[LOW_PRIORITY|DELAYED|HIGH_PRIORITY][IGNORE][INTO]tbl_name[PARTITION(partition_list)][(col,...)]{VALUES|VALUE}({expr|DEFAULT},...),(...),...[ONDUPLICATEKEYUPDATEcol=expr[,col=expr]...]
表结构如下:
MariaDB[mydb]>DESCuser;+----------+-------------+------+-----+---------------------+----------------+|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-0000:00:00|||logip|varchar(20)|YES||NULL||+----------+-------------+------+-----+---------------------+----------------+6rowsinset(0.01sec)插入单条数据
MariaDB[mydb]>INSERTINTOuserVALUES(1,'test','test',NOW(),NOW(),'127.0.0.1');
因为在很多时候有些值是默认的,所以我们可以指定为哪些列插入数据,而其他列则使用默认值,如下:
MariaDB[mydb]>INSERTINTOuser(username,password)VALUES('test2','test2');
同样的,插入特定列数据还可以这样写:
MariaDB[mydb]>INSERTINTOuserSETusername='test3',password='test3';
这样就仅仅插入了用户名和密码,其他值则使用默认。
MariaDB[mydb]>SELECT*FROMuser;+----+----------+----------+---------------------+---------------------+-----------+|id|username|password|regtime|logtime|logip|+----+----------+----------+---------------------+---------------------+-----------+|1|test|test|2018-02-2415:43:41|2018-02-2415:43:41|127.0.0.1||2|test2|test2|2018-02-2415:45:16|0000-00-0000:00:00|NULL||3|test3|test3|2018-02-2415:46:56|0000-00-0000:00:00|NULL|+----+----------+----------+---------------------+---------------------+-----------+3rowsinset(0.00sec)插入多行数据
很多时候我们会有使用一条INSERT语句向数据表插入多条记录的需求,就可以这样写:
MariaDB[mydb]>INSERTINTOuser(username,password)VALUES('test4','test4'),('test5',->'test5');莫名其妙的优先级?
当使用的存储引擎(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)]SETcol1={expr1|DEFAULT}[,col2={expr2|DEFAULT}]...[WHEREwhere_condition][ORDERBY...][LIMITrow_count]更新所有
当不使用WHERE子句约束选择条件的时候,则更新所有数据,例如,修改user表所有记录的登陆时间为现在:
MariaDB[mydb]>UPDATEuserSETlogtime=NOW();QueryOK,5rowsaffected(0.01sec)Rowsmatched:5Changed:5Warnings:0更新最早注册的三个人的登录IP为127.0.0.1
MariaDB[mydb]>UPDATEuserSETlogip='127.0.0.1'ORDERBYregtimeLIMIT3;
ORDER BY语句可以用于SELECT UPDATE DELETE等,是指示该表输出、删除、更新时遵循该表哪个字段排列。 例如以上,ORDER BY regtime就是根据注册时间来正序排列更新,并且配合LIMIT语句只更新了前三行。
再使用DESC来指定倒叙排列,例如:ORDER BY regtime DESC
LIMIT语句:用于限制查询结果的条数。 用法:
LIMIT[位置偏移量,]行数
第一行从0开始,所以以下:
SELECT*FROMuserLIMIT2,2;//从第3行开始,取两行,即取第3、4条记录。使用WHERE语句选中特定行更新
MariaDB[mydb]>UPDATEuserSETlogip='192.168.1.2'WHEREusername='test2';
因为WHERE子句也有很多东西,这里就不过多贴内容了。
LOW_PRIORITY:这个跟INSERT的LOW_PRIORITY是一样的。
REPLACE语句MariaDB[mydb]>REPLACEINTOuserVALUES(1,'test111','test111',NOW(),NOW(),'192.168.1.1');
以上这条语句是MariaDB的扩展SQL,相当于删除重复(主键或唯一索引)的记录再添加新的记录。
好像有点鸡肋?….
删除数据DELETE语语法:
DELETE[LOW_PRIORITY][QUICK][IGNORE]FROMtbl_name[PARTITION(partition_list)][WHEREwhere_condition][ORDERBY...][LIMITrow_count][RETURNINGselect_expr[,select_expr...]]删除所有数据
不使用WHERE语句来约束条件时,则删除所有数据,如下:
MariaDB[mydb]>DELETEFROMuser;使用WHERE语句约束选中行
MariaDB[mydb]>DELETEFROMuserWHEREusername='test1';
看完了这篇文章,相信你对“MariaDB中如何实现数据的插入、修改和删除”有了一定的了解,如果想了解更多相关知识,欢迎关注亿速云行业资讯频道,感谢各位的阅读!
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。