2012-04-03 8 views
1

exec sp_lockをデータベースの1つに実行すると、3000個近くのロックが存在することがわかりましたが、すべてのテーブルにアクセスして書き込むことができます。SQL Serverデータベースの3000近くのロック

私たちは、アプリケーション層でNHibernateを使用しています。これは正常ですか?

答えて

2

ほとんどのデータベースにはいくつかのロックがありますが、そのほとんどは気にする必要はありません。

ロックは、複数のユーザーが同じデータを同時に変更できないようにすることで、データの破損や無効なデータを防止するために使用されることがよくあります。

さまざまなタイプのロックがありますが、ほとんどの場合、ユーザーが実際にデータを更新するときにのみアクティブになる楽観的ロックが使用されます。

0

実際の問題は「SQLプロファイラ」を使用して追跡できる「デッドロック」に由来します。 このarticleは、SQLプロファイラを検索するよう設定することができるようです。

関連する問題