首页 > 其他 > 详细

EF中关于日期字值的处理

时间:2018-11-10 10:04:54      阅读:146      评论:0      收藏:0      [点我收藏+]

一、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中关于日期字值的处理

原文:https://www.cnblogs.com/SimpleGIS/p/9938055.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!