多条件查询

                       同一字段的多个值查询多条数据

1、 在前一编讲到通过递归拼接得到一个由多个节点的ID拼接起来的字符串,
2、 那么这次将的就是将那个字符串分割处理查询出每个节点所对在的那条数据。
3、 我们已经将那个字符串存放在标签里,那么在就可以获取到这个数据,通过post提交到控制器中即可。
4、代码直接从控制器讲起。
5、 public ActionResult MultipleQuerySupplier(PW_Supplier pwSupplier,string stSupplierClassifyID, string QueryCondition, LayuiTablePage layuiTablePage)
{

        #region 获取数据
        List stSupplier = (from tbSupplier in myModel.PW_Supplier//供应商表
                                                join tbSupplierClassify in myModel.SYS_SupplierClassify on tbSupplier.SupplierClassifyID equals tbSupplierClassify.SupplierClassifyID //供应商表分类表
                                                join tbState in myModel.PW_State on tbSupplier.StateID equals tbState.StateID //状态表
                                                orderby tbSupplier.StateID ascending
                                                select new SupplierInformation
                                                {
                                                    SupplierID = tbSupplier.SupplierID,//供应商ID
                                                    SupplierClassifyID = tbSupplier.SupplierClassifyID,//分类ID

tbSupplier.SiContacts,//联系人
SiExplain = tbSupplier.SiExplain,//备注

                                                }).ToList();
        #endregion


        #region 筛选数据
       
        if (!string.IsNullOrEmpty(pwSupplier.SiExplain))
        {
            stSupplier = stSupplier.Where(m => m.SiExplain == pwSupplier.SiExplain).ToList();
        }
        if (!string.IsNullOrEmpty(stSupplierClassifyID))
        {

//实例化一个sbSupplier来接收数据
List sbSupplier = new List();
//对字符串进行分割,用声明一个string[]数组来接收
string[] sbSupplierClassifyID = stSupplierClassifyID.Split(’,’);
for (var i=0;i< sbSupplierClassifyID.Length; i++)
{
//把每次获取到的数据存放到sbSupplier里,同时注意,因为声明获取到的是数据类型是string类型的所有在下面想要对数据类型进行转换,因为我的数据库的SupplierClassifyID是int类型的所以在这里也把它转换成int类型
sbSupplier.AddRange(stSupplier.Where(m => m.SupplierClassifyID == Convert.ToInt32(sbSupplierClassifyID[i])).ToList();
);
}
//将所有查询出来的数据给回到sbSupplier,因未还有其他的条件查询,所有同一返回数据用sbSupplier,也是方便下面的分页功能
stSupplier = sbSupplier;

        }

        #endregion

        #region 分页
        var intTotalRow = stSupplier.Count();
        List list = stSupplier
             .Skip(layuiTablePage.GetStartIndex())
             .Take(layuiTablePage.limit)
             .ToList();
        //调用分页封装类
        LayuiTableData layuiTableData = new LayuiTableData();
        layuiTableData.count = intTotalRow;
        layuiTableData.data = list;
        #endregion

        return Json(layuiTableData, JsonRequestBehavior.AllowGet);
    }

你可能感兴趣的:(多条件查询)