zoukankan      html  css  js  c++  java
  • jdbcTemplate insert 封装

    public <T> void insert(String sql, List<T> objlist) {
            final List<T> list=objlist;
            BatchPreparedStatementSetter setter=new BatchPreparedStatementSetter(){  
                                            
                    public int getBatchSize(){  
                        return list.size();  
                    }  
                    public void setValues(PreparedStatement ps,int index) throws SQLException{  
                        T t=list.get(index);  
                        Field fields[]=t.getClass().getDeclaredFields();
                        try {
                            for(int i=0;i<fields.length;i++){
                                PropertyDescriptor  prop=new PropertyDescriptor(fields[i].getName(),t.getClass());
                                Method getmethod=prop.getReadMethod();
                                if(fields[i].getType().getCanonicalName().equalsIgnoreCase("java.lang.String")){
                                    ps.setString(i+1, String.valueOf(getmethod.invoke(t)));
                                    //System.out.println(ps.getResultSet().getString(i+1));
                                }
                                else if(fields[i].getType().getCanonicalName().equalsIgnoreCase("int")){
                                    ps.setInt(i+1, (Integer)getmethod.invoke(t));
                                    //System.out.println(ps.getResultSet().getInt(i+1));
                                }
                                else if(fields[i].getType().getCanonicalName().equalsIgnoreCase("long")){
                                    ps.setLong(i+1, (Long) getmethod.invoke(t));
                                    //System.out.println(ps.getResultSet().getLong(i+1));
                                }
                                else if(fields[i].getType().getCanonicalName().equalsIgnoreCase("double")){
                                    ps.setDouble(i+1, (Double) getmethod.invoke(t));
                                    //System.out.println(ps.getResultSet().getDouble(i+1));
                                }
                                else if(fields[i].getType().getCanonicalName().equalsIgnoreCase("java.lang.Integer")){
                                    ps.setInt(i+1, (Integer)getmethod.invoke(t));
                                    //System.out.println(ps.getResultSet().getInt(i+1));
                                }
                                else if(fields[i].getType().getCanonicalName().equalsIgnoreCase("java.lang.Long")){
                                    ps.setLong(i+1, (Long) getmethod.invoke(t));
                                    //System.out.println(ps.getResultSet().getLong(i+1));
                                }
                                else if(fields[i].getType().getCanonicalName().equalsIgnoreCase("java.lang.Double")){
                                    ps.setDouble(i+1, (Double) getmethod.invoke(t));
                                    //System.out.println(ps.getResultSet().getDouble(i+1));
                                }
                                else if(fields[i].getType().getCanonicalName().equalsIgnoreCase("java.util.Date")){
                                    ps.setDate(i+1,   new java.sql.Date(((Date)getmethod.invoke(t)).getTime()));
                                    //System.out.println(ps.getResultSet().getDate(i+1));
                                }
                            }
                        } catch (IllegalAccessException e) {
                            // TODO Auto-generated catch block
                            e.printStackTrace();
                        } catch (IllegalArgumentException e) {
                            // TODO Auto-generated catch block
                            e.printStackTrace();
                        } catch (InvocationTargetException e) {
                            // TODO Auto-generated catch block
                            e.printStackTrace();
                        } catch (IntrospectionException e) {
                            // TODO Auto-generated catch block
                            e.printStackTrace();
                        }
                    } 
                };  
                jdbcTemplate.batchUpdate(sql,setter);  
                                    
        }
    }
  • 相关阅读:
    001 spring AOP介绍
    026 spring事件机制--基础内容
    025 使用@Profile完成环境条件注入
    ExpandoObject使用
    企业微信接口问题
    企业号验证后携带URL参数跳转问题
    在创建一个MVC控制器,显示运行所选代码生成器时出错(带读写,使用EF)
    码栈批量提取淘宝后台的图图片空间图片
    码栈编码
    在微信里面打开链接,显示501 Not Implemented,但是同样的链接在其他浏览器是可以打开的。
  • 原文地址:https://www.cnblogs.com/JAYIT/p/12522642.html
Copyright © 2011-2022 走看看