MyBatis 学习总结(一)

1.原生JDBC(Java database connectity)操作数据库(以MySQL数据为例)步骤
1.1 加载驱动

Class.forName("com.mysql.jdbc.Driver");

1.2 创建数据库连接

String url = "jdbc:mysql://localhost:3306/test?characterEncoding=utf-8";
String name = "root";
String passwoed = "root123";
Connection conn = DriverManager.getConnection(url,name,password);

1.3 创建预编译陈述对象

String sql = "SELECT * FROM T_USER WHERE NAME = ?";
PreparedStatement ps = conn.prepareStatement(sql);
ps.setString(1,"Jobs");//为预编译sql传参

1.4 获取结果

ResultSet rs = ps.executeQuery();

1.5 处理结果

if(rs != null) {
    while(rs.next()){
        System.out.println(rs.getString("id")+rs.getString("pwd"));
    }
}

1.6 释放资源(这里以rs为例,ps与conn对象均一样)

if (rs != null) {
    try {
        rs.close();
    } catch (SQLException e) {
        e.printStackTrace();
    }
}

2.原生JDBC编码的缺点

1.1 浪费系统资源
数据库的连接,使用时就创建不使用时就释放,一开一闭,对数据库进行频繁的操作,导致资源严重的被浪费。
1.2 可移植性差
sql语句被写到了java的代码中,如果数据库的表改变了,那么就得重新的编写java类。
1.3 传参与结果处理复杂
sql语句设置参数比较麻烦,必须的确定参数的位置,要不然会出错。获取结果时存在大量的手工操作,如果一张表里有10几个字段的话,手工就得写10几条rs.get语句,造成大量的重复工作。

原文地址:https://www.cnblogs.com/liqingdong/p/6077010.html