zoukankan      html  css  js  c++  java
  • 怎么使用hsqldb 和 mybatis 构造单元测试

    项目是使用spring + mybatis的项目 

    下面说下配置怎么写:

    spring中这样写:

    <jdbc:embedded-database id="dataSource">  
            <jdbc:script location="classpath:/test/vmdb.script"/>  
        </jdbc:embedded-database>   -- 关键是这句
    
     <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
            <!-- 实例化sqlSessionFactory时需要使用上述配置好的数据源以及SQL映射文件 -->
            <property name="dataSource" ref="dataSource" />
            
            <property name="mapperLocations" value="classpath:com/suning/rdrs/admin/mapping/*.xml" />
        </bean>
        <!-- 配置扫描器 -->
        <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
            <!-- 扫描com.suning.rdrs.admin.dao这个包以及它的子包下的所有映射接口类 -->
            <property name="basePackage" value="com.suning.rdrs.admin.dao" />
            <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory" />
        </bean>

    单元测试的构造内存数据库的写法

    private Connection conn;
        @Before
        public void before(){
            //使用"spring.xml"和"spring-mybatis.xml"这两个配置文件创建Spring上下文
            ApplicationContext ac = new ClassPathXmlApplicationContext(new String[]{"/test/spring.xml","/test/conf.xml"});
            //从Spring容器中根据bean的id取出我们要使用的userService对象
            userService = (ITaskService) ac.getBean("taskService");
            try {
                 conn = DriverManager.getConnection("jdbc:hsqldb:mem:rdrs","sa",""); //启动内存数据库 rdrs,用户名sa 密码空
            } catch (SQLException e) {
                
            }
        }

    另外贴上脚本语句,虽然号称兼容,但是兼容不是那么好

    INDEX index_taskname (TASKNAME,USERNAME) 这样的不兼容

    COLUMN_PAIR text character set utf8 , text指定字符集不兼容

    SET DATABASE SQL SYNTAX MYS TRUE; -- 兼容mysql
    
    CREATE TABLE TASK (
      ID INT(10) NOT NULL auto_increment,
      TASKNAME varchar(150) NOT NULL,
      USERNAME varchar(150) NOT NULL,
      STATUS varchar(20) NOT NULL,
      TASK_TYPE varchar(20) NOT NULL,
      GMT_CREATE varchar(80) NOT NULL,
      GMT_START varchar(80) NOT NULL,
      PRIMARY KEY  (ID),
    ) ;

    剩下的就是单纯mybatis的东西了,单元测试就很好写了

  • 相关阅读:
    二叉树的存储方式以及递归和非递归的三种遍历方式
    java基础04 匿名内部类
    jvm007 jvm知识点总览
    jvm学习006 jvm内存结构分配
    java基础03 位运算符
    java基础02 数据类型转
    jvm005 从jvm的角度谈谈线程的实现
    Arcgis投影变换后图像变深的问题
    win 7 64位如何安装erdas 9.2
    Win7 64bit 成功安装ArcView3.X
  • 原文地址:https://www.cnblogs.com/juniorMa/p/7163091.html
Copyright © 2011-2022 走看看