【MyBatis】1:JDBC编程存在的问题

        做Java开发,如何操作数据库?想必大家都知道,使用JDBC(Java Data Base Connectivity),这是一种用于执行SQL语句的Java API,可以为多种关系型数据库提供统一访问,它是由一组用Java编写的类和接口组成。JDBC提供了一种基准,在此基础上我们可以构建更高级的工具和接口,使数据库开发人员能够更加方便和轻松的编写数据库应用程序。

        JDBC编程8步走:

        1加载数据库驱动

        2创建并获取数据库连接

        3创建jdbc statement对象

        4设置sql语句

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

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

        7对sql执行结果进行解析处理

        8释放所有的资源(resultSet、preparedStatement、connection)

        捋清楚了编码思路,来,上机敲代码……

public class JdbcTest {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		//数据库连接
		Connection connection = null;
		//预编译的Statement,使用预编译的Statement提高数据库性能
		PreparedStatement preparedStatement = null;
		//结果集
		ResultSet resultSet = null;
		
		try {
			//加载数据库驱动
			Class.forName("com.mysql.jdbc.Driver");
			
			//通过驱动管理类获取数据库链接
			connection =  DriverManager.getConnection("jdbc:mysql://localhost:3306/shop?characterEncoding=utf-8", "root", "");
			//定义sql语句 ?表示占位符
			String sql = "select * from user where username = ?";
			//获取预处理statement
			preparedStatement = connection.prepareStatement(sql);
			//设置参数,第一个参数为sql语句中参数的序号(从1开始),第二个参数为设置的参数值
			preparedStatement.setString(1, "ljw");
			//向数据库发出sql执行查询,查询出结果集
			resultSet =  preparedStatement.executeQuery();
			//遍历查询结果集
			while(resultSet.next()){
				System.out.println(resultSet.getString("uid")+"  "+resultSet.getString("username"));
			}
		} catch (Exception e) {
			e.printStackTrace();
		}finally{
			//释放所有的资源
			if(resultSet!=null){
				try {
					resultSet.close();
				} catch (SQLException e) {
					e.printStackTrace();
				}
			}
			if(preparedStatement!=null){
				try {
					preparedStatement.close();
				} catch (SQLException e) {
					e.printStackTrace();
				}
			}
			if(connection!=null){
				try {
					connection.close();
				} catch (SQLException e) {
					e.printStackTrace();
				}
			}

		}

	}

}

        编写完代码之后,我们回过头去分析使用JDBC编程存在一些什么问题。

        1如果使用JDBC做开发,那么数据库连接将会大量的被创建,并且每一次的创建最终都要释放资源,如此频繁的操作将严重影响系统的性能,同时也会造成系统资源的浪费,一个很好的解决办法是使用数据库连接池。

        2使用JDBC进行开发,sql语句是写死在代码里面的,也就是所谓的硬编码,这样会造成代码极难维护,因为实际的需求会有变动,一旦需求有变,我们就要修改java源代码,并进行再次的编译和部署,简直是麻烦。

        3使用PreparedStatement对象向sql语句的占位符中传递参数的时候,也存在硬编码的情况,实际应用中sql语句的where条件是不固定的,可能多也可能少,每一次的变动都要修改java代码,系统维护困难。

        4在最后对结果集进行解析和输出的时候,也存在硬编码的情况(即查询列名),这样一来,sql语句如果变化,那么对应的解析代码也将随之变化,系统不易维护,比较好的解决办法是将数据库记录封装成pojo对象再进行解析。

        综上来看,使用JDBC编程存在不少的问题,当然上面列举的也只是一部分而已,还有开发效率问题,代码复用率问题等等。了解了这些问题,我们才能更好的理解,接下来我们要学习的MyBatis是如何解决这些问题的。
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值