多条件查询

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

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

        #region 获取数据
        List<SupplierInformation> 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<SupplierInformation> list = stSupplier
             .Skip(layuiTablePage.GetStartIndex())
             .Take(layuiTablePage.limit)
             .ToList();
        //调用分页封装类
        LayuiTableData<SupplierInformation> layuiTableData = new LayuiTableData<SupplierInformation>();
        layuiTableData.count = intTotalRow;
        layuiTableData.data = list;
        #endregion

        return Json(layuiTableData, JsonRequestBehavior.AllowGet);
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值