zoukankan      html  css  js  c++  java
  • C# Lambda表达式Contains方法 like


    1、使用Contains方法的必备条件:

    Contains等价于SQL中的like语句。不过Contains只针对于字符串(string)类型的数据而言。如果是int等数值类型,则不会有Contains方法的存在,因此数值字段貌似无法通过使用Lambda表达式来完成like操作。因此在使用实体框架的同时,设计数据的时候如果想使用like请确保数据库字段为字符串类型(text、varchar等)。否则在想模糊查询的时候让你痛苦不堪。

    2、Contains方法关联方法(均等价于SQL中的like[注意:这里为什么会说是等价呢,因为如下列出的方法均为Stirng里的方法。like的应用是不分字符类型的,数值行亦可]):

    Contains等价于like '%key%' 指示指定的 String 对象是否出现在此字符串中。

    EndsWith等价于like '%key' 确定此字符串实例的结尾是否与指定的字符串匹配。

    StartsWith等价于like 'key%'  确定此字符串实例的开头是否与指定的字符串匹配。

    3、使用Contains方法时前往不要忘记非NULL的判断:

    写这边文章的原因来自,今天在使用Contains来做查询的时候,一直报错(未将对象引用设置到对象的实例。)。

    一开始百思不得其解,经过跟踪和调试最后才发现数据库中如果存在值为NULL的值。

    为什么会报错,看看如下的代码,想必大家也就知道其中的所以然了。
    string str = null;
    str.Contains("报错啦");//这里会报“未将对象引用设置到对象的实例。”错

    因此不要忘记将代码

    o.SearchKeyword.Contains("查询条件")

    改写为:

    o.SearchKeyword != null && o.SearchKeyword.Contains(("查询条件")

  • 相关阅读:
    gcc各个版本下载
    加减法运算解决乘除法
    蚂蚁碰撞的概率
    ns2.34移植leach协议
    ubantu16.04安装ns2.34 错误
    ubantu安全卸载火狐浏览器
    post和get的区别
    docker加速配置阿里云镜像
    重装系统后,会因为本机保存的公匙不对报错
    集合 set
  • 原文地址:https://www.cnblogs.com/deepalley/p/12704156.html
Copyright © 2011-2022 走看看