MySql的like语句中的通配符:百分号、下划线和escape 的使用

MySql的like语句中的通配符:百分号、下划线和escape

%代表任意多个字符

select * from user where username like '%huxiao'; 

select * from user where username like 'huxiao%'; 

select * from user where username like '%huxiao%'; 

 

 _代表一个字符

select * from user where username like '_'; 

select * from user where username like 'huxia_'; 

select * from user where username like 'h_xiao'; 

 

 如果我就真的要查%或者_,怎么办呢?使用escape,转义字符后面的%或_就不作为通配符了,注意前面没有转义字符的%和_仍然起通配符作用

select username from gg_user where username like '%xiao/_%' escape '/'; 

select username from gg_user where username like '%xiao/%%' escape '/'; 


个人开发实例:

/**
     * 根据查询条件分页查询广告包信息-广告包管理
     *
     * @param adPackageName
     * @param pageSize
     * @param pageNum
     * @return
     */
    @SuppressWarnings("unchecked")
    public List<Map<String, Object>> listAllAdByPage(String adPackageName,
            int pageSize, int pageNum) {

        StringBuffer sbHQL = new StringBuffer(256);

        sbHQL.append(" from AdPackage as P ");
        sbHQL.append(" ,AdTemplate as T ");
        sbHQL.append(" where P.adTemplateId = T.adTemplateId ");
        sbHQL.append(" and P.dataStat = " + Constant.DATA_STAT_ON);// 选择0-有效数据

        List<Object> params = new ArrayList<Object>();
        setQueryCondition(adPackageName, sbHQL, params);
        sbHQL.append(" order by P.adPackageCreaterTime desc");

        return getHibernateTemplate().executeFind(
                new QueryByHqlWithHibernateCallBack(sbHQL.toString(), params,
                        pageNum, pageSize));
    }
/**
     * 设置广告包管理模块查询条件
     * 20130826 查询”_“处理
     * @param adPackageName
     * @param sbHQL
     * @param params
     */
    private void setQueryCondition(String adPackageName, StringBuffer sbHQL,
            List<Object> params) {
        if (!StringUtils.isEmpty(adPackageName)) {
            sbHQL.append(" and P.adPackageName like ? escape '/'");
            params.add("%" + adPackageName.trim().replaceAll("_", "/_") + "%");
            
        }
   
    }





转载于:https://www.cnblogs.com/chubeautiful/p/3282171.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值