繁体   English   中英

提交数据库地理表单

[英]Submit a dbgeography form

提交新创建的表单时出现问题,我无法验证变量dbgeometry的数据。错误消息是“没有为此对象定义参数的构造函数”。 这是我的代码控制器:

    [HttpPost]
    [ValidateAntiForgeryToken]
    public ActionResult Create([Bind(Include = "id,name,Location")] schoolinfo schoolinfo)
    {
        if (ModelState.IsValid)
        {
            db.schoolinfo.Add(schoolinfo);
            db.SaveChanges();
            return RedirectToAction("Index");
        }
        return View(schoolinfo);
    }

我来自EF的模型:

public partial class schoolinfo
{
    public string id { get; set; }
    public string name { get; set; }
    public System.Data.Entity.Spatial.DbGeography Location { get; set; }
}

最好的方法是使用sqlQuery命令

var id = form["id"];
            var name = form["name"];
            var lat = form["Location.Latitude"];
            var lng = form["Location.Longitude"];
            db.Database.ExecuteSqlCommand("insert into [dbo].[schoolinfo] values ('" + id + "','" + name + "',geography::Point(" + lat + ", " + lng + ", 4326))");

这是100%可行的

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM