Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 5018|回复: 0

JDBC连接数据库的五个步骤、Mybatis是什么?可以解决jdbc的什么问题。

[复制链接]
  • TA的每日心情
    奋斗
    2024-11-24 15:47
  • 签到天数: 804 天

    [LV.10]以坛为家III

    2053

    主题

    2111

    帖子

    72万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    726782
    发表于 2021-4-13 15:05:39 | 显示全部楼层 |阅读模式

    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("\n");
     }

    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

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-2-5 20:55 , Processed in 0.062365 second(s), 29 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表