杂记jdbc保存



/**
 *  批量插入
 * @Version                  : 1.0
 * @Author                   :
 * @CreateDate               : Jan 21, 2013 9:45:31 AM
 * @param list
 * @throws SQLException 
 * @Return
 */
public void batchInsert(List<ProjectArDetail> list) throws SQLException{
PreparedStatement pstmt = null;
Connection con = null;
try {
Properties properties = ConfigUtil.getProperties(Global.JdbcConnectionFileNme);
String username = properties.getProperty(Global.JdbConnectionUserName);
String password = properties.getProperty(Global.JdbcConnectionPassword);
String className = properties.getProperty(Global.JdbcConnectionClassName);
String url =  properties.getProperty(Global.JdbcConnectionUrl);


JdbcHelperUtil jdbc = new JdbcHelperUtil(username,password,className,url);
con = jdbc.getConnection();
con.setAutoCommit(false);

String sql = "insert into b_project_ar_detail(" +
"year,month,sale_id,sale_name,project_sn,bill_num,project_name,company_name," +
"billing_date,ar_date,project_gp,project_type,ar_money,money_award,contract_date," +
"contract_start,contract_finish,terms_of_pay,ec_or_nc,budget_revenue," +
"status,modify_person,modify_time,remark)"+
" values(?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?)";

pstmt = con.prepareStatement(sql, ResultSet.TYPE_SCROLL_SENSITIVE,
ResultSet.CONCUR_READ_ONLY);

for (int i = 0; i < list.size(); i++) {
ProjectArDetail detail = list.get(i);
if(detail==null){continue;}


pstmt.setString(1, detail.getYear());
pstmt.setString(2, detail.getMonth());
if(detail.getSaleId()!=null && detail.getSaleId()>0)
pstmt.setInt(3, detail.getSaleId());
else 
pstmt.setNull(3, Types.INTEGER);


pstmt.setString(4, detail.getSaleName());
pstmt.setString(5, detail.getProjectSn());
pstmt.setString(6, detail.getBillNum());
pstmt.setString(7, detail.getProjectName());
pstmt.setString(8, detail.getCompanyName());
if(detail.getBillingDate()!=null)
pstmt.setDate(9, Date.valueOf(DateUtil.formatDateToYMD(detail.getBillingDate())));
if(detail.getArDate()!=null)
pstmt.setDate(10, Date.valueOf(DateUtil.formatDateToYMD(detail.getArDate())));


if(detail.getProjectGp()!=null && !detail.getProjectGp().equals(""))
pstmt.setDouble(11, detail.getProjectGp());
else
pstmt.setNull(11, Types.DOUBLE);


if(detail.getProjectType()!=null && detail.getProjectType()>0)
pstmt.setInt(12, detail.getProjectType());
else
pstmt.setNull(12, Types.INTEGER);


if(detail.getArMoney()!=null && detail.getArMoney()>0)
pstmt.setDouble(13, detail.getArMoney());
else
pstmt.setNull(13, Types.DOUBLE);


if(detail.getMoneyAward()!=null && detail.getMoneyAward()>0)
pstmt.setDouble(14, detail.getMoneyAward());
else
pstmt.setNull(14, Types.DOUBLE);


if(detail.getContractDate()!=null)
pstmt.setDate(15, Date.valueOf(DateUtil.formatDateToYMD(detail.getContractDate())));
else
pstmt.setNull(15, Types.DATE);

if(detail.getContractStart()!=null)
pstmt.setDate(16, Date.valueOf(DateUtil.formatDateToYMD(detail.getContractStart())));
else
pstmt.setNull(16, Types.DATE);

if(detail.getContractFinish()!=null)
pstmt.setDate(17, Date.valueOf(DateUtil.formatDateToYMD(detail.getContractFinish())));
else
pstmt.setNull(17, Types.DATE);



if(detail.getTermsOfPay()!=null && !detail.getTermsOfPay().equals(""))
pstmt.setString(18, detail.getTermsOfPay());
else
pstmt.setNull(18, Types.LONGVARCHAR);


if(detail.getEcOrNc()!=null && !detail.getEcOrNc().equals("")) 
pstmt.setString(19, detail.getEcOrNc());
else
pstmt.setNull(19, Types.VARCHAR);


if(detail.getBudgetRevenue()!=null && detail.getBudgetRevenue()>0)
pstmt.setDouble(20, detail.getBudgetRevenue());
else
pstmt.setNull(20, Types.DOUBLE);


if(detail.getStatus()!=null && !detail.getStatus().equals(""))
pstmt.setString(21, detail.getStatus());
else
pstmt.setNull(21, Types.VARCHAR);


if(detail.getModifyPerson()!=null && detail.getModifyPerson()>0)
pstmt.setInt(22, detail.getModifyPerson());
else
pstmt.setNull(22, Types.INTEGER);
if(detail.getModifyTime()!=null)
pstmt.setDate(23, Date.valueOf(DateUtil.formatDateToYMD(detail.getModifyTime())));
else
pstmt.setNull(23, Types.DATE);


if(detail.getRemark()!=null && !detail.getRemark().equals(""))
pstmt.setString(24, detail.getRemark());
else
pstmt.setNull(24, Types.VARCHAR);


pstmt.addBatch();
}


pstmt.executeBatch();
con.commit();


}catch (Exception e) {
e.printStackTrace();
}finally{
if(con!=null){
con.close();
}
}


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值