Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/wpf/14.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/variables/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# sqlserverce中的多线程_C#_Wpf_Multithreading_Sql Server Ce_Repository Pattern - Fatal编程技术网

C# sqlserverce中的多线程

C# sqlserverce中的多线程,c#,wpf,multithreading,sql-server-ce,repository-pattern,C#,Wpf,Multithreading,Sql Server Ce,Repository Pattern,我已经开发了一个WPF应用程序,它是一个工作单元和存储库模式。我使用的是SQLServerCE3.5SP2。我的应用程序在单线程上使用时运行良好。但当我在服务器上使用它时,用户通过远程桌面连接进行连接,它变成了多线程应用程序,这会造成问题 我的数据库位于环境.SpecialFolder.CommonApplicationData中 当两个用户同时启动数据库的任何事务时,我会收到以下错误: 内部错误:无法打开共享内存区域 及 数据库已由其他用户打开 避免这种情况的最佳方法是什么?或者,如果无法避免

我已经开发了一个WPF应用程序,它是一个工作单元和存储库模式。我使用的是SQLServerCE3.5SP2。我的应用程序在单线程上使用时运行良好。但当我在服务器上使用它时,用户通过远程桌面连接进行连接,它变成了多线程应用程序,这会造成问题

我的数据库位于
环境.SpecialFolder.CommonApplicationData

当两个用户同时启动数据库的任何事务时,我会收到以下错误:

内部错误:无法打开共享内存区域

数据库已由其他用户打开


避免这种情况的最佳方法是什么?或者,如果无法避免这种情况,那么处理这种异常的最佳方法是什么。

正如@marc_s所评论的,您确实应该尝试使用至少
SQL Server Express
或更高版本,以使多个并发用户能够同时从您的应用程序成功访问数据库


这篇文章中也提出了一个类似的问题,这篇文章给出了一个很好的答案,并提供了更多详细信息,您应该看一看。

SQL Server CE是一个单用户本地数据库-如果您需要支持多个并发用户,您应该使用全面的、基于服务器的SQL Server(快速版、标准版-任何版本-只是不紧凑)@marc_s:谢谢你的建议,但是SQL Server Express在安装时会造成很多麻烦。但是我想我只能使用SQL Express。谢谢你的建议,但是SQL Server Express在安装时会造成很多麻烦。但是我想我只能使用SQL Express。。