发表于: 2020-06-02 22:47:37

5 1425


今日作为:学习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>
       <!-- 使用jdbcgetGeneratedKeys获取数据库自增主键值 -->
       <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并且不使用实现类完成对数据库的操作

            

           










返回列表 返回列表
评论

    分享到