Mybatis快速入门
大家好,我是【1+1=王】, 热爱java的计算机(人工智能)渣硕研究生在读。
如果你也对java、人工智能等技术感兴趣,欢迎关注,抱团交流进大厂!!!
Good better best, never let it rest, until good is better, and better best.近期会重新温习一下SSM的相关知识,相应的博客会更新至专栏【SSM框架】中,欢迎大家关注!
SSM专栏:https://blog.csdn.net/weixin_43598687/category_11652306.html
准备工作
1. 创建user表
2. 创建User实体类
publicclassUser{privateInteger id;privateString username;privateString password;publicUser(){}publicUser(String username,String password){this.username = username;this.password = password;}publicUser(Integer id,String username,String password){this.id = id;this.username = username;this.password = password;}publicIntegergetId(){return id;}publicvoidsetId(Integer id){this.id = id;}publicStringgetUsername(){return username;}publicvoidsetUsername(String username){this.username = username;}publicStringgetPassword(){return password;}publicvoidsetPassword(String password){this.password = password;}@OverridepublicStringtoString(){return"User{"+"id="+ id +", username='"+ username +'\''+", password='"+ password +'\''+'}';}}
3. 引入mysql驱动
<dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>5.1.6</version></dependency>
原始JDBC操作
查询
publicstaticList<User>findAll()throwsException{Class.forName("com.mysql.jdbc.Driver");Connection conn =DriverManager.getConnection("jdbc:mysql:///test","root","123456");String sql ="select * from user";PreparedStatement pstmt = conn.prepareStatement(sql);ResultSet rs = pstmt.executeQuery();List<User> userList =newArrayList<User>();while(rs.next()){User user =newUser();
user.setId(rs.getInt("id"));
user.setUsername(rs.getString("username"));
user.setPassword(rs.getString("password"));
userList.add(user);}
rs.close();
pstmt.close();
conn.close();return userList;}
插入
publicstaticvoidinsertUser(User user)throwsException{Class.forName("com.mysql.jdbc.Driver");Connection conn =DriverManager.getConnection("jdbc:mysql:///test","root","123456");String sql ="insert into user(id,username,password) values(?,?,?)";PreparedStatement pstmt = conn.prepareStatement(sql);
pstmt.setInt(1,user.getId());
pstmt.setString(2,user.getUsername());
pstmt.setString(3,user.getPassword());int i = pstmt.executeUpdate();System.out.println(i);
pstmt.close();
conn.close();}
mybatis简介与开发步骤
- mybatis是一个优秀的基于java的持久层框架,它内部封装了jdbc,使开发者只需要关注sql语句本身,而不需要花费精力去处理加载驱动、创建连接、创建statement等繁杂的过程。
- mybatis通过xml或注解的方式将要执行的各种statement配置起来,并通过java对象和statement中sql的动态参数进行映射生成最终执行的sql语句。
- 最后mybatis框架执行sql并将结果映射为java对象并返回。采用ORM思想解决了实体和数据库映射的问题,对jdbc进行了封装,屏蔽了jdbcapi底层访问细节,使我们不用与jdbcapi打交道,就可以完成对数据库的持久化操作。
MyBatis官网地址:http://www.mybatis.org/mybatis-3/
1. 引入mybatis依赖包
<dependency><groupId>org.mybatis</groupId><artifactId>mybatis</artifactId><version>3.4.5</version></dependency>
2. 创建表和对应实体类
同上。
3. 编写映射文件UserMapper.xml
在resources目录下创建文件com/wang/mapper/UserMapper.xml。路径与实体类的包路径对应
<?xml version="1.0" encoding="UTF-8" ?><!DOCTYPEmapperPUBLIC"-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd"><mappernamespace="userMapper"><selectid="findAll"resultType="com.wang.pojo.User">
select * from user
</select></mapper>
4. 配置mybatis核心配置文件
在resources目录下创建文件sqlMapConfig.xml. 并添加相应配置
<configuration><environmentsdefault="development"><environmentid="development"><transactionManagertype="JDBC"/><dataSourcetype="POOLED"><propertyname="driver"value="com.mysql.jdbc.Driver"/><propertyname="url"value="jdbc:mysql:///test"/><propertyname="username"value="root"/><propertyname="password"value="123456"/></dataSource></environment></environments><mappers><!-- 映射文件所在位置--><mapperresource="com/wang/mapper/UserMapper.xml"/></mappers></configuration>
测试
publicstaticvoidmain(String[] args)throwsIOException{//加载核心配置文件InputStream inputStream =Resources.getResourceAsStream("sqlMapConfig.xml");//获得sqlSession工厂对象SqlSessionFactory sqlSessionFactory =newSqlSessionFactoryBuilder().build(inputStream);//获得sqlSession对象SqlSession session = sqlSessionFactory.openSession();//执行sql语句List<User> userList = session.selectList("userMapper.findAll");Iterator<User> iterator = userList.iterator();while(iterator.hasNext()){System.out.println(iterator.next());}
session.close();}
mybatis的增删改查
插入操作
- 映射文件加入
<insertid="add"parameterType="com.wang.pojo.User">
insert into user(id,username,password) values(#{id},#{username},#{password})
</insert>
- 测试
@Testpublicvoidadd()throwsException{//加载核心配置文件InputStream inputStream =Resources.getResourceAsStream("sqlMapConfig.xml");//获得sqlSession工厂对象SqlSessionFactory sqlSessionFactory =newSqlSessionFactoryBuilder().build(inputStream);//获得sqlSession对象SqlSession session = sqlSessionFactory.openSession();//执行sql语句int insert = session.insert("userMapper.add",newUser("Curry","30303030"));System.out.println(insert);
session.commit();
session.close();}
3. 注意
- 插入语句使用insert标签
- 在映射文件中使用parameterType属性指定要插入的数据类型
- Sql语句中使用#{实体属性名}方式引用实体中的属性值
- 插入操作使用的API是sqlSession.insert(“命名空间.id”,实体对象);
- 插入操作涉及数据库数据变化,所以要使用sqlSession对象显示的提交事务,即sqlSession.commit()
删除操作
- 映射文件加入
<deleteid="delete"parameterType="java.lang.Integer">
delete from user where id=#{id}
</delete>
- 测试
@Testpublicvoiddelete()throwsException{//加载核心配置文件InputStream inputStream =Resources.getResourceAsStream("sqlMapConfig.xml");//获得sqlSession工厂对象SqlSessionFactory sqlSessionFactory =newSqlSessionFactoryBuilder().build(inputStream);//获得sqlSession对象SqlSession session = sqlSessionFactory.openSession();//执行sql语句int delete = session.delete("userMapper.delete",1);//删除id=1的userSystem.out.println(delete);
session.commit();
session.close();}
3. 注意
- 删除语句使用delete标签
- Sql语句中使用#{任意字符串}方式引用传递的单个参数
- 删除操作使用的API是sqlSession.delete(“命名空间.id”,Object);
修改操作
- 映射文件加入
<updateid="update"parameterType="com.wang.pojo.User">
update user set username=#{username},password=#{password} where id=#{id}
</update>
- 测试
@Testpublicvoidupdate()throwsException{//加载核心配置文件InputStream inputStream =Resources.getResourceAsStream("sqlMapConfig.xml");//获得sqlSession工厂对象SqlSessionFactory sqlSessionFactory =newSqlSessionFactoryBuilder().build(inputStream);//获得sqlSession对象SqlSession session = sqlSessionFactory.openSession();//执行sql语句int update = session.update("userMapper.update",newUser(2,"科比","24-8"));//删除id=2的userSystem.out.println(update);
session.commit();
session.close();}
3. 注意
- 修改语句使用update标签
- 修改操作使用的API是sqlSession.update(“命名空间.id”,实体对象);
查询操作
见上述开发步骤,这里不再重复。
核心配置文件常用标签
1. environments标签
事务管理类型有两种:
- JDBC:使用了JDBC 的提交和回滚设置,它依赖于从数据源得到的连接来管理事务作用域。
- MANAGED:这个配置几乎没做什么。它从来不提交或回滚一个连接,而是让容器来管理事务的整个生命周期(比如JEE 应用服务器的上下文)。默认情况下它会关闭连接,然而一些容器并不希望这样,因此需要将closeConnection属性设置为false 来阻止它默认的关闭行为。
数据源类型有三种:
- UNPOOLED:这个数据源的实现只是每次被请求时打开和关闭连接。
- POOLED:这种数据源的实现利用“池”的概念将JDBC 连接对象组织起来。
- JNDI:这个数据源的实现是为了能在如EJB 或应用服务器这类容器中使用,容器可以集中或在外部配置数据源,然后放置一个JNDI 上下文的引用。
2. mapper标签
mapper标签用于加载映射文件。
加载方式有如下几种:
- 使用相对于类路径的资源引用,例如:
<mapper resource="com/wang/mapper/UserMapper.xml"/>
- 使用完全限定资源定位符(URL),例如:
<mapper url="file:///mapper/UserMapper.xml"/>
- 使用映射器接口实现类的完全限定类名,例如:
<mapper class="com.wang.mapper.UserMapper"/>
- 将包内的映射器接口实现全部注册为映射器,例如:
<package name="com.wang.mapper"/>
3. properties标签
properties标签加载额外配置的properties文件,例如将数据源的配置信息单独抽取成一个properties文件。
4. typeAliases标签
在映射文件中为SQL参数类型或者返回类型的时候,需要配置全包名,这就比较烦人。
这是就可以使用typeAliases标签,为Java 类型设置一个短的名字。
<typeAliases><typeAliastype="com.wang.pojo.User"alias="user"/></typeAliases>
mybatis框架已经为我们设置好的一些常用的类型的别名
SSM专栏:https://blog.csdn.net/weixin_43598687/category_11652306.html
版权归原作者 1 + 1=王 所有, 如有侵权,请联系我们删除。