两种情况:

1.带索引 2.不带索引

前提介绍:

方式:采用命令行的方式来模拟

1.mysq由于默认是开启自动提交事务,所以首先得查看自己当前的数据库是否开启了自动提交事务。

命令:select @@autocommit;

结果如下:

+--------------+| @@autocommit |+--------------+|  0 |+--------------+

2.当前的数据库表格式如下

tb_user | CREATE TABLE `tb_user` ( `id` bigint(20) NOT NULL AUTO_INCREMENT, `name` varchar(32) DEFAULT NULL, `phone` varchar(11) DEFAULT NULL, `operator` varchar(32) DEFAULT NULL, `gmt_create` datetime DEFAULT NULL, `gmt_modified` datetime DEFAULT NULL, PRIMARY KEY (`id`)) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8

实际例子:

1.没有索引

运行命令:begin;开启事务,然后运行命令:update tb_user set phone=11 where name="c1";修改,先别commit事务。

再开一个窗口,直接运行命令:update tb_user set phone=22 where name=“c2”;会发现命令卡住了,但是当前面一个事务通过commit提交了,命令就会正常运行结束,说明是被锁表了。

2.给name字段加索引

create index index_name on tb_user(name);

然后另一个运行update tb_user set phone=22 where name="c2";发现命令不会卡住,说明没有锁表

但是如果另一个也是update tb_user set phone=22 where name="c1";更新同一行,说明是锁行了

3.总结

如果没有索引,所以update会锁表,如果加了索引,就会锁行

更多相关文章

  1. [置顶] android 批量插入数据
  2. Android性能优化-SQLite数据库
  3. 我的android 第16天 - SQLite数据库
  4. Android(安卓)FragmentManage FragmentTransaction介绍
  5. 第15天android:使用sqlite
  6. 【转载】Android数据库事务浅析
  7. Android(安卓)使用ORMLite打造万能泛型Dao简化数据持久化层
  8. Android数据库事务浅析
  9. Android(安卓)Developers:日历提供者

随机推荐

  1. php 安装zip模块
  2. PHP中Redis扩展无法加载问题
  3. php实现汉字转拼音
  4. PHP提高SESSION响应速度的方法有哪些
  5. opcode 操作数 5 种不同的类型
  6. 不要在循环体中使用 array_push ()
  7. PHP中的服务容器与依赖注入的思想
  8. PHP中Session ID的实现原理分析
  9. 不要在循环体中使用 array_merge ()
  10. PHP安装ssh2扩展