zoukankan      html  css  js  c++  java
  • JDBC连接数据库的五个步骤、Mybatis是什么?可以解决jdbc的什么问题。

    JDBC连接数据库大概可以分为五个步骤:
    1)加载驱动

    2)建立连接

    3)创建statement对象(创建执行者)

    4)执行SQL(执行命令),返回结果

    5)关闭数据库

    Statement对象执行不带参数的简单SQL语句

    Prepared Statement对象用于执行预编译SQL语句

    Callable Statement对象用于执行对存储过程的调用

    1)利用类的反射来获取驱动

    加载 mysql驱动,Class.forName("com.mysql.jdbc.Driver");

    2)获得数据库连接对象Connection

    //通过驱动管理类获取数据库连接
    conn = DriverManager.getConnection(DB_URL,USER,PASS);

    3)实例化Statement对象,执行SQL

    Statement stmt = conn.createStatement();
    String sql = "SELECT id, name, url FROM websites";
    ResultSet rs = stmt.executeQuery(sql);
    或者// 定义sql语句 ?表示占位符
    String sql = "select * from user where username = ?";
    // 获取预处理statement
    preparedStatement = connection.prepareStatement(sql);
    // 设置参数,第一个参数为sql语句中参数的序号(从1开始),第二个参数为设置的参数值
    preparedStatement.setString(1, "王五");
    // 向数据库发出sql执行查询,查询出结果集
    resultSet = preparedStatement.executeQuery();

    // 遍历查询结果集
    while (resultSet.next()) {
      System.out.println(resultSet.getString("id") + " " + resultSet.getString("username"));
    }

    4)遍历结果集

     while(rs.next()){
     // 通过字段检索
      int id  = rs.getInt("id");
      String name = rs.getString("name");
      String url = rs.getString("url");
        
     // 输出数据
      System.out.print("ID: " + id);
      System.out.print(", 站点名称: " + name);
      System.out.print(", 站点 URL: " + url);
      System.out.print("
    ");
     }

    5)关闭连接,释放资源

    jdbc更详细一点的步骤:

    1)加载数据库驱动

    2)创建并获取数据库连接

    3)创建jdbc statement对象

    4)设置sql语句

    5)设置sql语句中的参数(使用preparedStatement)

    6)通过statement执行sql并获取结果

    7)对sql执行结果进行解析

    8)释放资源(resultSet、preparedStatement、connection、connection)

    JDBC问题总结:

    1、数据库连接创建、释放频繁造成系统资源浪费,从而影响系统性能。如果使用数据库连接池可以解决此问题。
    2、SQL语句在代码中硬编码,造成代码不易维护,实际应用中sql变化的可能性较大,sql变动需要改变java代码。
    3、使用preparedStatement向占有位符号传参数存在硬编码,因为sql语句的where条件不一定,可能多也可能少,修改sql还要修改代码,系统不易维护。
    4、对结果集的解析也存在硬编码,sql变化导致解析代码变化,系统不易维护如果能将数据库记录封装成pojo对象解析比较方便。

    Mybatis可以解决jdbc编程的一些问题:

    问题:1、数据库连接创建、释放频繁造成系统资源浪费,从而影响系统性能。如果使用数据库连接池可以解决此问题。
    解决:在配置文件中配置数据库连接池,使用连接处管理数据库连接。
    问题:2、SQL语句在代码中硬编码,造成代码不易维护,实际应用中sql变化的可能性较大,sql变动需要改变java代码。
    解决:将Sql语句配置在XXXXmapper.xml文件中与java代码分离。
    问题:3、向sql语句传参麻烦,sql语句where条件不一定,占位符需要和参数一 一对应
    解决:Mybatis可以自动将java对象映射至sql语句,通过statement中的parameterType定义传入参数的类型。
    问题:4、对结果集解析麻烦,sql变化导致解析代码变化,且解析前需要需要遍历,如果能将数据库记录封装陈pojo对象解析比较方便。
    解决:Mybatis可以自动将sql执行结果映射至java对象,通过statement中的resultType定义输出结果的类型。

    MyBatis是什么

    Mybatis是一个优秀的持久层框架,它对jdbc的操作数据库的过程进行封装,是开发者只需要关注SQL本身,而不需要花费精力去处理例如注册驱动、创建connection、创建statement、手动设置参数、结果集检索等jdbc繁杂的过程代码。
    Mybatis通过xml或注解的方式将要执行的各种statement(statement、preparedStatement、CallableStatement)配置起来,并通过java对象和statement中的sql进行映射成最终执行的sql语句,最后由Mybatis框架执行sql并将结果映射成java对象并返回。

    参考:https://blog.csdn.net/qq_44543508/article/details/97007064

  • 相关阅读:
    windown reids
    redis 类型、方法
    nginx 路由配置
    http status code
    beego orm mysql
    thinkphp5
    beego
    MAC 更新brew 镜像源
    php session存入redis
    ios项目开发— iOS8 定位功能API改变
  • 原文地址:https://www.cnblogs.com/lhh666/p/11545525.html
Copyright © 2011-2022 走看看