spring 多条件访问数据库

@service 层
public List<T> getAllObject(int toPage, int pageSize,  
            String name,  String type, int status) {  
        String sql = "" ;
        Object[] params = new Object[3];//最多有几个参数就写多大  
        int index = 0;  
        if (null!=name&&!name.equals("")) {  
            sql += " WHERE name LIKE CONCAT('%',?,'%') ";  
            params[index] = name;  
            index++;  
        }  
        if (null!=taskType&&!taskType.equals("")) { 
            if(index==0){
                sql += "WHERE type= ? ";  
            }else{
                sql += " AND type= ? ";  
            }
            params[index] = taskType;  
            index++;  
        }   
        if (status== 1 || status== 0) {  
           if(index==0){
            sql += "WHERE status= ? ";  
        }else{
            sql += " AND status= ? ";  
            }
            params[index] = status;  
            index++;  
        }  
        Object[] paramsEnd = new Object[index];  
        System.arraycopy(params, 0, paramsEnd, 0, index);  //把params的内容复制给paramsEnd,这是最终的参数数组
        return objectDao.getAllObject(sql,paramsEnd);

@dao层
public List<T> getAllObject(String str, Object[] param)
            throws Exception {
        String sql = SELECT_OBJECT_ALL+str;
        List<T> task = new ArrayList<T>();
        task = jdbcTemplate.query(sql,param,
                new TaskRowMapper());                       
        return task;
    }

使用System.arraycopy()实现数组之间的复制
System提供了一个静态方法arraycopy(),我们可以使用它来实现数组之间的复制。其函数原型是: public static void arraycopy(Object src, int srcPos, Object dest, int destPos, int length) src:源数组; srcPos:源数组要复制的起始位置; dest:目的数组; destPos:目的数组放置的起始位置; length:复制的长度。 注意:src and dest都必须是同类型或者可以进行转换类型的数组. 有趣的是这个函数可以实现自己到自己复制,比如: int[] fun ={0,1,2,3,4,5,6}; System.arraycopy(fun,0,fun,3,3); 则结果为:{0,1,2,0,1,2,6}; 实现过程是这样的,先生成一个长度为length的临时数组,将fun数组中srcPos 到srcPos+length-1之间的数据拷贝到临时数组中,再执行System.arraycopy(临时数组,0,fun,3,3).
此文为根据csdn上文章思路创作的代码片段,本段代码为自己编写,但是思路为spring jdbc多条件查询(参数化传参,防止sql注入风险)
原文为https://blog.csdn.net/fangqun663775/article/details/50581683

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值