
大家好,又见面了,我是你们的朋友全栈君。
(1)注册驱动 (只做一次) (2)建立连接(Connection) (3)创建执行SQL的语句(Statement) (4)执行语句 (5)处理执行结果(ResultSet) (6)释放资源
(1)Class.forName(“com.mysql.jdbc.Driver”); 推荐这种方式,不会对具体的驱动类产生依赖。 (2)DriverManager.registerDriver(com.mysql.jdbc.Driver); 会造成DriverManager中产生两个一样的驱动,并会对具体的驱动类产生依赖。 (3)System.setProperty(“jdbc.drivers”, “driver1:driver2”); 虽然不会对具体的驱动类产生依赖;但注册不太方便,所以很少使用 。
Connection conn = DriverManager.getConnection(url, user, password); (1)url格式:JDBC:子协议:子名称//主机名:端口/数据库名?属性名=属性值&… (2)User,password可以用“属性名=属性值”方式告诉数据库;
(1)Statement类的创建执行sql语句:
String sql = “select * from table_name where col_name=‘李四’”; Statement st = conn.createStatement(); ResultSet rs =st.executeQuery(sql)
(2)PreparedStatement类的创建执行sql语句:
String sql = “select * from table_name where col_name=?”; PreparedStatement ps = conn.preparedStatement(sql); ps.setString(1, “col_value”); //将第一个?替换成col_value ResultSet rs = ps.executeQuery();
While(rs.next()){ rs.getString(“col_name”); rs.getInt(“col_name”); //… }
(1)释放ResultSet, Statement,Connection. (2)数据库连接(Connection)是非常稀有的资源,用完后必须马上释放,如果Connection不能及时正确的关闭将导致系统宕机。Connection的使用原则是尽量晚创建,尽量早的释放。
Connection conn = null; Statement st=null; ResultSet rs = null; try { //获得Connection //创建Statement //处理查询结果ResultSet } finally { //释放资源ResultSet, Statement,Connection }
(1)增、删、改用Statement.executeUpdate来完成,返回整数(匹配的记录数),这类操作相对简单。
(2) 查询用Statement.executeQuery来完成,返回的是ResultSet对象,ResultSet中包含了查询的结果;查询相对与增、删、改要复杂一些,因为有查询结果要处理。
在SQL中包含特殊字符或SQL的关键字(如:’ or 1 or ‘)时Statement将出现不可预料的结果(出现异常或查询的结果不正确),可用PreparedStatement来解决。
PreperedStatement(从Statement扩展而来)相对Statement的优点: 1.没有SQL注入的问题。 2.Statement会使数据库频繁编译SQL,可能造成数据库缓冲区溢出。 3.数据库和驱动可以对PreperedStatement进行优化(只有在相关联的数据库连接没有关闭的情况下有效)。
工具类JdbsUtils.java
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import com.mysql.jdbc.Statement;
public final class JdbcUtils {
private static String url = "jdbc:mysql://localhost:3306/mydatabase";
private static String user = "root";
private static String password = "123";
private JdbcUtils() {
}
/**
* 注册驱动
*/
static {
try {
Class.forName("com.mysql.jdbc.Driver");
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
}
/**
* 建立连接
*
* @return
*/
public static Connection getConnection() {
Connection conn = null;
try {
conn = (Connection) DriverManager.getConnection(url, user, password);
} catch (SQLException e) {
e.printStackTrace();
}
return conn;
}
/**
* 释放资源
*
* @param rs
* @param st
* @param conn
*/
public static void free(ResultSet rs, Statement st, Connection conn) {
// 释放ResultSet
try {
if (rs != null)
rs.close();
} catch (SQLException e) {
e.printStackTrace();
} finally {
// 释放Statement
try {
if (st != null)
st.close();
} catch (SQLException e) {
e.printStackTrace();
} finally {
// 释放Connection
try {
if (conn != null)
conn.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
}
}
}工具类(单例模式)JdbsUtilsSing.java
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import com.mysql.jdbc.Statement;
public final class JdbcUtilsSing {
private String url = "jdbc:mysql://localhost:3306/mydatabase";
private String user = "root";
private String password = "123";
private static JdbcUtilsSing instance = null;
private JdbcUtilsSing() {
}
public static JdbcUtilsSing getInstance() {
if (instance == null) {
synchronized (JdbcUtilsSing.class) {
if(null == instance){ //这步必须
instance = new JdbcUtilsSing();
}
}
}
return instance;
}
/**
* 注册驱动
*/
static {
try {
Class.forName("com.mysql.jdbc.Driver");
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
}
/**
* 建立连接
*
* @return
*/
public Connection getConnection() {
Connection conn = null;
try {
conn = (Connection) DriverManager.getConnection(url, user, password);
} catch (SQLException e) {
e.printStackTrace();
}
return conn;
}
/**
* 释放资源
*
* @param rs
* @param st
* @param conn
*/
public void free(ResultSet rs, Statement st, Connection conn) {
// 释放ResultSet
try {
if (rs != null)
rs.close();
} catch (SQLException e) {
e.printStackTrace();
} finally {
// 释放Statement
try {
if (st != null)
st.close();
} catch (SQLException e) {
e.printStackTrace();
} finally {
// 释放Connection
try {
if (conn != null)
conn.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
}
}
}(1)单例模式是通过静态方法 public static JdbcUtilsSing getInstance() 来创建实例,从而调用类中的其他成员方法。
(2)工具类是直接类名调用相应的静态方法。
采用Statement建立连接(采用的是单例模式JdbcUtilsSing)
static void template() { Connection conn = null; Statement st = null; ResultSet rs = null; try { // 建立连接 // conn = (Connection) JdbcUtils.getConnection(); conn = (Connection) JdbcUtilsSing.getInstance().getConnection(); // 创建语句 st = (Statement) conn.createStatement(); // 执行语句 String sql = null; // sql = "select * from my_class"; sql = "insert into my_class"; rs = st.executeQuery(sql); // 处理结果 while (rs.next()) { System.out.println(rs.getObject("id") + "\t" + rs.getObject("c_name") + "\t" + rs.getObject("room")); } } catch (SQLException e) { e.printStackTrace(); } finally { JdbcUtilsSing.getInstance().free(rs, st, conn); //关闭资源 } }采用PreparedStatement建立连接(采用的是工具类JdbcUtils)
static void query(String name) {
Connection conn = null;
PreparedStatement ps = null;
ResultSet rs = null;
try {
// 建立连接
// conn = (Connection) JdbcUtils.getConnection();
conn = (Connection) JdbcUtilsSing.getInstance().getConnection();
// 创建语句
String sql = "select id,Number,name,age from my_Student where name =?";
ps = (PreparedStatement) conn.prepareStatement(sql);
ps.setString(1, name); // 代替第一个?
// 执行语句
rs = ps.executeQuery();
// 处理结果
while (rs.next()) {
System.out.println(rs.getObject("id") + "\t" + rs.getObject("Number") + "\t" + rs.getObject("name")
+ "\t" + rs.getObject("age"));
}
} catch (SQLException e) {
e.printStackTrace();
} finally {
JdbcUtilsSing.getInstance().free(rs, ps, conn); //关闭资源
}
}发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/141904.html原文链接:https://javaforall.cn