我目前部署在使用 Entity Framework 4.3 进行数据库访问的 MVC 3 网站上。
该应用程序在 Visual Studio 开发服务器中按预期工作,但一旦将其部署到远程服务器,查询就会意外反应
它应该显示一个排序列表和该排序数据的页面
我尝试重新启动 Web 服务器和物理服务器机器以确保缓存消失,甚至尝试在远程服务器上使用干净的 IIS 站点,结果相同。
[编辑]:我也完成了完全删除并重新发布到一个干净的站点
在开发机上
在远程服务器上
我用来生成表格的代码:
控制器
[HttpGet]
public virtual ActionResult Index(string filter = "", int? page = null)
{
page = page ?? 1;
filter = filter.Trim().ToLower();
int pageSize = Properties.Settings.Default.DefaultSPPageSize;
int skipNum = (page.Value - 1) * pageSize;
IQueryable<SamplePoint> spList;
var points = new HashSet<string>(Settings.Default.SamplePointFilter.Split(','));
if (filter != "")
spList = db.SamplePoints.Where(e=>
points.Any(p=> e.Id.StartsWith(p))
&& e.Id.ToLower().Trim().StartsWith(filter.ToLower()))
.OrderBy(o => o.Id);
else
spList = db.SamplePoints.Where(e =>
points.Any(p => e.Id.StartsWith(p))
&& e.Id.Trim().StartsWith(filter)).OrderBy(o => o.Id);
List<SamplePoint> pageItems;
if (page != 0)
{
pageItems = spList.Skip(skipNum).Take(pageSize).ToList();
}
else
{
pageItems = spList.OrderBy(o=> o.Id).ToList();
}
int _totPages = Convert.ToInt32(pageSize > 0 ? Math.Ceiling(((double)spList.Count() / (double)pageSize)) : 0);
var vModel = new SamplePointListViewModel(pageItems, filter) { LocationList = FilterListItems, TotalPages = _totPages, CurrentPage = page.Value };
return View(this.IsExcelRequest() ? MVC.Reports.Views.Excel.SamplePointList : MVC.Reports.Views.SamplePointList, vModel);
}