EF中关于日期字值的处理

一、SQL语句方式

   var datefrom = DateTime.Parse(fromdate);
   var dateto = DateTime.Parse(todate);

  var sql = string.Format("insert into {0}(id,regionid,fromdate,todate,createdate) values('{1}','{2}',{3},{4},{5})", typeof(DownloadHistory).Name, taskid, region.ID,datefrom,dateto,DateTime.Now);
  int i = dbContext.Database.ExecuteSqlCommand(sql);

 

   执行时,报错:System.Data.SqlClient.SqlException:“Incorrect syntax near '0'.”

  需改成以下方式来执行:

object objFrom = datefrom;
object objTo = dateto;
object objNow = DateTime.Now;
var sql = string.Format("insert into {0}(id,regionid,fromdate,todate,createdate) values('{1}','{2}',@fromdate,@todate,@createdate)", typeof(DownloadHistory).Name, taskid, region.ID);
var parameters = new SqlParameter[]
{
new SqlParameter("@fromdate",objFrom),
new SqlParameter("@todate",objTo),
new SqlParameter("@createdate",objNow)
};
int i = dbContext.Database.ExecuteSqlCommand(sql, parameters);

 

二、DateTime?类型字段的处理(日期为空)

  (1) 如果使用EF语句来执行,必须使用以下语法:

   DateTime? ohzrq = null;  //ef用法

  (2)如果是SQL语句来执行,必须使用以下语法:

   object ohzrq = DBNull.Value;

 

转载于:https://www.cnblogs.com/SimpleGIS/p/9938055.html

### EF Core 中批量处理、保存和修改数据的方法 #### 批量操作概述 EF Core 的早期版本确实存在对批量操作的支持不足的问题[^1]。然而,在后续的发展过程中,通过多种方式实现了更高效的批量处理能力。 #### 实现批量更新 为了实现批量更新,可以采用如下策略: - **查询并存储待更新实体** 使用 `Where` 条件筛选出需要更新的数据集,并将其赋给一个临时变量,比如 `resInfo`。 - **遍历与状态变更** 对上述获取的对象集合进行迭代,针对每一个实例执行必要的属性更改动作;随后利用上下文中的 `Entry(entity).State = EntityState.Modified` 将这些记录的状态设为已修改模式[^2]。 - **统一提交事务** 调用 `SaveChanges()` 或者异步版的 `SaveChangesAsync()` 完成最终的一次性写入数据库的操作,而不是每次循环都单独发起请求,从而提高了效率并减少了网络开销。 ```csharp using (var context = new YourDbContext()) { var resInfo = context.YourEntities.Where(e => e.Condition); foreach(var entity in resInfo) { // Modify properties of the entity here context.Entry(entity).State = EntityState.Modified; } await context.SaveChangesAsync(); } ``` #### 利用缓存优化性能 当涉及到大量数据变动时,考虑到 EF Core 自身具备的跟踪机制,所有被追踪的变化都会先暂存在内存里的 ChangeTracker 组件里直到调用了 SaveChanges() 后才会真正同步至持久化层[^3]。这种方式不仅简化了编程逻辑同时也提升了整体吞吐率。 #### 处理时间戳和其他特殊类型的段 对于像日期这样的特定类型段,建议定义为可的形式以避免因为而导致异常情况的发生。例如可以通过声明 `public DateTime? SetMainDate { get; set; }` 这样的形式来允许该列接受 NULL [^5]。 #### 应对潜在错误 如果遇到诸如插入或更新失败的情况,则可能是因为违反了一些约束条件或者是其他原因引起的冲突。此时应该仔细检查 SQL Server 返回的具体报错信息以便定位问题所在[^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值