?? sqldboperator.java
字號:
package com.ntsky.note;
import java.io.*;
import java.sql.*;
import java.util.*;
import com.ntsky.note.Debug;
import com.ntsky.note.DBConnectionManager;
/**
* <p>Title: NTsky新聞發布</p>
* <p>Description: 數據庫操作</p>
* <p>Copyright: Copyright (c) 2003</p>
* <p>Company: NTsky</p>
* @authory 姚君林
* @version 1.0
*/
public class SQLDBOperator extends DBOperator {
private DBConnectionManager conManager;
private String poolName;
private PreparedStatement prepstmt=null;
private Connection conn;
private static SQLDBOperator instance;
/**
* 構造函數[從連接池取得連接]
*/
private SQLDBOperator(String strKey){
this.poolName = strKey;
//調用getInstance()方法獲得對連接池唯一實例的引用。
this.conManager = DBConnectionManager.getInstance();
this.conn = conManager.getConnection(strKey);
}
/**
* 關閉數據庫連接
*/
public void Close() {
try{
conManager.freeConnection(this.poolName, this.conn);
}
catch(Exception e){
e.printStackTrace(System.out);
}
}
/**
* 數據更新(插入&修改&刪除)
* @param strSql
*/
public void executeUpdate(String strSql){
try{
//strSql=new String(strSql.getBytes("GBK"),"ISO8859_1");
Statement stmt = this.conn.createStatement();
stmt.executeUpdate(strSql);
}
catch(Exception e){
e.printStackTrace(System.out);
Debug.writeLog("In executeUpdate(String), Exception Occured ! Info :" + e.getLocalizedMessage());
}
}
/**
* 數據查詢
* @param sql
* @return rs
*/
public ResultSet executeQuery(String strSql) {
ResultSet rs=null;
try{
//strSql=new String(strSql.getBytes("GBK"),"ISO8859_1");
Statement stmt = this.conn.createStatement();
rs = stmt.executeQuery(strSql);
}
catch(Exception e){
e.printStackTrace(System.out);
Debug.writeLog("In executeQuery(String), Exception Occured ! Info :" + e.getLocalizedMessage());
}
return rs;
}
/**
* 帶參數的數據操作
* @param strSql
*/
/**
* 創建數據庫操作的對象
* @param strSql
*/
public void prepareStatement(String strSql){
try{
prepstmt = this.conn.prepareStatement(strSql);
}
catch(Exception e){
e.printStackTrace(System.out);
Debug.writeLog("In prepareStatement(String strSql), Exception Occured ! Info :" + e.getLocalizedMessage());
}
}
/**
* 參數設置
*/
//字符串
public void setString(int index,String value){
try{
//value = new String(value.getBytes("GBK"), "ISO8859_1");
prepstmt.setString(index, value);
}
catch(Exception e){
e.printStackTrace(System.out);
Debug.writeLog("In setString(int index,String value), Exception Occured ! Info :" + e.getLocalizedMessage());
}
}
//整數
public void setInt(int index,int value){
try{
prepstmt.setInt(index, value);
}
catch(Exception e){
e.printStackTrace(System.out);
Debug.writeLog("In setInt(int index,int value), Exception Occured ! Info :" + e.getLocalizedMessage());
}
}
//清除接口包含SQL語句當前所用的全部參數
public void clearParameters(){
try{
prepstmt.clearParameters();
prepstmt=null;
}
catch(Exception e){
e.printStackTrace(System.out);
Debug.writeLog("In clearParameters(), Exception Occured ! Info :" + e.getLocalizedMessage());
}
}
//返回prepstmt
public PreparedStatement getPreparedStatement(){
return prepstmt;
}
/**
* 數據更新(帶參數)
*/
public void executeUpdate(){
try{
if(prepstmt!=null){
prepstmt.executeUpdate();
}
}
catch(Exception e){
e.printStackTrace(System.out);
Debug.writeLog("In executeUpdate(String), Exception Occured ! Info :" + e.getLocalizedMessage());
}
}
/**
* 數據查詢(帶參數)
* @return rs
*/
public ResultSet executeQuery(){
ResultSet rs=null;
try{
if(prepstmt!= null){
rs = prepstmt.executeQuery();
}
}
catch(Exception e){
e.printStackTrace(System.out);
Debug.writeLog("In executeQuery(String), Exception Occured ! Info :" + e.getLocalizedMessage());
}
return rs;
}
/**
* getConnection 方法注解。
*/
public Connection getConnection() {
return this.conn;
}
public static SQLDBOperator getInstance(String strKey){
if (instance==null)
instance = new SQLDBOperator(strKey);
return instance;//返回一個SQLDBOperator對象
}
}
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -