重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
1 如何锁一个表的某一行
成都创新互联成立与2013年,先为五原等服务建站,五原等地企业,进行企业商务咨询服务。为五原企业网站制作PC+手机+微官网三网同步一站式服务解决您的所有建站问题。
SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED
SELECT * FROM table ROWLOCK WHERE id = 1
2 锁定数据库的一个表
SELECT * FROM table WITH (HOLDLOCK)
加锁语句:
sybase:
update 表 set col1=col1 where 1=0 ;
MSSQL:
select col1 from 表 (tablockx) where 1=0 ;
oracle:
LOCK TABLE 表 IN EXCLUSIVE MODE ;
加锁后其它人不可操作,直到加锁用户解锁,用commit或rollback解锁
SQL SERVER里的锁机制:
NOLOCK(不加锁)
此选项被选中时,SQL Server 在读取或修改数据时不加任何锁。 在这种情况下,用户有可能读取到未完成事务(Uncommited Transaction)或回滚(Roll Back)中的数据, 即所谓的“脏数据”。
HOLDLOCK(保持锁)
此选项被选中时,SQL Server 会将此共享锁保持至整个事务结束,而不会在途中释放。 例如,“ SELECT * FROM my_table HOLDLOCK”就要求在整个查询过程中,保持对表的锁定,直到查询完成才释放锁定。
UPDLOCK(修改锁)
此选项被选中时,SQL Server 在读取数据时使用修改锁来代替共享锁,并将此锁保持至整个事务或命令结束。使用此选项能够保证多个进程能同时读取数据但只有该进程能修改数据。
TABLOCK(表锁)
此选项被选中时,SQL Server 将在整个表上置共享锁直至该命令结束。 这个选项保证其他进程只能读取而不能修改数据。
PAGLOCK(页锁)
此选项为默认选项, 当被选中时,SQL Server 使用共享页锁。
TABLOCKX(排它表锁)
此选项被选中时,SQL Server 将在整个表上置排它锁直至该命令或事务结束。这将防止其他进程读取或修改表中的数据。
不需要,就算确实用户同时执行,数据库的操作机制是有队列的,所以不存在并发情况。
锁基本用不到,我反正开发了5年了没用到过。
你要了解死锁发生的情况,一般是用事务的时候可能会碰到死锁,你申请了A资源,锁住了A然后申请B资源,其他人申请了B资源,然后申请A,这样就互不相让,导致A,B资源都不可访问了,不过其他数据我不知道,SQLSERVER发生这种死锁不是一直锁死的,过几分钟就会发现这个死锁,把锁释放掉,2个事务都失败。