如何在DB中写入当前日期?

时间:2013-03-25 16:33:33

标签: c# asp.net-mvc date razor time

我正在尝试将当前日期传递到文本框中,因为用户无法在此字段中输入值。这将写入数据库。我这样做,我不能写在DB,因为表中的字段是NULLABLE,这不记录。我怎么能这样做?

@Html.TextBox("DATA_HORA", string.Format("{0:dd/MM/yyyy}", DateTime.Now), new { disabled = "disabled", @readonly = "readonly", Style = "width:100px;" })

谢谢大家。

- 编辑 -

我正在使用ADO.NET Entity Framework。创建Controller时自动生成“创建”页面。

- 编辑2 -

我的控制器:

namespace enChamados.Controllers
{ 
    public class ChamadosController : Controller
    {
        private enChamados_ModeloContainer db = new enChamados_ModeloContainer();

        //
        // GET: /Chamados/

        public ViewResult Index()
        {
            return View(db.CHAMADOS.ToList());
        }

        //
        // GET: /Chamados/Details/5

        public ViewResult Details(int? id)
        {
            CHAMADOS chamados = db.CHAMADOS.Find(id);
            return View(chamados);
        }

        //
        // GET: /Chamados/Create

        public ActionResult Create()
        {
            return View();
        } 

        //
        // POST: /Chamados/Create

        [HttpPost]
        public ActionResult Create(CHAMADOS chamados)
        {
            if (ModelState.IsValid)
            {
                db.CHAMADOS.Add(chamados);
                db.SaveChanges();
                return RedirectToAction("Index");
            }

            return View(chamados);
        }

        //
        // GET: /Chamados/Edit/5

        public ActionResult Edit(int? id)
        {
            CHAMADOS chamados = db.CHAMADOS.Find(id);
            return View();
        }

        //
        // POST: /Chamados/Edit/5

        [HttpPost]
        public ActionResult Edit(CHAMADOS chamados)
        {
            if (ModelState.IsValid)
            {
                db.Entry(chamados).State = EntityState.Modified;
                db.SaveChanges();
                return RedirectToAction("Index");
            }
            return View();
        }

        //
        // GET: /Chamados/Delete/5

        public ActionResult Delete(int? id)
        {
            CHAMADOS chamados = db.CHAMADOS.Find(id);
            return View(chamados);
        }

        //
        // POST: /Chamados/Delete/5

        [HttpPost, ActionName("Delete")]
        public ActionResult DeleteConfirmed(int id)
        {            
            CHAMADOS chamados = db.CHAMADOS.Find(id);
            db.CHAMADOS.Remove(chamados);
            db.SaveChanges();
            return RedirectToAction("Index");
        }

        protected override void Dispose(bool disposing)
        {
            db.Dispose();
            base.Dispose(disposing);
        }
    }
}

2 个答案:

答案 0 :(得分:0)

正如Brian P所说,你可以为这个领域创建一个html编辑器

创建一个DateTime EditorTemplate(在Views \ Shared文件夹中添加一个名为EditorTemplates的文件夹),如下所示:

<%@ Control Language="C#" Inherits="System.Web.Mvc.ViewUserControl<Nullable<System.DateTime>>" %>
<% if ( Model.HasValue )
   { %>
    <%: Html.TextBox( "" , String.Format( "{0:ddd, MMM d, yyyy}" , Model.Value )  )%>
<% }
   else
   { %>
   <%: Html.TextBox( "" , String.Format( "{0:ddd, MMM d, yyyy}" , DateTime.Now )  )%>
<% } %>

从您的视图中使用

<%: Html.EditorFor(model => model.nameOfYourField) %> 

答案 1 :(得分:0)

如果要在模型上设置不应更改的日期,则应使用文本字段。不仅没有理由在视图层中传递信息,而且如果模型绑定器可以访问该字段,则可能会更改它。如果最终用户知道如何在浏览器中使用开发工具,即使隐藏,禁用或只读字段仍然可以修改。

在您的控制器中只需设置日期:

[HttpPost]
public ActionResult Create(CHAMADOS chamados)
{
    if (ModelState.IsValid)
    {
        chamados.CreatedDate = DateTime.Now;
        db.CHAMADOS.Add(chamados);
        db.SaveChanges();
        return RedirectToAction("Index");
    }

    return View(chamados);
}

或者对于您实际上设置默认值的类似内容,通常更容易在模型中进行设置:

private DateTime? createdDate = null;
public DateTime CreatedDate
{
    get { return createdDate ?? DateTime.Now; }
    set { createdDate = value; }
}

然后,您不必在控制器中执行任何操作。 CreatedDate将自动填充保存时的当前日期和时间。