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等