草庐IT

entity_repositories

全部标签

c# - 为什么使用 Attach 更新 Entity Framework 6?

在搜索通过EF执行CRUD操作的最佳实践时,我注意到强烈建议在更新实体之前使用Attach()或Find()方法.它运行良好,根据EF文档,这些方法将实体提取到对我来说非常清楚的上下文中。但是下面的代码让我很困惑publicvoidUpdate(objectentity){Recordrecord=newRecord(){id=1,value=5};using(SomeContextctx=newSomeContext()){ctx.Entry(record).State=EntityState.Modified;ctx.SaveChanges();}}假设我们在数据库中有一条id=1

c# - Entity Framework Core 2.0.1 在所有嵌套的相关实体上预先加载

我有一个简单的问题,但似乎找不到解决方法。我正在使用EntityFrameworkCore版本2.0.1,并希望在默认情况下预先加载我的所有实体。例子:publicclassOrder{publicintId{get;set;}publicstringName{get;set;}publicintCustomerId{get;set;}publicCustomerCustomer{get;set;}}publicclassCustomer{publicintId{get;set;}publicstringName{get;set;}publicintAddressId{get;set;

c# - LINQ to Entities 无法识别该方法并且无法将此方法转换为存储表达式

我使用EntityFramework在我的数据库中调用某个日期。但是我下面的代码给出了这个错误LINQtoEntities无法识别“SchoolBreifcase.Complianceget_Item(Int32)”方法,并且无法将此方法转换为存储表达式。这是我的完整代码FinancialCompliancefinancialCompliance=newFinancialCompliance();Listcompliance=null;if(HttpContext.Current.User.IsInRole("SchoolAdmin")){compliance=datamodel.Co

c# - 是否可以创建用于将项目添加到 Entity Framework dbset 的通用方法?

我之前没有使用过EntityFramework或泛型,在减少我的代码时遇到了一些困难。我正在解析一个文本文件以加载10个查找表,其中包含可能每晚都可能更改的数据。文本文件有一个“类型”标题,后跟键/值集列表。我已经完美地工作了,但我想重构代码以清理它,并想使用通用方法来完成它,这样我就可以减少重复的代码。我已经将解析归结为通用方法,但我无法弄清楚如何以通用方式将实体添加到上下文中。我必须遍历每种类型的实体列表并将它们添加到上下文中:voidMain(){switch(line.ToUpper()){case"AREA":{ListareaList=this.GetItems(file)

c# - LINQ to Entities - 多个 OrderBy 方法不起作用

如果我对查询应用两个OrderBy方法,就像这样query.OrderBy(rec=>rec.Name).OrderByDescending(rec=>rec.Title);然后只应用第二种方法,第一种方法被忽略。这是一个错误吗?如果我需要对一列进行升序排序而对另一列进行降序排序怎么办?方法语法根本无法实现吗? 最佳答案 试试这个:query.OrderBy(rec=>rec.Name).ThenByDescending(rec=>rec.Title);您的第二个OrderBy正在重置您的第一个结果集。这就是存在ThenBy扩展的原

c# - 如何让 Entity Framework Code First 和可为空的外键属性工作?

我正在尝试创建一个简单的EntityFramework代码优先应用程序。我有这些类(class):publicclassUser{publicintUserId{get;set;}publicstringUsername{get;set;}publicvirtualActivationTicketActivationTicket{get;set;}}publicclassActivationTicket{publicintActivationTicketId{get;set;}publicvirtualUserUser{get;set;}publicstringTicket{get;s

c# - 将 DataAnnotations 与 Entity Framework 一起使用

我在VS2010中使用了EntityFramework来创建一个简单的人类,其中包含属性、名字、姓氏和电子邮件。如果我想像在本blogpost中那样附加DataAnnotations我有一个小问题,因为我的person类是动态生成的。我可以直接编辑动态生成的代码,但任何时候我必须更新我的模型时,我的所有验证代码都会被清除。第一直觉是创建一个部分类并尝试附加注释,但它提示说我正在尝试重新定义该属性。我不确定您是否可以在C#中进行属性声明,就像在C++中进行函数声明一样。如果可以,那可能就是答案。这是我尝试过的片段:namespacePersonWeb.Models{publicparti

c# - LINQ to Entities/LINQ to SQL : switching from server (queryable) to client (enumerable) in the middle of a query comprehension?

在许多情况下,我想在服务器端进行一些过滤(有时是投影),然后切换到客户端以执行LINQ提供程序本身不支持的操作。天真的方法(这基本上就是我现在所做的)是将其分解为多个查询,类似于:varfromServer=fromtincontext.Tablewheret.Col1=123wheret.Col2="blah"selectt;varclientSide=fromtinfromServer.AsEnumerable()wheret.Col3.Split('/').Last()=="whatever"selectt.Col4;但是,很多时候,这带来的代码/麻烦多于它的实际值(value)

c# - Entity Framework 核心 - 包含区分大小写还是不区分大小写?

EntityFramework核心中的“包含”应该等同于SQL%like%运算符。因此,“包含”应该不区分大小写,但它区分大小写!(至少在postgres中????)以下仅在使用正确的关键字大小写时才输出结果。context.Counties.Where(x=>x.Name.Contains(keyword)).ToList();我做错了什么? 最佳答案 旧版本的EF核心曾经是这种情况。现在string.Contains区分大小写,例如对于sqlite,它映射到sqlite函数`instr()'(我不知道postgresql)。如果

c# - Linq to Entity 从 DateTime 获取日期

varislemList=(fromislinentities.Islemlerwhere(isl.KayitTarihi.Date>=dbas&&isl.KayitTarihi.Value.Date它给出错误:LINQtoEntities不支持日期...我如何在linq中获取日期。 最佳答案 使用EntityFunctions.TruncateTime. 关于c#-LinqtoEntity从DateTime获取日期,我们在StackOverflow上找到一个类似的问题: