CREATE TABLE `user` ( `id` int(10) unsigned NOT NULL AUTO_INCREMENT, `username` varchar(50) DEFAULT NULL, `password` varchar(50) DEFAULT NULL, `email` varchar(50) DEFAULT NULL, PRIMARY KEY (`id`), );
import java.sql.Connection;
import java.sql.DriverManager;
/**
* 获取数据库连接
*/
public class DBConnection {
/** Oracle数据库连接URL*/
private final static String DB_URL = "jdbc:oracle:thin:@127.0.0.1:1521:orcl";
/** Oracle数据库连接驱动*/
private final static String DB_DRIVER = "oracle.jdbc.driver.OracleDriver";
/** 数据库用户名*/
private final static String DB_USERNAME = "root";
/** 数据库密码*/
private final static String DB_PASSWORD = "admin";
/**
* 获取数据库连接
* @return
*/
public Connection getConnection(){
/** 声明Connection连接对象*/
Connection conn = null;
try{
/** 使用Class.forName()方法自动创建这个驱动程序的实例且自动调用DriverManager来注册它*/
Class.forName(DB_DRIVER);
/** 通过DriverManager的getConnection()方法获取数据库连接*/
conn = DriverManager.getConnection(DB_URL,DB_USERNAME,DB_PASSWORD);
}catch(Exception ex){
ex.printStackTrace();
}
return conn;
}
/**
* 关闭数据库连接
*
* @param connect
*/
public void closeConnection(Connection conn){
try{
if(conn!=null){
/** 判断当前连接连接对象如果没有被关闭就调用关闭方法*/
if(!conn.isClosed()){
conn.close();
}
}
}catch(Exception ex){
ex.printStackTrace();
}
}
}
<%@page import="java.sql.*, com.mysql.jdbc.Driver"%>
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<html>
<body>
<%
//com.mysql.jdbc.Driver
Class.forName(Driver.class.getName()).newInstance();
String url = "jdbc:mysql://localhost:3306/demo?useUnicode=true&characterEncoding=UTF8";
String user = "root";
String password = "123";
Connection conn = DriverManager.getConnection(url, user, password);
Statement stmt = conn.createStatement();
String sql = "select * from user";
ResultSet rs = stmt.executeQuery(sql);
while(rs.next()) {
out.print("<br />" + "====================" + "<br />");
out.print(rs.getLong("id") + " ");
out.print(rs.getString("username") + " ");
out.print(rs.getString("password") + " ");
out.print(rs.getString("email") + " ");
}
%>
</body>
</html>
<%@page import="java.sql.*, javax.naming.*, javax.sql.DataSource"%>
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<html>
<body>
<%
Context initCtx = new InitialContext();
DataSource ds = (DataSource)initCtx.lookup("java:comp/env/jdbc/demoDB");
Connection conn = ds.getConnection();
Statement stmt = conn.createStatement();
String sql = "select * from user";
ResultSet rs = stmt.executeQuery(sql);
while(rs.next()) {
out.print("<br />" + "====================" + "<br />");
out.print(rs.getLong("id") + " ");
out.print(rs.getString("username") + " ");
out.print(rs.getString("password") + " ");
out.print(rs.getString("email") + " ");
}
%>
</body>
</html>
<Context> <Resource name="jdbc/demoDB" auth="Container" type="javax.sql.DataSource" driverClassName="com.mysql.jdbc.Driver" url="jdbc:mysql://localhost:3306/demo" username="root" password="123" maxActive="50" maxIdle="30" maxWait="10000" /> </Context>
<resource-ref> <description>mysqlDB Connection</description> <res-ref-name>jdbc/demoDB</res-ref-name> <res-type>javax.sql.DataSource</res-type> <res-auth>Container</res-auth> </resource-ref>
<?xml version="1.0" encoding="UTF-8"?> <Context> <Resource name="jdbc/demoDB" auth="Container" type="javax.sql.DataSource" driverClassName="com.mysql.jdbc.Driver" url="jdbc:mysql://localhost:3306/demo" username="root" password="123" maxActive="50" maxIdle="30" maxWait="10000" /> </Context>
package db.utils;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.SQLException;
import java.sql.Statement;
import java.text.DateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import javax.naming.InitialContext;
import javax.sql.DataSource;
//import org.apache.log4j.Logger;
/**
* 数据库操作辅助类
*/
public class DbUtils {
//private static Logger logger = Logger.getLogger("DbUtils");
/**
* 该语句必须是一个 SQL INSERT、UPDATE 或 DELETE 语句
* @param sql
* @param paramList:参数,与SQL语句中的占位符一一对应
* @return
* @throws Exception
*/
public int execute(String sql, List<Object> paramList) throws Exception {
if(sql == null || sql.trim().equals("")) {
//logger.info("parameter is valid!");
}
Connection conn = null;
PreparedStatement pstmt = null;
int result = 0;
try {
conn = getConnection();
pstmt = DbUtils.getPreparedStatement(conn, sql);
setPreparedStatementParam(pstmt, paramList);
if(pstmt == null) {
return -1;
}
result = pstmt.executeUpdate();
} catch (Exception e) {
//logger.info(e.getMessage());
throw new Exception(e);
} finally {
closeStatement(pstmt);
closeConn(conn);
}
return result;
}
/**
* 将查询数据库获得的结果集转换为Map对象
* @param sql:查询语句
* @param paramList:参数
* @return
*/
public List<Map<String, Object>> getQueryList(String sql, List<Object> paramList) throws Exception {
if(sql == null || sql.trim().equals("")) {
//logger.info("parameter is valid!");
return null;
}
Connection conn = null;
PreparedStatement pstmt = null;
ResultSet rs = null;
List<Map<String, Object>> queryList = null;
try {
conn = getConnection();
pstmt = DbUtils.getPreparedStatement(conn, sql);
setPreparedStatementParam(pstmt, paramList);
if(pstmt == null) {
return null;
}
rs = getResultSet(pstmt);
queryList = getQueryList(rs);
} catch (RuntimeException e) {
//logger.info(e.getMessage());
System.out.println("parameter is valid!");
throw new Exception(e);
} finally {
closeResultSet(rs);
closeStatement(pstmt);
closeConn(conn);
}
return queryList;
}
private void setPreparedStatementParam(PreparedStatement pstmt, List<Object> paramList) throws Exception {
if(pstmt == null || paramList == null || paramList.isEmpty()) {
return;
}
DateFormat df = DateFormat.getDateTimeInstance();
for (int i = 0; i < paramList.size(); i++) {
if(paramList.get(i) instanceof Integer) {
int paramValue = ((Integer)paramList.get(i)).intValue();
pstmt.setInt(i+1, paramValue);
} else if(paramList.get(i) instanceof Float) {
float paramValue = ((Float)paramList.get(i)).floatValue();
pstmt.setFloat(i+1, paramValue);
} else if(paramList.get(i) instanceof Double) {
double paramValue = ((Double)paramList.get(i)).doubleValue();
pstmt.setDouble(i+1, paramValue);
} else if(paramList.get(i) instanceof Date) {
pstmt.setString(i+1, df.format((Date)paramList.get(i)));
} else if(paramList.get(i) instanceof Long) {
long paramValue = ((Long)paramList.get(i)).longValue();
pstmt.setLong(i+1, paramValue);
} else if(paramList.get(i) instanceof String) {
pstmt.setString(i+1, (String)paramList.get(i));
}
}
return;
}
/**
* 获得数据库连接
* @return
* @throws Exception
*/
private Connection getConnection() throws Exception {
InitialContext cxt = new InitialContext();
DataSource ds = (DataSource) cxt.lookup(jndiName);
if ( ds == null ) {
throw new Exception("Data source not found!");
}
return ds.getConnection();
}
private static PreparedStatement getPreparedStatement(Connection conn, String sql) throws Exception {
if(conn == null || sql == null || sql.trim().equals("")) {
return null;
}
PreparedStatement pstmt = conn.prepareStatement(sql.trim());
return pstmt;
}
/**
* 获得数据库查询结果集
* @param pstmt
* @return
* @throws Exception
*/
private ResultSet getResultSet(PreparedStatement pstmt) throws Exception {
if(pstmt == null) {
return null;
}
ResultSet rs = pstmt.executeQuery();
return rs;
}
/**
* @param rs
* @return
* @throws Exception
*/
private List<Map<String, Object>> getQueryList(ResultSet rs) throws Exception {
if(rs == null) {
return null;
}
ResultSetMetaData rsMetaData = rs.getMetaData();
int columnCount = rsMetaData.getColumnCount();
List<Map<String, Object>> dataList = new ArrayList<Map<String, Object>>();
while (rs.next()) {
Map<String, Object> dataMap = new HashMap<String, Object>();
for (int i = 0; i < columnCount; i++) {
dataMap.put(rsMetaData.getColumnName(i+1), rs.getObject(i+1));
}
dataList.add(dataMap);
}
return dataList;
}
/**
* 关闭数据库连接
* @param conn
*/
private void closeConn(Connection conn) {
if(conn == null) {
return;
}
try {
conn.close();
} catch (SQLException e) {
//logger.info(e.getMessage());
}
}
/**
* 关闭
* @param stmt
*/
private void closeStatement(Statement stmt) {
if(stmt == null) {
return;
}
try {
stmt.close();
} catch (SQLException e) {
//logger.info(e.getMessage());
}
}
/**
* 关闭
* @param rs
*/
private void closeResultSet(ResultSet rs) {
if(rs == null) {
return;
}
try {
rs.close();
} catch (SQLException e) {
//logger.info(e.getMessage());
}
}
private String jndiName = "java:/comp/env/jdbc/demoDB";
public void setJndiName(String jndiName) {
this.jndiName = jndiName;
}
}
机械节能产品生产企业官网模板...
大气智能家居家具装修装饰类企业通用网站模板...
礼品公司网站模板
宽屏简约大气婚纱摄影影楼模板...
蓝白WAP手机综合医院类整站源码(独立后台)...苏ICP备2024110244号-2 苏公网安备32050702011978号 增值电信业务经营许可证编号:苏B2-20251499 | Copyright 2018 - 2025 源码网商城 (www.ymwmall.com) 版权所有