How do I escape a LIKE clause?

后端 未结 2 2097
情话喂你
情话喂你 2020-12-11 08:15

The code we\'re using is straightforward in this part of the search query:

myCriteria.Add(
    Expression.InsensitiveLike(\"Code\", itemCode, MatchMode.Anywh         


        
相关标签:
2条回答
  • 2020-12-11 08:46

    The only way I can find to achieve database independence is to escape every character in the search string and call the appropriate constructor on LikeExpression as in my previous answer. You could do this manually or extend LikeExpression:

        public class LikeExpressionEscaped : LikeExpression
        {
            private static string EscapeValue(string value)
            {
                var chars = value.ToCharArray();
                var strs = chars.Select(x => x.ToString()).ToArray();
                return "\\" + string.Join("\\", strs);
            }
    
            public LikeExpressionEscaped(string propertyName, string value, MatchMode matchMode, bool ignoreCase)
                : base(propertyName, EscapeValue(value), matchMode, '\\', ignoreCase)
            {}
        }
    

    There is no doubt a more efficient way to create the escaped string (see the answers and comments to this question). Usage is:

    var exp = new LikeExpressionEscaped("Code", itemCode, MatchMode.Anywhere, true);
    myCriteria.Add(exp);
    
    0 讨论(0)
  • 2020-12-11 09:03

    You can create an instance of LikeExpression to accomplish this. In this example I am escaping % with a backslash (which itself has to be escaped):

    var itemCode = "ItemWith%Symbol";
    itemCode = searchCode.Replace("%", "\\%");
    var exp = new LikeExpression("Code", itemCode, MatchMode.Anywhere, '\\', true);
    myCriteria.Add(exp);
    

    I didn't see a static method to return a LikeExpression using this overload.

    By the way, if you're using SQL Server it is case insensitive by default.

    0 讨论(0)
提交回复
热议问题