前言:为什么在学mybatis之前要先了解JDBC呢?因为mybatis是以ORM模型为中心思想的框架,而所有的ORM模型都是基于JDBC进行封装的,不同的ORM模型对JDBC封装的强度是不一样的。


JDBC

  相信有一部分读者是通过JDBC连接数据库的,但是JDBC之定义了接口规范,具体实现是交由给各个数据库厂商实现的,因为每个数据库都有其特殊性,这些是Java规范没有办法确定的,所以JDBC是一种典型的桥接模式(桥接模式,简单地说就是,将抽象部分与它的实现部分分离开来,将继承关系转化成关联关系,降低类与类之间的耦合度,减少系统中的类的代码,使他们都可以独立变化,具体可以看https://www.cnblogs.com/chenssy/p/3317866.html )。

  JDBC基本连接类:


public class JdbcExample{

    private Connection getConnection(){

        Connection connection = null;  //初始化Connection

        try{

            Class.forName("com.mysql.Driver");  //注册驱动

            String url = "jdbc:mysql://localhost:3306/mybatis";

            String user="root";

            String password="";

            connection = DriverManager.getConnection(url,user,password);  //注册数据库信息

        }catch(ClassNotFoundException|SQLException ex){

            Logger.getConnection(JdbcExample.class.getName()).log(Level.SEVERE,null,ex);

            return null;

        }

        return connection;

    }

  JDBC实现类:

public User getUser(int id){

        Connection connection = getConnection();  //获取连接信息

        PreparedStatement ps = null;  //操作数据库

        ResultSet rs = null;  //接收返回的结果

        try{

            ps = connection.prepareStatement("select id, userName from user_info where id =?");  

            ps.setInt(1,id);

            rs = ps.executeQuery();

            while(rs.next()){

                int roleId = rs.getInt("id");

                String userName = rs.getString("userName");

                User user = new User(id,userName);

                return user;

            }

        }catch(SQLException ex){

            Logger.getConnection(JdbcExample.class.getName()).log(Level.SEVERE,null,ex);

        }finally{

            this.close(rs,ps,connection);

        }

        return null;

    }  //关闭数据库的连接
    private void close(ResultSet rs, Statement stmt, Connection connection){

        try{

            if(rs!=null&&!rs.isClosed()){

                rs.close();

            }

        }catch(SQLException ex){

            Logger.getConnection(JdbcExample.class.getName()).log(Level.SEVERE,null,ex);

        }

        try{

            if(stmt!=null&&!stmt.isClosed()){

                stmt.close();

            }

        }catch(SQLException ex){

            Logger.getConnection(JdbcExample.class.getName()).log(Level.SEVERE,null,ex);

        }

        try{

            if(connection!=null&&!connection.isClosed()){

                connection.close();

            }

        }catch(SQLException ex){

            Logger.getConnection(JdbcExample.class.getName()).log(Level.SEVERE,null,ex);

        }

    }
    //测试
    public static void main(String[] args){

        JdbcExample example = new JdbcExample();

        User user = example.getUser(1);

        System.err.println("userName=>+"+user.getName());

    }

}

从代码中我们可以看出,整个过程大致分为几部分:

1、 使用JDBC编程连接数据库,注册驱动和数据库信息。

2、 操作Connection以打开Statement对象。

3、 通过Statementzhixing SQL,将结果返回到ResultSet对象。

4、 使用ResultSet读取数据库信息,然后通过代码转换为具体的POJO对象。

5、 关闭数据库相关资源。

JDBC虽然比ODBC(用C语言实现可关联数据库工具)的平台独立性要好,但是它还是存在一些弊端。其一,工作量相对较大。我们需要先连接,然后处理JDBC底层事务,处理数据类型。我们还需要操作Connection对象、Statement对象和ResultSet对象去拿到数据。其二,我们要对JDBC编程可能产生的异常进行捕捉处理并正确关闭资源。

(一)mybatis之JDBC介绍的更多相关文章

  1. jdbc、Mybatis、Hibernate介绍(非原创)

    文章大纲 一.jdbc介绍二.Mybatis介绍三.Hibernate介绍四.jdbc.Mybatis.Hibernate比较五.参考文章   一.jdbc介绍 1. jdbc编程步骤 (1)加载数据 ...

  2. MyBatis注解Annotation介绍及Demo

     MyBatis注解Annotation介绍及Demo 2014-04-21 17:09:55 标签:Mybatis Annotation 注解 ResultMap SqlBuilder 原创作品,允 ...

  3. JavaWeb_(Mybatis框架)JDBC操作数据库和Mybatis框架操作数据库区别_一

    系列博文: JavaWeb_(Mybatis框架)JDBC操作数据库和Mybatis框架操作数据库区别_一 传送门 JavaWeb_(Mybatis框架)使用Mybatis对表进行增.删.改.查操作_ ...

  4. Mybatis通用Mapper介绍和使用

    Mybatis通用Mapper介绍与使用 前言 使用Mybatis的开发者,大多数都会遇到一个问题,就是要写大量的SQL在xml文件中,除了特殊的业务逻辑SQL之外,还有大量结构类似的增删改查SQL. ...

  5. Mybatis解决jdbc编程的问题

    1.1.1  Mybatis解决jdbc编程的问题 1.  数据库链接创建.释放频繁造成系统资源浪费从而影响系统性能,如果使用数据库链接池可解决此问题. 解决:在SqlMapConfig.xml中配置 ...

  6. Mybatis与JDBC批量插入MySQL数据库性能测试及解决方案

    转自http://www.cnblogs.com/fnz0/p/5713102.html 不知道自己什么时候才有这种钻研精神- -. 1      背景 系统中需要批量生成单据数据到数据库表,所以采用 ...

  7. MyBatis、JDBC相关知识

    引言 在mybatis的基础知识中我们已经可以对mybatis的工作方式窥斑见豹.但是,为什么还要要学习mybatis的工作原理?因为,随着mybatis框架的不断发展,如今已经越来越趋于自动化,从代 ...

  8. 一、mybatis的插件介绍

    摘自:https://www.cnblogs.com/qm-article/p/11785350.html mybatis的插件机制   一.mybatis的插件介绍 关于mybatis的插件,我想大 ...

  9. JDBC(1):JDBC介绍

    一,JDBC介绍 SUN公司为了简化.统一对数据库的操作,定义了一套Java操作数据库的规范(接口),称之为JDBC.这套接口由数据库厂商去实现,这样,开发人员只需要学习jdbc接口,并通过jdbc加 ...

随机推荐

  1. dockerfile:制作tomcat镜像+javaweb

    FROM ubuntu:14.10 MAINTAINER linx #把java与tomcat添加到容器中,Add会解压 ADD jdk-8u151-linux-x64.tar.gz /usr/loc ...

  2. 20个Flutter实例视频教程-第05节: 酷炫的路由动画-1

    视屏地址: https://www.bilibili.com/video/av39709290/?p=5 博客地址: https://jspang.com/post/flutterDemo.html# ...

  3. Flutter实战视频-移动电商-50.持久化_shared_preferences

    50.持久化_shared_preferences 当app关掉了.再进去的时候 ,购物车的内容还是存在. sqflite提供这个来操作SQLite数据库 flutter提供三种持久化的工具 今天要学 ...

  4. Subresource Integrity(子资源一致性)和JS DDos 攻击

    以下文章转载自 http://www.cnblogs.com/zoucaitou/p/4505483.html 和 http://www.puronglong.com/blog//2015/04/12 ...

  5. 验证网站SiteMap的工具

    验证网站SiteMap的在线工具 http://www.xmlvalidation.com/ 在SiteMap文件中,不能直接这样写url  "http://www.obriensplast ...

  6. Dapper的正确使用姿势

    本文demo适用于MySQL Dapper优势和缺点 优点 高性能.易排查.易运维.灵活可控 缺点 和EF相比,手写sql当修改表结构不易发现bug. 习惯了EF后再来使用Dapper,会很难适应那种 ...

  7. 检测到"_ITERATOR_DEBUG_LEVEL"的不匹配项

    error: vtkCommon.lib(vtkSmartPointerBase.obj) : error LNK2038: 检测到“_ITERATOR_DEBUG_LEVEL”的不匹配项:值“0”不 ...

  8. [Xcode 实际操作]八、网络与多线程-(6)使用UIApplication对象打开地图

    目录:[Swift]Xcode实际操作 本文将演示如何使用应用程序单例对象,打开地图的功能. 在项目导航区,打开视图控制器的代码文件[ViewController.swift] import UIKi ...

  9. 计算机网络自顶向下方法第3章-传输层 (Transport Layer).1

    3.1 概述和运输层服务 运输层协议为运行在不同主机上的应用进程之间提供了逻辑通信(logic communication)功能. 3.1.1 运输层和网络层的关系 网络层提供了主机之间的逻辑通信,而 ...

  10. sed 匹配\n换行符

    假设 str="a,b,c,d" echo ${str} | sed "s/,/\n/g" 输出: a b c d echo ${str} | sed &quo ...