发表于: 2019-12-14 19:20:02
1 1056
今天完成的事情:
使用mybatis连接数据库并获取数据库中的一条数据
1.mybatis的配置文件
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<environments default="development">
<environment id="development">
<transactionManager type="JDBC"/>
<!-- 配置数据库连接信息 -->
<dataSource type="POOLED">
<property name="driver" value="com.mysql.cj.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/test?characterEncoding=UTF-8"/>
<property name="username" value="root"/>
<property name="password" value="19980710"/>
</dataSource>
</environment>
</environments>
<mappers>
<!-- 注册userMapper.xml文件,
userMapper.xml位于com.mybatis.mapping这个包下,所以resource写成com/mybatis/mapping/userMapper.xml-->
<mapper resource="com/mybatis/mapping/userMapper.xml"/>
</mappers>
</configuration>
2.get,set方法
3.userMapper.xml
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!-- 为这个mapper指定一个唯一的namespace,namespace的值习惯上设置成包名+sql映射文件名,这样就能够保证namespace的值是唯一的
例如namespace="com.mybatis.mapping.userMapper"就是com.mybatis.mapping(包名)+userMapper(userMapper.xml文件去除后缀)
-->
<mapper namespace="com.mybatis.mapping.userMapper">
<!-- 在select标签中编写查询的SQL语句, 设置select标签的id属性为getUser,id属性值必须是唯一的,不能够重复
使用parameterType属性指明查询时使用的参数类型,resultType属性指明查询返回的结果集类型
resultType="com.mybatis.domain.User"就表示将查询结果封装成一个User类的对象返回
User类就是users表所对应的实体类
-->
<!--
根据id查询得到一个user对象
-->
<select id="getUser" parameterType="int" resultType="com.mybatis.domain.User">
select *
from user
where id = #{id}
</select>
<insert id="addUser" parameterType="User"
useGeneratedKeys="true" keyProperty="id">
insert into user(name, pwd)
values (#{name}, #{pwd})
</insert>
<update id="updateUser" parameterType="User">
update user
set name=#{name},
pwd=#{pwd}
where id = #{id}
</update>
<delete id="deleteUser" parameterType="int">
delete
from user
where id = #{id}
</delete>
</mapper>
4.测试
package com.mybatis.test;
import com.mybatis.domain.User;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import java.io.InputStream;
public class testMybatis {
public static void main(String[] args) {
//mybatis的配置文件
String resource = "conf.xml";
//使用类加载器加载mybatis的配置文件(它也加载关联的映射文件)
InputStream is = testMybatis.class.getClassLoader().getResourceAsStream(resource);
//构建sqlSession的工厂
SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(is);
//创建能执行映射文件中sql的sqlSession
SqlSession session = sessionFactory.openSession();
//映射sql的标识字符串
String statement = "com.mybatis.mapping.userMapper.getUser";
//执行查询返回一个唯一user对象的sql
User user = session.selectOne(statement, 1);
System.out.println(user);
}
}
明天计划的事情:
看一看关于mybatis的基础视频,了解一下它的工作流程,了解一下什么是sqlsession工厂等相关知识。
遇到的问题:
1.在执行时代码报错信息是找不到这个目录
com/mybatis/mapping/userMapper.xml
师兄帮我找到了处理办法,我自己对报错原因的理解还是不到位,以至于不知道怎么上网去找这个问题的解决办法
在pom.xml中添加如下代码
<resources>
<resource>
<directory>src/main/java</directory>
<includes>
<include>**/*.xml</include>
</includes>
</resource>
</resources>
2.今天找的这个例子不太好,做完之后发现不知道从哪添加测试增删改的代码,这个例子直接在main方法里运行的。师兄说少了接口和实现类,明天找个好点的例子在做一遍。
收获:
了解了一点mybatis
让我认识到了自己对每个模块作用的了解还是有所不足,专业术语也是听不太懂,还是需要抽时间复习基础。
评论