草庐IT

skip_database_clean

全部标签

c# - EntityFramework 测试初始化​​错误 : CREATE DATABASE statement not allowed within multi-statement transaction

我正在尝试构建一个快速测试,每次运行时都会删除并重新创建数据库。我有以下内容:[TestClass]publicclassPocoTest{privateTransactionScope_transactionScope;privateProjectDataSource_dataSource;privateRepository_repository=newRepository();privateconststring_cstring="DataSource=.;InitialCatalog=test_db;Trusted_Connection=True";[TestInitialize

c# - 引用滥用 : Worth Cleaning Up?

我继承了一些广泛且不必要地使用ref关键字的代码。最初的开发人员显然担心如果不使用ref对象会像原始类型一样被克隆,并且在编写50k+行代码之前没有费心去研究这个问题。这与其他不良编码实践相结合,造成了一些表面上非常危险的情况。例如:Customerperson=NextInLine();//personisAliceperson.DataBackend.ChangeAddress(refperson,newAddress);//personcouldnowbeBob,Eve,ornull您能想象走进一家商店更改地址,然后以完全不同的方式走出去吗?可怕,但在实践中在此应用程序中使用re

c# - Count 或 Skip(1).Any() 我想知道是否有超过 1 条记录的地方 - Entity Framework

我不确定是什么时候,但我读了一篇关于此的文章,其中指出Skip(1).Any()的用法优于Count()使用EntityFramework时的同情心(我可能记错了)。在看到生成的T-SQL代码后,我不确定这一点。这是第一个选项:intuserConnectionCount=_dbContext.HubConnections.Count(conn=>conn.UserId==user.Id);boolisAtSingleConnection=(userConnectionCount==1);这会生成以下合理的T-SQL代码:SELECT[GroupBy1].[A1]AS[C1]FROM(

c# - 在 "CREATE TABLE permission denied in database"ASP.NET - MVC4 中列出表结果

我正在使用ASP.NETMVC4-c#连接到实时数据库并列出结果,但是当我查看页面时它返回以下错误:CREATETABLEpermissiondeniedindatabase'DatabaseName'.Description:Anunhandledexceptionoccurredduringtheexecutionofthecurrentwebrequest.Pleasereviewthestacktraceformoreinformationabouttheerrorandwhereitoriginatedinthecode.ExceptionDetails:System.Dat

c# - EF 5 代码迁移错误 : "There is already an object named _____ in the database"

在进行EF5代码迁移时遇到了一个反复出现的奇怪问题,现在让我无法工作。尝试运行update-database并收到此错误:Thereisalreadyanobjectnamed'RequestStatus'inthedatabase.详细的日志转储:PM>update-database-vUsingStartUpproject'LicensingWorkflow'.UsingNuGetproject'LicensingWorkflow'.Specifythe'-Verbose'flagtoviewtheSQLstatementsbeingappliedtothetargetdataba

c# - 无法使用 EFCore、EntityState.Modified : "Database operation expected to affect 1 row(s) but actually affected 0 row(s)." 编辑数据库条目

我将IdentityCore1.0与ASP.NETMVCCore1.0和EntityFrameworkCore1.0结合使用来创建一个简单的用户注册系统thisarticle作为起点,我正在尝试添加用户角色。我可以添加用户角色,但无法编辑它们。这是RolesController中的Edit操作:[HttpPost][ValidateAntiForgeryToken]publicIActionResultEdit(IdentityRolerole){try{_db.Roles.Attach(role);_db.Entry(role).State=Microsoft.EntityFrame

c# - "Data Source cannot be empty. Use :memory: to open an in-memory database"是什么意思?

我最近将我的SQLServer数据库转换为SQLite数据库。但是当我尝试使用.Open()打开我的SQLite时,它​​抛出了这个错误:DataSourcecannotbeempty.Use:memory:toopenanin-memorydatabase编辑:添加连接字符串:ConnectionString=@"DataSource=D:\XXX.db;Version=3";connection=newSQLiteConnection(connectionString);connection.Open();为什么我会得到这个?我将相同的SQLServer数据库转换为SQLCE和my

c# - MVC ICollection<IFormFile> ValidationState 始终设置为 Skipped

作为ASP.NETCoreMVC1.0项目的一部分,我有一个带有ICollection的ViewModel属性(property)。我需要验证此集合是否包含一项或多项。我的自定义验证属性未执行。在我的实例中,它包含来自multipart/form-data的多个文件附件形式。我用自定义验证属性装饰了ViewModel中的属性:[RequiredCollection]publicICollectionAttachments{get;set;}下面是自定义属性类。它只是检查集合不为空且元素大于零:publicclassRequiredCollectionAttribute:Validati

c# - LINQ 为什么 "Enumerable = Enumerable.Skip(N)"慢?

我在LINQ查询的性能方面遇到问题,因此我创建了一个简化的小示例来演示下面的问题。该代码采用一个随机的小整数列表,并返回分成几个较小列表的列表,每个列表总计10个或更少。问题是(正如我所写的那样)N的代码花费的时间呈指数增长。这只是一个O(N)问题。N=2500时,代码在我的电脑上运行需要10多秒。如果有人能解释发生了什么,我将不胜感激。谢谢,马克。intN=250;Randomr=newRandom();varwork=Enumerable.Range(1,N).Select(x=>r.Next(0,6)).ToList();varchunks=newList>();//work.D

C# 打开 XML : empty cells are getting skipped while getting data from EXCEL to DATATABLE

任务从excel导入数据至DataTable问题不包含任何数据的单元格将被跳过,并且行中具有数据的下一个单元格用作空列的值。例如A1为空A2的值为Tom然后在导入数据时A1获取A2的值并且A2保持为空为了清楚起见,我在下面提供了一些屏幕截图这是excel数据这是从excel导入数据后的DataTable代码publicclassImportExcelOpenXml{publicstaticDataTableFill_dataTable(stringfileName){DataTabledt=newDataTable();using(SpreadsheetDocumentspreadSh