社区
应用实例
帖子详情
MS SQL SERVER 对for update的问题
jenhi
2006-02-24 04:38:07
SELECT * FROM table_name WHERE INDEX='10' FOR UPDATE
在sql server中好象不行,请问应该如何达到同样的功能呢。
...全文
3300
5
打赏
收藏
MS SQL SERVER 对for update的问题
SELECT * FROM table_name WHERE INDEX='10' FOR UPDATE 在sql server中好象不行,请问应该如何达到同样的功能呢。
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
5 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
jenhi
2006-02-27
打赏
举报
回复
请问楼上的, sql server在什么时候解锁呢,会在执行一次update操作后sql server自己解锁吗?
wgsasd311
2006-02-24
打赏
举报
回复
我只想锁定选择出来的行,那该怎么写呢?
===>
with(rowlock)
jenhi
2006-02-24
打赏
举报
回复
我只想锁定选择出来的行,那该怎么写呢?
-狙击手-
2006-02-24
打赏
举报
回复
锁定提示
可以使用 SELECT、INSERT、UPDATE 和 DELETE 语句指定表级锁定提示的范围,以引导 Microsoft® SQL Server™ 2000 使用所需的锁类型。当需要对对象所获得锁类型进行更精细控制时,可以使用表级锁定提示。这些锁定提示取代了会话的当前事务隔离级别。
说明 SQL Server 查询优化器自动作出正确的决定。建议仅在必要时才使用表级锁定提示更改默认的锁定行为。禁止锁定级别反过来会影响并发。
锁定提示 描述
HOLDLOCK 将共享锁保留到事务完成,而不是在相应的表、行或数据页不再需要时就立即释放锁。HOLDLOCK 等同于 SERIALIZABLE。
NOLOCK 不要发出共享锁,并且不要提供排它锁。当此选项生效时,可能会读取未提交的事务或一组在读取中间回滚的页面。有可能发生脏读。仅应用于 SELECT 语句。
PAGLOCK 在通常使用单个表锁的地方采用页锁。
READCOMMITTED 用与运行在提交读隔离级别的事务相同的锁语义执行扫描。默认情况下,SQL Server 2000 在此隔离级别上操作。
READPAST 跳过锁定行。此选项导致事务跳过由其它事务锁定的行(这些行平常会显示在结果集内),而不是阻塞该事务,使其等待其它事务释放在这些行上的锁。READPAST 锁提示仅适用于运行在提交读隔离级别的事务,并且只在行级锁之后读取。仅适用于 SELECT 语句。
READUNCOMMITTED 等同于 NOLOCK。
REPEATABLEREAD 用与运行在可重复读隔离级别的事务相同的锁语义执行扫描。
ROWLOCK 使用行级锁,而不使用粒度更粗的页级锁和表级锁。
SERIALIZABLE 用与运行在可串行读隔离级别的事务相同的锁语义执行扫描。等同于 HOLDLOCK。
TABLOCK 使用表锁代替粒度更细的行级锁或页级锁。在语句结束前,SQL Server 一直持有该锁。但是,如果同时指定 HOLDLOCK,那么在事务结束之前,锁将被一直持有。
TABLOCKX 使用表的排它锁。该锁可以防止其它事务读取或更新表,并在语句或事务结束前一直持有。
UPDLOCK 读取表时使用更新锁,而不使用共享锁,并将锁一直保留到语句或事务的结束。UPDLOCK 的优点是允许您读取数据(不阻塞其它事务)并在以后更新数据,同时确保自从上次读取数据后数据没有被更改。
XLOCK 使用排它锁并一直保持到由语句处理的所有数据上的事务结束时。可以使用 PAGLOCK 或 TABLOCK 指定该锁,这种情况下排它锁适用于适当级别的粒度。
-狙击手-
2006-02-24
打赏
举报
回复
SELECT au_lname FROM authors WITH (NOLOCK)
GO
sql
server
锁表 select for
update
SELECT 语句中“加锁选项”的功能说明
SQL
Server
提供了强大而完备的锁机制来帮助实现数据库系统的并发性和高性能。用户既能使用
SQL
Server
的缺省设置也可以在select 语句中使用“加锁选项”来实现预期的效果。 本文介绍了SELECT语句中的各项“加锁选项”以及相应的功能说明。 功能说明: NOLOCK(不加锁) 此选项被选中时,
SQL
Server
在读
sql
server
关于 执行
update
语句超级慢原因
转自http://blog.csdn.net/miqi770/article/details/6763985做了一个
update
一次性手动批量修改的
sql
,在执行的时候很长时间没有反应,还以为自己的
sql
写的有
问题
,死循环了...原来发现是trigger的
问题
,影响了修改的速率。可以在执行
update
之前关闭该表的trigger,执行完毕之后再启用trigger[
sql
] view plain ...
利用
Sql
Server
触发器自动更新表
update
time字段值
本文主要记录了使用
Sql
Server
数据库触发器自动更新表的"更新时间
update
time"字段 在 My
SQL
数据库中,某行数据创建时间字段 createtime 、 行最新更新时间字段
update
time 可建表时分别用"datetime DEFAULT CURRENT_TIMESTAMP" 和 " datetime DEFAULT CURRENT_TIMESTAMP ON
UPDATE
C...
MS
SQL
Server
的数据库多表关联更新
UPDATE
一条
Update
更新语句是不能更新多张表的,除非使用触发器隐含更新。而表的更新操作中,在很多情况下需要在表达式中引用要更新的表以外的数据。我们先来讨论根据其他表数据更新你要更新的表 MS
SQL
Server
多表关联更新
sql
server
提供了
update
的from 子句,可以将要更新的表与其它的数据源连接起来。虽然只能对一个表进行更新,但是通过将
sql
server
中的
update
set from 对应 ORACLE 的写法
首先ms
sql
和oracle两边都支持
update
set where
update
xxx set col = 'xxx' where col = 'sss';但是
SQL
SERVER
也支持
update
set from
update
xxx set xxx.col = yyy.col from yyy where ......;ORACLE这边不支持,于是研究了一下有了一种可以代替的
sql
:upd
应用实例
27,579
社区成员
68,558
社区内容
发帖
与我相关
我的任务
应用实例
MS-SQL Server 应用实例
复制链接
扫一扫
分享
社区描述
MS-SQL Server 应用实例
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章