我正在开发 MVC Web 应用程序。
这意味着我正在创建视图、模型、视图模型。我使用 linq-to-sql 作为数据库提供程序,我已经实现了自定义工作单元SQL
模式,以及看起来完美(在我的实现中)并且与直接代码完全分离的数据源、存储库和服务模式。实际上,从任何为单元测试而设计的数据库中,我都可以使用内存数据源测试我的应用程序,而不会影响数据库。
最终我遇到了一个问题:我没有针对跨线程(或跨进程,因为据我所知,IIS可以使用单个 Web 应用程序创建多个应用程序域)操作的保护。
例如,我有一个包含一些记录的表。并且每隔一段时间就会发生一个 Web 请求(在控制器内部,然后是服务,然后是存储库)在假设TicketId
列的最大值上选择 SQL 表的行,然后在该表中插入另一行(that column value + 1)
。
如果两个或多个线程或进程执行相同的操作,重复的值可能会出现在数据库中。前段时间,当我的 web 应用程序变小时,我使用了直接 SQL 代码和简单UPDLOCK
的SELECT语句,其中using块内部锁定了我正在修改的记录(或其他任何内容),以防止所有其他数据库客户端等到我完成。TransactionScope
对于所有这些模式,我忘记了一件事:
我如何实际实现数据库多访问保护问题?
没有任何直接的 SQL 代码。