EF中关于日期字值的处理

Posted simplegis

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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;

 

以上是关于EF中关于日期字值的处理的主要内容,如果未能解决你的问题,请参考以下文章

EF中关于实体类枚举问题

Swift3.0中关于日期类的使用指引

java中关于时间日期操作的常用函数

MySQL关于日期为零值的处理

资产监测设备中关于OTA升级串口应答帧处理

在VS中关于MySQL的相关问题