• EF空字段使用contains查询的解决办法


    在用entityframework访问数据库时通常使用contains来实现模糊查询,用法如下:

    var userlist= (IEnumerable<User>)data.Where(t => t.Name.Contains(querystring));

    如果字段HostName允许为空且在数据库中存在空值(NULL),使用contains会出现常见的报错:

    Object reference not set to an instance of an object.

    (未将对象引用到对象的实例. )

    数据库中存在的空字段(null)没有实例化。

    解决方法:

    使用三目运算符,首先判断该字段是否为空,是则返回false,否则执行contains

    原理:

    Contains关键字的工作原理是返回一个bool值,当满足contains条件时返回true,否则返回false,以此来决定本条数据是否要获取,所以判断字段为空就直接用false来返回来跳过执行contains

    用法如下:

    var userlist= (IEnumerable<User>)data.Where(t => (string.IsNullOrWhiteSpace(t.Name) ? false : t.Name.Contains(querystring));

  • 相关阅读:
    Java操作Excel之POI简单例子
    机器学习之KNN算法
    机器学习之sklearn数据集
    数据分析之matplotlib
    数据分析之pandas
    数据分析之numpy
    python模块contextlib
    前端jsonp解决跨域问题
    django media和static配置
    Django之数据库迁移和创建
  • 原文地址:https://www.cnblogs.com/XCCU-2015/p/5577198.html
Copyright © 2020-2023  润新知