发表于: 2020-06-02 22:47:37
5 1426
今日作为:学习Mybatis来做任务1-17
通过百度查到的资料有好多种方法,全部尝试了,就没一个通过的。。。。
问题1:下面是我觉得最接近成功的配置文件,麻烦师兄帮忙看一下到底是哪里出问题了
目录结构:
dao里面没写任何方法,暂时当个标识接口用(白天时候写了,跑不过晚上又删了)
Student是实体类
db.properties:(数据库配置)
jdbc.user = root
jdbc.password = 54229103w
jdbc.driverClass = com.mysql.cj.jdbc.Driver
jdbc.jdbcUrl = jdbc:mysql://localhost:3306/it-xzy?serverTimezone=UTC&useUnicode=true&characterEncoding=utf8&useSSL=true
jdbc.initPoolSize = 5
jdbc.maxPoolSize = 10
applicationConntext.xml:(把Mybatis丢到spring JDBC Template连接池?)
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.3.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.3.xsd">
<!-- 导入资源文件
读取db.properties文件中的数据 -->
<context:property-placeholder location="classpath:db.properties"/>
<!-- 配置C3P0数据源 -->
<bean id="dataSource"
class="com.mchange.v2.c3p0.ComboPooledDataSource">
<property name="user" value="${jdbc.user}"></property>
<property name="password" value="${jdbc.password}"></property>
<property name="jdbcUrl" value="${jdbc.jdbcUrl}"></property>
<property name="driverClass" value="${jdbc.driverClass}"></property>
<property name="initialPoolSize" value="${jdbc.initPoolSize}"></property>
<property name="maxPoolSize" value="${jdbc.maxPoolSize}"></property>
</bean>
<!-- 3.配置SqlSessionFactory对象 -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<!-- 注入数据库连接池 -->
<property name="dataSource" ref="dataSource" />
<!-- 配置MyBaties全局配置文件:mybatis-config.xml -->
<property name="configLocation" value="classpath:mybatis-config.xml" />
<!-- 扫描entity包 使用别名 -->
<property name="typeAliasesPackage" value="com.jnshu.entity" />
<!-- 扫描sql配置文件:mapper需要的xml文件 -->
<property name="mapperLocations" value="classpath:studentDao_Mapper.xml" />
</bean>
<!-- 4.配置扫描Dao接口包,动态实现Dao接口,注入到spring容器中 -->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<!-- 注入sqlSessionFactory -->
<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory" />
<!-- 给出需要扫描Dao接口包 -->
<property name="basePackage" value="com.soecode.lyf.dao" />
</bean>
</beans>
mybatis-config.xml:(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>
<!-- 配置全局属性 -->
<settings>
<!-- 使用jdbc的getGeneratedKeys获取数据库自增主键值 -->
<setting name="useGeneratedKeys" value="true" />
<!-- 使用列别名替换列名 默认:true -->
<setting name="useColumnLabel" value="true" />
<!-- 开启驼峰命名转换:Table{create_time} -> Entity{createTime} -->
<setting name="mapUnderscoreToCamelCase" value="true" />
</settings>
</configuration>
spring-config.xml:(说实话不懂这个是干什么的,但是看教程通过
@ContextConfiguration({ "classpath:applicationConntext.xml", "classpath:spring-config.xml" })这种方式能够不用产生实现类通过加载写在XML配置文件的SQL语句直接操作数据库)
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:tx="http://www.springframework.org/schema/tx"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx.xsd">
<!-- 扫描service包下所有使用注解的类型 -->
<context:component-scan base-package="com.jnshu.service" />
<!-- 配置事务管理器 -->
<bean id="transactionManager"
class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<!-- 注入数据库连接池 -->
<property name="dataSource" ref="dataSource" />
</bean>
<!-- 配置基于注解的声明式事务 -->
<tx:annotation-driven transaction-manager="transactionManager" />
</beans>
studentDao_Mapper.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="com.jnshu.dao.StudentDao">
<!-- 目的:为dao接口方法提供sql语句配置 -->
<select id="" resultType="" parameterType="">
<!-- 具体的sql -->
SELECT
*
FROM
student
</select>
</mapper>
namespace是该xml对应的接口全名
select和update中的id对应方法名
resultType是返回值类型
parameterType是参数类型(可选)
#{...}中填写的是方法的参数
(写日报的时候我把里面的具体参数删了。。。。)
然后今天还尝试了其他很多方法比这个复杂很多,但就是没有一个成功
问题2:有的资料说DAO思想是分四种类
1.DAO接口
里面只有一个接口,和一个定义实现类需要的方法
2.实现类
对数据库的具体操作
3.实体类
对应表的字段和在程序中传递存储数据(这是数据的持久化么?)
4.连接关闭数据库
还有的资料说的是
或者是
1.dao 数据访问层(接口)
与数据打交道,可以是数据库操作,也可以是文件读写操作,甚至是redis缓存操作,总之与数据操作有关的都放在这里,也有人叫做dal或者数据持久层都差不多意思。为什么没有daoImpl,因为我们用的是mybatis,所以可以直接在配置文件中实现接口的每个方法
2.entity 实体类
一般与数据库的表相对应,封装dao层取出来的数据为一个对象,也就是我们常说的pojo,一般只在dao层与service层之间传输
3.dto 数据传输层
刚学框架的人可能不明白这个有什么用,其实就是用于service层与web层之间传输,为什么不直接用entity(pojo)?其实在实际开发中发现,很多时间一个entity并不能满足我们的业务需求,可能呈现给用户的信息十分之多,这时候就有了dto,也相当于vo
4.service 业务逻辑(接口)
写我们的业务逻辑,也有人叫bll,在设计业务接口时候应该站在“使用者”的角度。额,不要问我为什么这里没显示!IDE调皮我也拿它没办法~
5.serviceImpl 业务逻辑(实现)
实现我们业务接口,一般事务控制是写在这里
6.web 控制器
springmvc就是在这里发挥作用的,一般人叫做controller控制器,相当于struts中的action
这三种都是对的么?还是有一种是对的,麻烦师兄解答一下,谢啦
问题3:根据下面这张Mybatis的结构图,根据任务1-17的要求,和我前几天写用两种连接数据库的方式,一种JDBC,一种SpringJDBC Template
的经验
我感觉上Mybatis是通过建立到SpringJDBC Template的连接池,然后再往连接池注入Mybatis自己封装的SQL语句来执行的么?
如果说Spring JDBC Template是对JDBC的封装抽象,Mybatis又是再抽象一次?
所以也能解答任务1-17的问题,为什么用Mybatis不需要实现类,因为通过Mybatis的配置文件,Mybatis他自己会通过你所对应的实体类中的字 段去查找并且执行SQL语句,因而就不需要实体类了?
明天的计划:继续抓脑阔完成1-17Mybatis并且不使用实现类完成对数据库的操作
评论