[心缘地方]同学录
首页 | 功能说明 | 站长通知 | 最近更新 | 编码查看转换 | 代码下载 | 常见问题及讨论 | 《深入解析ASP核心技术》 | 王小鸭自动发工资条VBA版
登录系统:用户名: 密码: 如果要讨论问题,请先注册。

[备忘]SQL中LIKE需要Escape的字符都有哪些哇

上一篇:[备忘]星际争霸在局域网使用IPX协议时,报unable to join game的解决。
下一篇:[备忘]单例模式的效率问题……

添加日期:2010/8/10 17:02:29 快速返回   返回列表 阅读3854次
比如输入%,那么就变为
Like "%",
需要Escape,怎么Escape哇?mysql……
 
都有哪些字符需要Escape哇?
------------------------------------
把检索用的关键字作如下转换
将% 转化成 /%
将/   转化成//
将_   转化成/_
在执行 LIKE ? Escape '/' 就可以了。
-------------------------------------
比如输入%,那么就变为
Like "%",
的话

\%         Matches one “%” character
\_         Matches one “_” character
就可以了
\n⇒\\n
\⇒\\\\
---------------------------------------------
Java code:


public static String escapeForSql(Object basic){
    String strBasic = null;
    if(basic ==null){
        strBasic = "";
    }else{
        strBasic = String.valueOf(basic);
        if(0<strBasic.length()){
            if(strBasic.indexOf("\\")!=-1){
                strBasic = strBasic.replace("\\","\\\\"); //"\" --> "\\"
            }
            strBasic = strBasic.replaceAll("'","\\\\'"); //"'" --> "\'"
            strBasic = strBasic.replaceAll("_","\\\\_"); //"_" --> "\_"
            strBasic = strBasic.replaceAll("%","\\\\%"); //"%" --> "\%"
        }
    }
    return strBasic;
}


 

评论 COMMENTS
没有评论 No Comments.

添加评论 Add new comment.
昵称 Name:
评论内容 Comment:
验证码(不区分大小写)
Validation Code:
(not case sensitive)
看不清?点这里换一张!(Change it here!)
 
评论由管理员查看后才能显示。the comment will be showed after it is checked by admin.
CopyRight © 心缘地方 2005-2999. All Rights Reserved