主頁 > 知識(shí)庫 > JSP基于JDBC的數(shù)據(jù)庫連接類實(shí)例

JSP基于JDBC的數(shù)據(jù)庫連接類實(shí)例

熱門標(biāo)簽:如何用中國地圖標(biāo)注數(shù)字點(diǎn) 地圖標(biāo)注市場(chǎng)怎么樣 企業(yè)怎么在聯(lián)通申請(qǐng)400電話 南京新思維電話機(jī)器人 南昌市地圖標(biāo)注app 好操作的電話機(jī)器人廠家 百度地圖添加標(biāo)注圖標(biāo)樣式 泰州泰興400電話 怎么申請(qǐng) 聊城智能電銷機(jī)器人外呼

本文實(shí)例講述了JSP基于JDBC的數(shù)據(jù)庫連接類。分享給大家供大家參考,具體如下:

/*
 *
 * TODO To change the template for this generated file go to
 * Window - Preferences - Java - Code Style - Code Templates
 */
package com.yanek.test;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.util.Enumeration;
import java.util.Hashtable;
import java.util.PropertyResourceBundle;
import javax.naming.Context;
import javax.naming.InitialContext;
import javax.naming.NamingException;
import javax.sql.DataSource;
/**
 * @author Administrator
 * 
 * TODO To change the template for this generated type comment go to Window -
 * Preferences - Java - Code Style - Code Templates
 */
public class Database {
 /**
 * 數(shù)據(jù)庫訪問URL
 */
 private static String url;
 /**
 * 數(shù)據(jù)庫驅(qū)動(dòng)
 */
 private static String driver;
 /**
 * 數(shù)據(jù)庫訪問用戶名
 */
 private static String username;
 /**
 * 數(shù)據(jù)庫訪問口令
 */
 private static String password;
 /**
 * 訪問類型
 */
 private static String type;
 /**
 * 數(shù)據(jù)源名稱
 */
 private static String datasource;
 /**
 * 配置文件名稱
 */
 private final static String fileName = "database";
 private static ThreadLocal connection = new ThreadLocal();
 static {
 config();
 }
 private static void config() {
 // 讀取系統(tǒng)配置
 PropertyResourceBundle resourceBundle = (PropertyResourceBundle) PropertyResourceBundle
  .getBundle(fileName);
 // 將系統(tǒng)設(shè)置賦值給類變量
 Enumeration enu = resourceBundle.getKeys();
 while (enu.hasMoreElements()) {
  String propertyName = enu.nextElement().toString();
  if (propertyName.equals("database.url"))
  url = resourceBundle.getString("database.url");
  if (propertyName.equals("database.driver"))
  driver = resourceBundle.getString("database.driver");
  if (propertyName.equals("database.username"))
  username = resourceBundle.getString("database.username");
  if (propertyName.equals("database.password"))
  password = resourceBundle.getString("database.password");
  if (propertyName.equals("database.type"))
  type = resourceBundle.getString("database.type");
  if (propertyName.equals("database.datasource"))
  datasource = resourceBundle.getString("database.datasource");
 }
 }
 /**
 * 取得數(shù)據(jù)庫連接
 * 
 * @return
 * @throws SQLException
 */
 public synchronized static java.sql.Connection getConnection()
  throws SQLException {
 Connection con = (Connection) connection.get();
 if (con != null  !con.isClosed()) {
  return con;
 }
 if ("pooled".equalsIgnoreCase(type)) {
  // 從JNDI中取得數(shù)據(jù)源
  try {
  // 此處對(duì)于不同的應(yīng)用服務(wù)器,對(duì)env傳入不同
  Hashtable env = new Hashtable();
  // 此處對(duì)于不同的應(yīng)用服務(wù)器,對(duì)env傳入不同
  Context ctx = new InitialContext(env); // 從命名系統(tǒng)中獲取 DataSource
  // 工廠對(duì)象
  DataSource dataSource = (DataSource) ctx.lookup(datasource);
  con = dataSource.getConnection();
  connection.set(con);
  return con;
  } catch (NamingException e) {
  e.printStackTrace();
  }
 } else {
  // 直接使用JDBC驅(qū)動(dòng)連接
  try {
  Class providerClass = Class.forName(driver);
  con = DriverManager.getConnection(url, username, password);
  con.setAutoCommit(false);
  connection.set(con);
  return con;
  } catch (ClassNotFoundException e) {
  e.printStackTrace();
  }
 }
 return null;
 }
 public static void commit() {
 Connection con = (Connection) connection.get();
 try {
  con.commit();
 } catch (SQLException e) {
  e.printStackTrace();
 }
 }
 public static void rollback() {
 Connection con = (Connection) connection.get();
 try {
  con.rollback();
 } catch (SQLException e) {
  e.printStackTrace();
 }
 }
 public synchronized static void releaseConnection(Connection connection) {
 try {
  if (connection != null  !connection.isClosed())
  connection.close();
 } catch (SQLException e) {
  // TODO Auto-generated catch block
  e.printStackTrace();
 }
 connection = null;
 }
 public static void main(String[] args) {
 try {
  System.out.println("conn:" + Database.getConnection());
 } catch (SQLException e) {
  // TODO Auto-generated catch block
  e.printStackTrace();
 }
 }
}

database.property文件

復(fù)制代碼 代碼如下:
database.driver=com.mysql.jdbc.Driver
database.url=jdbc:mysql://localhost/test?user=rootpassword=rootuseUnicode=truecharacterEncoding=gbk

希望本文所述對(duì)大家jsp程序設(shè)計(jì)有所幫助。

您可能感興趣的文章:
  • jsp+jdbc實(shí)現(xiàn)連接數(shù)據(jù)庫的方法
  • JSP中使用JDBC訪問SQL Server 2008數(shù)據(jù)庫示例
  • 加快JDBC設(shè)計(jì)中JSP訪問數(shù)據(jù)庫
  • JDBC操作數(shù)據(jù)庫的增加、刪除、更新、查找實(shí)例分析
  • jdbc操作mysql數(shù)據(jù)庫實(shí)例
  • JDBC鏈接數(shù)據(jù)庫的幾個(gè)步驟
  • JDBC對(duì)MySQL數(shù)據(jù)庫布爾字段的操作方法
  • Java使用JDBC連接數(shù)據(jù)庫的實(shí)現(xiàn)方法

標(biāo)簽:烏蘭察布 開封 山南 銅川 白銀 吉林 自貢 臨汾

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《JSP基于JDBC的數(shù)據(jù)庫連接類實(shí)例》,本文關(guān)鍵詞  JSP,基于,JDBC,的,數(shù)據(jù)庫,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《JSP基于JDBC的數(shù)據(jù)庫連接類實(shí)例》相關(guān)的同類信息!
  • 本頁收集關(guān)于JSP基于JDBC的數(shù)據(jù)庫連接類實(shí)例的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章