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等 |