浅谈JDBC与MyBatis

浅谈JDBC与MyBatis

MyBatis是一个基于Java的、封装了JDBC的持久层框架。

1 JDBC

JDBC(Java Data Base Connectivity)表示Java数据库连接。在Java语言中,我们使用JDBC来操作关系型数据库。

1.1 案例代码

package core;

import java.sql.*;

/**
 * JDBC案例类.
 *
 * @author 李程鹏
 */
public class JDBC {
    public static void main(String[] args) {
        // 定义连接对象
        Connection connection = null;
        // 定义预编译语句对象
        PreparedStatement preparedStatement = null;
        // 定义结果集对象
        ResultSet resultSet = null;
        try {
            // 加载数据库驱动
            Class.forName("com.mysql.jdbc.Driver");
            // 通过数据库驱动获取数据库连接
            connection = DriverManager.
                    getConnection("jdbc:mysql://localhost:3306/jdbc?characterEncoding=utf-8", "root", "root");
            // 定义并初始化SQL语句
            String sql = "select * from user where id = ?";
            // 创建预编译语句对象
            preparedStatement = connection.prepareStatement(sql);
            // 设置查询参数
            preparedStatement.setString(1, "1");
            // 向数据库发出SQL并执行查询,获取查询结果集.
            resultSet = preparedStatement.executeQuery();
            // 遍历查询结果集
            while (resultSet.next()) {
                // 输出查询结果
                System.out.println("id = " + resultSet.getString("id"));
                System.out.println("name = " + resultSet.getString("name"));
            }
        } catch (Exception e) {
            e.printStackTrace();
        } finally { // 释放资源
            if (resultSet != null) {
                try {
                    // 关闭结果集对象
                    resultSet.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }

            if (preparedStatement != null) {
                try {
                    // 关闭预编译语句对象
                    preparedStatement.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }

            if (connection != null) {
                try {
                    // 关闭连接对象
                    connection.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }
        }
    }
}

1.2 问题分析

上面的JDBC代码存在以下几个问题:

  • 频繁地开启和关闭数据库连接,严重地影响了数据库的性能。
  • 代码中存在硬编码。每当需求变更时,都需要修改源代码然后重新编译,系统不易维护。硬编码的具体体现:
    • SQL语句中的查询条件(String sql = "select * from user where id = ?";)。如果需求变更,改为根据用户主键和用户名进行查询,那么就需要修改源代码。
    • 设置查询参数时的参数位置和参数值(preparedStatement.setString(1, "1");)。如果SQL语句由于需求变更而发生变化,那么原来编写的赋值语句就可能出错,需要修改源代码。
    • 获取查询结果时指定的列名(resultSet.getString("name");)。如果数据表的字段名发生了变化,那么就需要修改源代码。
  • 设置查询参数的过程繁琐。因为在设置查询参数的过程中,需要为查询语句中不同位置上的占位符设置不同的值。
  • 获取查询结果的过程繁琐。因为在获取查询结果的过程中,需要遍历查询结果集,而且在遍历的过程中还需要根据数据表的列名才可以获取出其值。

2 MyBatis

MyBatis是一个优秀的持久层框架,它对JDBC操作数据库的过程进行了封装,使开发者只需要关注SQL本身,而不需要花费精力去处理例如注册驱动、创建连接、创建执行语句、手动设置参数和结果集检索等繁杂的过程。

MyBatis通过封装JDBC解决了它在编程中出现的问题,解决的技术方案主要有以下五种:

  • 数据库连接池。我们可以在MyBatis的全局配置文件SqlMapConfig.xml中配置数据库连接池,使用它来管理数据库连接,这样就可以避免由于频繁地创建和释放数据库连接而造成的资源浪费。
  • SQL配置文件。MyBatis将SQL语句与Java源文件进行分离,将SQL语句放置到配置文件Mapper.xml中。如果有需求变更需要修改SQL语句,那么只需要修改配置文件即可。修改配置文件的维护成本比修改Java源文件的成本要低,因为修改配置文件后重启系统就可以生效,但是如果修改的是Java源文件,那么就需要经过修改、编译、打包、发布和重启五个步骤。
  • 动态SQL语句。MyBatis使用动态SQL技术解决了JDBC编程中存在的SQL硬编码的问题。
  • 输入映射。MyBatis通过输入映射技术将Java对象映射至SQL语句,SQL语句可以通过使用该Java对象取出查询参数值,简化了JDBC中设置查询参数的过程。
  • 输出映射。MyBatis通过输出映射技术将SQL的执行结果映射至Java对象,省去了JDBC编程中对结果集检索的过程。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,816评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,729评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,300评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,780评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,890评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,084评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,151评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,912评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,355评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,666评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,809评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,504评论 4 334
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,150评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,882评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,121评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,628评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,724评论 2 351

推荐阅读更多精彩内容