框架---mybatis(一)

本文介绍了MyBatis框架,一种半自动化的ORM框架,对比Hibernate并详细解释了使用MyBatis的原因,包括解决传统JDBC编程中的硬编码问题,提供数据库连接池管理和参数映射等功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

mybatis框架介绍:

       mybatis和hibernate是平等的两个框架,都是封装好了的jdbc的持久层框架,都属于ORM(对象关系映射)框架,但是hibernate是一个完全的ORM框架,mybatis是一个不完全的ORM框架,mybatis框架原来是apache的产品,后来被github接收,现在存放在github上,下载的话可以去github上下载,地址:github.com/mybatis

         使用了mybatis可以让程序员只关注sql本身,不用去关注连接的创建,statement的创建等,mybatis会将输入参数,输出结果进行映射

为什么要用mybatis框架:

        因为mybatis框架是封装的jdbc,所以这里就要说一下传统的jdbc的缺点,先附上原生jdbc的代码:

 

 

public static void main(String[] args) {

Connection connection = null;

PreparedStatement preparedStatement = null;public static void main(String[] args) {

Connection connection = null;

PreparedStatement preparedStatement = null;

 

ResultSet resultSet = null;

try {

//1加载数据库驱动

Class.forName("com.mysql.jdbc.Driver");

//2通过驱动管理类获取数据库链接

connection =  DriverManager.getConnection("jdbc:mysql://localhost:3306/mybatis?characterEncoding=utf-8", "root", "root");

//3定义sql语句 ?表示占位符

String sql = "select * from user where username = ?";

/4获取预处理statement

preparedStatement = connection.prepareStatement(sql);

//5设置参数,第一个参数为sql语句中参数的序号(从1开始),第二个参数为设置的参数值

preparedStatement.setString(1, "王");

//6向数据库发出sql执行查询,查询出结果集

resultSet =  preparedStatement.executeQuery();

//7遍历查询结果集

while(resultSet.next()){

User user

System.out.println(resultSet.getString("id")+"  "+resultSet.getString("username"));

}

} catch (Exception e) {

e.printStackTrace();

}finally{

//8释放资源

if(resultSet!=null){

try {

resultSet.close();

} catch (SQLException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

}

if(preparedStatement!=null){

try {

preparedStatement.close();

} catch (SQLException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

}

if(connection!=null){

try {

connection.close();

} catch (SQLException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

}

}

}

jdbc的问题:

1.创建连接时,存在硬编码------配置文件(全局配置文件)

2.在执行statement时存在硬编码------配置文件(映射文件)

3.频繁的开启和关闭数据库连接,会造成数据库性能下降-------数据库连接池(全局配置文件)

mybatis框架原理:

           

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值