Jdbc保存成功怎么获取id,和获取连接的类

连接类:

package com.tr.tools;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;

/**
 * @author Administrator
 *
 */
public class JdbcUtil {

 private String url = "jdbc:sqlserver://localhost:1433;databaseName=FireWolf";
 private String user = "sa";
 private String pwd = "123456";

 public static JdbcUtil getJdbcUtil() {
  return jdbcUtil;
 }

 private static JdbcUtil jdbcUtil = new JdbcUtil();

 private JdbcUtil() {
 }

 static {
  try {
   Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");
  } catch (ClassNotFoundException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  }
 }

 @SuppressWarnings("finally")
 public Connection getConnection()   {
  Connection conn=null;
  try {
   conn=DriverManager.getConnection(url, user, pwd);
  } catch (SQLException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  }finally{
   return conn;
  }

 }
}

 

连接操作类:

 

package com.tr.tools;

import java.sql.*;
import java.util.List;

import javax.servlet.jsp.jstl.sql.Result;
import javax.servlet.jsp.jstl.sql.ResultSupport;

public class DataHelp {
 private Connection conn = null;
 private String sql = null;
 @SuppressWarnings("unchecked")
 private List values = null;

 @SuppressWarnings("unchecked")
 public Result executeQuery(String sql, List list) {
  Result result = null;
  ResultSet rs = null;
  Statement stmt = null;
  PreparedStatement pstmt = null;
  this.setSql(sql);
  this.setValues(list);
  try {
   if (values != null && values.size() > 0) {
    conn = JdbcUtil.getJdbcUtil().getConnection();
    pstmt = conn.prepareStatement(sql);
    setValue(pstmt, values);
    rs = pstmt.executeQuery();
   } else {
    conn = JdbcUtil.getJdbcUtil().getConnection();
    stmt = conn.createStatement();
    rs = stmt.executeQuery(sql);
   }
   result = ResultSupport.toResult(rs);
  } catch (Exception e) {
  } finally {
   closeConn(conn);
   closeAll(stmt, pstmt, result, rs);
  }
  return result;
 }
 
 @SuppressWarnings("unchecked")
 public int executeUpdate(String sql,List list) {
  int rows=0;
  ResultSet rs=null;
  PreparedStatement pstmt=null;
  Statement stmt=null;
  Result result=null;
  this.setSql(sql);
  this.setValues(list);
     try {
      conn = JdbcUtil.getJdbcUtil().getConnection();
   if (values != null && values.size() > 0) {
    pstmt = conn.prepareStatement(sql);
    setValue(pstmt, values);
    rows = pstmt.executeUpdate();
   } else {
    stmt = conn.createStatement();
    rows = stmt.executeUpdate(sql);
   }
  } catch (Exception e) {
   e.printStackTrace();
  }finally{
   closeConn(conn);
   closeAll(stmt, pstmt, result, rs); 
  }
  return rows;
    
 }

 @SuppressWarnings("unchecked")
 public int save(String sql, List list) {
  int rows = 0;
  ResultSet rs = null;
  PreparedStatement pstmt = null;
  Statement stmt = null;
  Result result = null;
  this.setSql(sql);
  this.setValues(list);
  try {
  
    if (values != null && values.size() > 0) {
     conn = JdbcUtil.getJdbcUtil().getConnection();
     pstmt = conn.prepareStatement(sql,Statement.RETURN_GENERATED_KEYS);
     setValue(pstmt, values);
     pstmt.executeUpdate();
     rs = pstmt.getGeneratedKeys();
     if (rs.next())
      rows = rs.getInt(1);
    }
  } catch (Exception e) {
   e.printStackTrace();
  } finally {
   closeConn(conn);
   closeAll(stmt, pstmt, result, rs);
  }
  return rows;

 }

 @SuppressWarnings("unchecked")
 private void setValue(PreparedStatement pstmt, List values)
   throws SQLException {
  for (int i = 0; i < values.size(); i++) {
   Object obj = values.get(i);
   pstmt.setObject(i + 1, obj);
  }
 }

 public Connection getConn() {
  return conn;
 }

 public String getSql() {
  return sql;
 }

 @SuppressWarnings("unchecked")
 public List getValues() {
  return values;
 }

 public void setConn(Connection conn) {
  this.conn = conn;
 }

 public void setSql(String sql) {
  this.sql = sql;
 }

 @SuppressWarnings("unchecked")
 public void setValues(List values) {
  this.values = values;
 }

 public static void closeAll(Statement stmt, PreparedStatement pstmt,
   Result result, ResultSet rs) {
  if (rs != null) {
   try {
    rs.close();
   } catch (SQLException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
   }
  }
  if (stmt != null) {
   try {
    stmt.close();
   } catch (SQLException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
   }
  }
  if (pstmt != null) {
   try {
    pstmt.close();
   } catch (SQLException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
   }
  }

 }

 public static void closeConn(Connection conn) {
  try {
   if (conn != null && (!conn.isClosed())) {
    conn.close();
   }
  } catch (SQLException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  }
 }

}

 

package test; import java.io.BufferedReader; import java.io.IOException; import java.io.InputStream; import java.io.InputStreamReader; import java.io.OutputStream; import java.net.HttpURLConnection; import java.net.MalformedURLException; import java.net.URL; import java.util.List; import java.util.Map; public class HttpTest { private HttpURLConnection hc = null; private static final String oneUrlString = "http://xxx.jsp"; private static final String twoUrlString = "http://xxx.action"; public String getSessionId() { String sessionId = ""; try { URL url = new URL(oneUrlString); hc = (HttpURLConnection) url.openConnection();//默认的用GET提交 hc.setDoOutput(true); hc.connect(); Map map = hc.getHeaderFields(); //得到Cookie的所有内容,包括SESSIONID,在进行下次提交的时候 直接把这个Cookie的值设到头里头就行了 //淡然只得到SESSIONID也很简单的 ,但是有时候Set-Cookie的值有几个的 List list = (List) map.get("Set-Cookie"); if(list.size() == 0||list == null) { return null; } StringBuilder builder = new StringBuilder(); for(String str : list) { sessionId = builder.append(str).toString(); } hc.disconnect(); } catch (MalformedURLException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } return sessionId; } public String getResponseContext(String parameters) { String responseContext = ""; try { URL url = new URL(twoUrlString); hc = (HttpURLConnection) url.openConnection();//使用POST提交 hc.addRequestProperty("Cookie", getSessionId()); hc.setDoOutput(true); hc.connect(); OutputStream out = hc.getOutputStream(); //参数是a=""&b=""这样拼接的一个串 out.flush(); out.close(); out.write(parameters.getBytes(),0,parameters.getBytes().length); InputStream in = hc.getInputStream(); InputStreamReader reader = new InputStreamReader(in,"gb2312"); BufferedReader read = new BufferedReader(reader); StringBuilder builder = new StringBuilder(); String str = ""; while((str = read.readLine()) != null) { builder = builder.append(str); } read.close(); reader.close(); in.close(); hc.disconnect(); responseContext = builder.toString(); } catch (MalformedURLException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } return responseContext; } }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值