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("\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

 

posted @ 2019-09-18 21:38  弘666  阅读(4006)  评论(0编辑  收藏  举报