为什么一定要commit,数据才能真正进入到数据库里面?
首先,我们要知道SQL语言分为五大类:
DDL(数据定义语言) - Create、Alter、Drop 这些语句自动提交,无需用Commit提交。
DQL(数据查询语言) - Select 查询语句不存在提交问题。
DML(数据操纵语言) - Insert、Update、Delete 这些语句需要Commit才能提交。
DTL(事务控制语言) - Commit、Rollback 事务提交与回滚语句。
DCL(数据控制语言) - Grant、Revoke 授予权限与回收权限语句。
然后再明白什么是事务。
事务由一个或多个sql语句组成一个整体,如果所有的语句执行成功那么修改将会全部生效,如一条sql语句将销量+1,下一条再+1,倘若第二条失败,那么销量将撤销第一条sql语句的+1操作,只有在该事务中所有的语句都执行成功才会将修改加入到数据库中。
数据操纵语言DML,就需要commit事务提交之后才能真正提交到库里面。
mysql在进行如插入(insert)操作的时候需不需要commit,这得看你的存储引擎。
如果是不支持事务的引擎,如myisam,则是否commit都没有效的。
如果是支持事务的引擎,如innodb,则得知道你事物支持是否自动提交事务(即commit)
看自己的数据库是否是自动commit,可以使用mysql> show variables like ‘%autocommit%’;来进行查看,如果是OFF即不自动commit,需要手动commit操作(命令行可以直接“commit;“命令),否则是自动commit。
提交数据有三种类型:显式提交、隐式提交及自动提交。
所以我们是可以通过更改设置来使数据库达到自动commit的,对于数据库的大规模数据加载或撤消来说,应该多使用COMMIT语句;然而,过多的COMMIT语句会让工作需要大量额外时间才能完成。