环境:mysql5.5,引擎innodb,SQLYOG

    行锁,表锁区别:其实就是看where后面的条件是否有有索引,有索引的时候就是行锁,没有索引的时候就是表索。

    先创建表结构:

        

CREATE TABLE `lock_test` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(200) DEFAULT NULL,
  `age` int(11) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

    再向里面添加数据:

    

INSERT INTO lock_test (NAME,age) VALUES('zangsan',15);
INSERT INTO lock_test (NAME,age) VALUES('zangsan1',16);
INSERT INTO lock_test (NAME,age) VALUES('zangsan2',17);
INSERT INTO lock_test (NAME,age) VALUES('zangsan3',18);
INSERT INTO lock_test (NAME,age) VALUES('zangsan4',19);
INSERT INTO lock_test (NAME,age) VALUES('zangsan5',20);


  一、无索引测试 :  

      Session1:     

        SET autocommit=0;

        SELECT * FROM lock_test;

        wKioL1RUsaGgR-DzAACZw9XQOBc832.jpg

        SELECT * FROM lock_test WHERE NAME = 'zangsan' FOR UPDATE;


        Session2:(在SQLYOG中新开一个连接)

            UPDATE  lock_test SET age=30 WHERE NAME = 'zangsan1' ;  

        此时你会发现这条SQL一直处于处于等待状态....

        现在我们回到 Session1: 中,再执行:COMMIT;语句。

        我们会在Session2的窗口看到:

        wKiom1RUs-WSmRMSAABZAUeuBWg109.jpg

        

        我们可以得出的结论是:在where条件后面接的条件是无索引的name字段,虽然我们锁的是值为zangsan的这条数据,实际上他是锁了整个表。


    二 有索引测试:

    我们在Session1窗口中执行:

        ALTER TABLE lock_test ADD INDEX index_name(NAME);

       然后再将上面的语过程重复一次。这时session2执行的update操作可以直接完成了。

        

        我们可以得出的结论是:在where条件后面接的条件是带索引的name字段,他只会锁住该行数据。