一、简易封装JDBC工具类

package com.jackie.MyBatis.main;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement; public class JdbcHelper { private static Connection conn = null; static {
try {
Class.forName("com.mysql.jdbc.Driver");
String url = "jdbc:mysql://localhost:3306/mybatis?useUnicode=true&characterEncoding=UTF-8";
String user = "jackie";
String pass = "123456";
conn = DriverManager.getConnection(url, user, pass);
} catch (ClassNotFoundException | SQLException e) {
e.printStackTrace();
}
} private void close(ResultSet rs, Statement stmt, Connection conn) {
try {
if(rs != null && !rs.isClosed()) {
rs.close();
}
if(stmt != null && !stmt.isClosed()) {
stmt.close();
}
if(conn != null && !conn.isClosed()) {
conn.close();
}
} catch (SQLException e) {
e.printStackTrace();
}
} public Role getRole(int id) {
PreparedStatement ps = null;
ResultSet rs = null;
try {
String sql = "select * from role where id=?";
ps = conn.prepareStatement(sql);
ps.setInt(1, id); // 注意从1开始计数
rs = ps.executeQuery(); Role role = null;
while(rs.next()) {
int roleId = rs.getInt("id");
String name = rs.getString("name");
role = new Role(roleId, name);
}
return role;
} catch (SQLException e) {
e.printStackTrace();
return null;
} finally {
this.close(rs, ps, conn);
}
}
}

实体类Role:

package com.jackie.MyBatis.main;

public class Role {

    private int id;

    private String name;

    public Role(int id, String name) {
this.id = id;
this.name = name;
} @Override
public String toString() {
return "[" + id + "," + name + "]";
} // getter and setter omitted }

使用:

public class Test {
public static void main(String[] args) {
JdbcHelper helper = new JdbcHelper();
System.out.println(helper.getRole(1));
}
}

二、三层架构

配置数据源 context.xml(也可以使用一些第三方的数据源库,如 c3p0):

<?xml version="1.0" encoding="UTF-8"?>
<context>
<resource name="jdbc/mysql" auth="Container" type="javax.sql.DataSource"
maxActive="100" maxIdle="30" maxWait="10000" username="jackie"
password="123456" driverClassName="com.mysql.jdbc.Driver"
url="jdbc:mysql://localhost:3306/mybatis?useUnicode=true&amp;characterEncoding=UTF-8" />
</context>

Dao层:

BaseDao:

package com.jackie.MyBatis.dao;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement; import javax.naming.Context;
import javax.naming.InitialContext;
import javax.naming.NamingException;
import javax.sql.DataSource; public class BaseDao { /**
* 查找JNDI,获得数据源对象,再获得数据库连接对象
*/
private Connection getConnection() {
Connection conn = null;
Context ctx = null;
try {
ctx = new InitialContext();
DataSource ds = (DataSource) ctx.lookup("java:comp/env/jdbc/mysql");
conn = ds.getConnection();
} catch (NamingException | SQLException e) {
e.printStackTrace();
}
if(conn == null) {
System.err.println("无法建立数据库连接");
}
return conn;
} private void closeAll(Connection conn, Statement stmt, ResultSet rs) {
try {
if(rs != null & !rs.isClosed()) {
rs.close();
}
if(stmt != null & !stmt.isClosed()) {
stmt.close();
}
if(conn != null & !conn.isClosed()) {
conn.close();
}
} catch (SQLException e) {
e.printStackTrace();
}
} private void closeAll(Connection conn, Statement stmt) {
closeAll(conn, stmt, null);
} public int executeUpdate(String sql, Object... params) {
int result = 0;
Connection conn = null;
PreparedStatement pstmt = null;
try {
conn = getConnection();
if(conn != null && !conn.isClosed()) {
pstmt = conn.prepareStatement(sql);
if(params != null) {
for (int i = 0; i < params.length; i++) {
pstmt.setObject(i + 1, params[i]);
}
}
result = pstmt.executeUpdate();
}
} catch (SQLException e) {
e.printStackTrace();
} finally {
closeAll(conn, pstmt);
}
return result;
} public Object executeQuery(RSProcessor processor, String sql, Object... params ) {
Object result = null;
Connection conn = null;
PreparedStatement pstmt = null;
ResultSet rs = null;
try {
conn = getConnection();
if(conn != null && !conn.isClosed()) {
pstmt = conn.prepareStatement(sql);
for (int i = 0; i < params.length; i++) {
pstmt.setObject(i + 1, params[i]);
}
rs = pstmt.executeQuery();
result = processor.process(rs);
}
} catch (SQLException e) {
e.printStackTrace();
} finally {
closeAll(conn, pstmt, rs);
}
return result;
} }

RSProcessor:

package com.jackie.MyBatis.dao;

import java.sql.ResultSet;
import java.sql.SQLException; /**
* 用于将Result对象指向的数据,转换成想要的对象
*/
public interface RSProcessor {
Object process(ResultSet rs) throws SQLException;
}

数据Dao —— UserDao:

package com.jackie.MyBatis.dao;

import java.util.List;

import com.jackie.MyBatis.domain.User;

public interface UserDao {
List<User> getAllUsers();
User getUserByName(String userName);
int addUser(User user);
}

Java 数据库篇的更多相关文章

  1. Jdbc访问数据库篇

    一万年太久,只争朝夕 What JDBC 上部 JDBC(Java DataBase Connectivity)Java 数据库连接,主要提供编写 Java 数据库应用程序的 API 支持 java. ...

  2. 【java 理论篇 2】J2EE的13种规范

    导读:看完了J2EE的视频,没有什么技术实践,现在就从理论上说明一下J2EE的13种规范,以及现在的自己对它的一个理解.可能会有偏差,但是,算是做为目前的一个记录. 一.13种规范 1.1.JDBC( ...

  3. (六) Java数据库

    一.概述 程序开发没有数据库的参与,可以说几乎是不可能的.数据库和Java都已经有了简单的了解,现在的关键是对两者进行连接,起到这一作用的正是JDBC——Java Database Connectiv ...

  4. JDBC与JAVA数据库编程

    一.JDBC的概念 1. JDBC (Java DataBase Connectivity) Java数据库连接 a) 主要提供java数据库应用程序的API支持 2. JDBC的主要功能 a) 创建 ...

  5. Java提高篇——对象克隆(复制)

    假如说你想复制一个简单变量.很简单: int apples = 5; int pears = apples; 不仅仅是int类型,其它七种原始数据类型(boolean,char,byte,short, ...

  6. Java提高篇(三三)-----Map总结

    在前面LZ详细介绍了HashMap.HashTable.TreeMap的实现方法,从数据结构.实现原理.源码分析三个方面进行阐述,对这个三个类应该有了比较清晰的了解,下面LZ就Map做一个简单的总结. ...

  7. Java提高篇(三二)-----List总结

    前面LZ已经充分介绍了有关于List接口的大部分知识,如ArrayList.LinkedList.Vector.Stack,通过这几个知识点可以对List接口有了比较深的了解了.只有通过归纳总结的知识 ...

  8. Java提高篇(三一)-----Stack

    在Java中Stack类表示后进先出(LIFO)的对象堆栈.栈是一种非常常见的数据结构,它采用典型的先进后出的操作方式完成的.每一个栈都包含一个栈顶,每次出栈是将栈顶的数据取出,如下: Stack通过 ...

  9. java提高篇(三十)-----Iterator

    迭代对于我们搞Java的来说绝对不陌生.我们常常使用JDK提供的迭代接口进行Java集合的迭代. Iterator iterator = list.iterator(); while(iterator ...

随机推荐

  1. PHP框架CI CodeIgniter 的log_message开启日志记录方法

    PHP框架CI CodeIgniter 的log_message开启日志记录方法 第一步:index.php文件,修改环境为开发环境define(‘ENVIRONMENT’, ‘development ...

  2. 一篇关于蓝牙SDP和L2CAP协议的文章

    SDP地址:http://www.cnblogs.com/strive-forever/archive/2011/11/04/2236640.html L2CAP地址:http://www.cnblo ...

  3. TensorFlow 分布式实践

    此wiki主要介绍分布式环境使用的一些条件,一直所要注意的内容: 确保在此之前阅读过TensorFlow for distributed 1.集群描述 当前tensorflow 的版本(0.8.0), ...

  4. N-Gram的基本原理

    1.N-Gram的介绍 N-Gram是基于一个假设:第n个词出现与前n-1个词相关,而与其他任何词不相关(这也是隐马尔可夫当中的假设).整个句子出现的概率就等于各个词出现的概率乘积.各个词的概率可以通 ...

  5. linux中权限对文件和目录的意义

    1.权限对文件的意义: 读:可查看文件的内容 写:可修改文件的内容(但不能删除文件) 执行:可执行文件 2.权限对目录的意义: 读:可以查看目录下的内容,即可以读取该目录下的结构列表 写:可修改目录下 ...

  6. Ajax解决csrf_token的不同方式

    ajax发送csrf_token的不同方式: 方式一: 在ajax发送之前,做好处理,用到了beforeSend方法,把csrf_token写入到Header头内,csrf_token去jquery. ...

  7. 《web前端设计基础——HTML5、CSS3、JavaScript》 张树明版 简答题简单整理

    web前端设计基础——HTML5.CSS3.JavaScript 简答题整理 第一章 (1)解释一下名词的含义:IP地址.URL.域名   iP定义了如何连入因特网,以及数据如何在主机间传输的标准. ...

  8. linux日常管理

    1.压缩和解压 tar压缩tar -czf hxl_product.tar.gz ./product tar解压tar -xzvf hxl_app.tar.gz z选项会将该压缩文件直接解压到目录,要 ...

  9. VIM自动补全Python代码

    pydiction插件 https://codeload.github.com/rkulla/pydiction/zip/master 新建bundle文件夹 mkdir ~/.vim/bundle ...

  10. Linux普通用户不能使用TAB键、上下键

    出发点 今天安装使用kail linux的时候发现tab键命令不能补全, 结合ubuntu, 因默认ubuntu创建的普通帐号,默认shell为/bin/sh,而这不支持tab等键的,所以将「指定用户 ...