前言
相信很多初学者学习用java操作数据库的时候,都会感觉到十分的麻烦,很多代码都需要反复写,将会浪费掉我们大量的时间,今天,我们就一起写工具包来缩短时间并减少工作量。
数据库的连接
在做工具包之前,我先简单为大家介绍下数据库的连接。我们通常使用 jdbc 对数据库进行连接,这里就需要用到一个jar包——“mysql-connector-java-5.1.46.jar”,我用的是5.1.46版本的,大家可以在网上自行下载,导好包以后。就可以用java代码来操作了。
//1.加载驱动(驱动数据库:有三种方式,常用反射加载)
Class.forName("com.mysql.jdbc.Driver");
//2.获取连接对象(建立从java到数据库的连接通道)
Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/mydb", "root", "123456");
//3.获取处理命令的对象(通过连接对象向数据库发送并执行sql语句)
Statement stat = conn.createStatement();
//4.执行sql操作
boolean f = stat.execute("insert into dept values(7,'事业部','10986')"); // false
//5.处理结果
if(f){
System.out.println("执行查询操作");
}else{
System.out.println("执行非查询操作");
}
//6.资源关闭
stat.close();
conn.close();
通常 java 连接数据库为以上基本的六步,随着版本的更新,现在第一步已经可以不用写,第三步容易在数据的注入出现bug,之后我们会用 PreparedStatement 代替 Statement。这里只是先立一个魔板,之后我再具体讲解。
用回调(CallBack)写工具包
在写工具包的时候,我们有两种方法,一个是用回调(CallBack)一个是用反射(reflect),回调的工具包肯定会比反射写的更少,不过每次调用工具包需要重写回调的方法,还是比较麻烦,所以我就只讲解用反射写的方法吧。不过我还是把用回调写的工具包列在下面,大家根据个人兴趣看是否了解一下。
public class DBUtils {
public static String driverClass;
public static String url;
public static String user;
public static String password;
static {
try {
driverClass = "com.mysql.jdbc:Driver";
url = "jdbc:mysql://127.0.0.1:3306/mydb";
user = "root";
password = "123456";
// 加载驱动
Class.forName(driverClass);
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
}
/**
* 获取连接
*
* @return
*/
public static Connection getConn() {
try {
return DriverManager.getConnection(url, user, password);
} catch (SQLException e) {
e.printStackTrace(