次のメソッドを使用して、jqgrid のサブグリッドのデータを取得し、完全に正常に動作しています。
このメソッドは、サーバー側の並べ替えとページングを実装するために使用されることに注意してください。
今私が持っているクエリは、あなたが行で見ることができるようです
List<SomeEntity> myList = _service.GetSomeData(id);
ここでデータベース呼び出しが行われ、すべてのレコードがフェッチされます。
よくわからなかったので、これがサーバー側のページングを実装するためのベストプラクティスに含まれているかどうかを知りたかっただけです。
public JsonResult GetData(string folderId, string sidx, string sord, int page, int rows) {
int id = int.Parse(folderId);
List < SomeEntity > myList = _service.GetSomeData(id);
const int pageSize = 5;
// total
double totalPages = Math.Ceiling((double) myList.Count() / pageSize);
// sort
if (sord == "asc") {
myList = myList.OrderBy(m = > m.Name).ToList();
}
else {
myList = myList.OrderByDescending(m = > m.Name).ToList();
}
// paging
myList = myList.Skip((page - 1) * pageSize).Take(pageSize).ToList();
var jsonData = new {
total = totalPages, records = domainList.Count, page,
rows = myList
};
return Json(jsonData, JsonRequestBehavior.AllowGet);
}