MyBatis----延迟加载demo

一:创建数据库脚本drop table project_info;
drop table status;

create table status(
id number(10) primary key,
name varchar2(20) not null
);

create table project_info(
id number(10) primary key,
project_name varchar2(100) not null,
start_date date not null,
end_date date not null,
status_id number(10) references status(id)
);

drop sequence seq_status;
drop sequence seq_projectinfo;
create sequence seq_status;
create sequence seq_projectinfo;

insert into status(id,name)values(seq_status.nextval,‘已申报‘);
insert into status(id,name)values(seq_status.nextval,‘审核中‘);
insert into status(id,name)values(seq_status.nextval,‘已审核‘);

insert into project_info(id,project_name,start_date,end_date,status_id)values(seq_projectinfo.nextval,‘北京社会科学院2017年申报‘,to_date(‘2017=04-02‘,‘yyyy-MM-dd‘),to_date(‘2017=04-03‘,‘yyyy-MM-dd‘),1);
insert into project_info(id,project_name,start_date,end_date,status_id)values(seq_projectinfo.nextval,‘福建社会科学院2017年申报‘,to_date(‘2017=04-04‘,‘yyyy-MM-dd‘),to_date(‘2017=04-05‘,‘yyyy-MM-dd‘),1);
insert into project_info(id,project_name,start_date,end_date,status_id)values(seq_projectinfo.nextval,‘上海社会科学院2017年申报‘,to_date(‘2017=04-06‘,‘yyyy-MM-dd‘),to_date(‘2017=04-07‘,‘yyyy-MM-dd‘),1);

  二:项目目录结构

三:在src下创建jdbc.properties

driver=oracle.jdbc.driver.OracleDriver
url=jdbc:oracle:thin:@127.0.0.1:1521:orcl
username=system
password=orcl

四:在src下创建log4j.properties

log4j.rootLogger=DEBUG, Console  

#Console
log4j.appender.Console=org.apache.log4j.ConsoleAppender
log4j.appender.Console.layout=org.apache.log4j.PatternLayout
log4j.appender.Console.layout.ConversionPattern=%d [%t] %-5p [%c] - %m%n  

log4j.logger.java.sql.ResultSet=INFO
log4j.logger.org.apache=INFO
log4j.logger.java.sql.Connection=DEBUG
log4j.logger.java.sql.Statement=DEBUG
log4j.logger.java.sql.PreparedStatement=DEBUG

五:在src下创建mybatis-config.xml

<?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>
  <properties resource="jdbc.properties"/>
  <settings>
  <!--  开启延时加载开关 -->
    <setting name="lazyLoadingEnabled" value="true"/>
    <!-- 设置延时加载 -->
    <setting name="aggressiveLazyLoading" value="false"/>
  </settings>
  <typeAliases>
    <typeAlias type="com.pojo.ProjectInfo" alias="ProjectInfo"/>
    <typeAlias type="com.pojo.Status" alias="Status"/>
  </typeAliases>
  <environments default="developement">
     <environment id="developement">
       <transactionManager type="JDBC"/>
       <dataSource type="POOLED">
         <property name="driver" value="${driver}"/>
         <property name="url" value="${url}"/>
         <property name="username" value="${username}"/>
         <property name="password" value="${password}"/>
       </dataSource>
     </environment>
  </environments>
  <mappers>
     <mapper resource="com/mapper/ProjectInfoMapper.xml"/>
  </mappers>
</configuration>

  

时间: 2024-12-19 05:03:51

MyBatis----延迟加载demo的相关文章

MyBatis的demo

把以前写的关于mybatis的demo放在这边,以便查看. 目录结构: 1 package com.test.mybatis.util; 2 3 import java.io.IOException; 4 import java.io.InputStream; 5 6 import org.apache.ibatis.io.Resources; 7 import org.apache.ibatis.session.SqlSession; 8 import org.apache.ibatis.se

MyBatis使用DEMO及cache的使用心得

下面是一个简单的MyBatis使用DEMO. 整体结构 整体代码大致如下: POM依赖 需要引用两个jar包,一个是mybatis,另一个是mysql-connector-java,如果是maven工程的话,pom里如下添加依赖就可以了. <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>3.2.3</ver

SpringMVC+Spring+Mybatis(SSM~Demo) 【转】

SpringMVC+Spring+Mybatis 框架搭建 整个Demo的视图结构: JAR: 下载地址:http://download.csdn.net/detail/li1669852599/8546059 首先,我是使用MyEclipse工具做的这个例子,整合了Sping 3 .Spring MVC 3 .MyBatis框架,演示数据库采用MySQL数据库.例子中主要操作包括对数据的添加(C).查找(R).更新(U).删除(D).我在这里采用的数据库连接池是来自阿里巴巴的Druid,至于D

测试mybatis延迟加载错误与解决方法

什么是延迟加载? 延迟加载又叫懒加载,也叫按需加载,也就是说先加载主信息,需要的时候,再去加载从信息. 需求: 查询订单信息,需要时再去查询用户信息 实现方式: 编写两个statement,其中一个statement是查询订单信息,一个是查询用户信息,但是查询订单信息的statement要使用resultMap标签进行结果映射. Mapper接口: /**  * 延迟加载  查询订单 需要时在查询用户信息  * */  public List<OrderExt> lazyLoading();

Mybatis延迟加载

现在有这么一个需求,要查询所有的订单,并且获得该订单的详细信息. 如果一次性把所有需要的数据都请求到,那么对服务器和数据库的开销会很大,所以可以先加载订单信息,需要用到订单详情的时候再请求详情数据. 那么就要用到mybatis的延迟加载 开启延迟加载 在mybaits配置文件中添加设置 <!--延迟加载--> <setting name="lazyLoadingEnabled" value="true"/> <setting name=

Mybatis入门DEMO

下面将通过以下步骤说明如何使用MyBatis开发一个简单的DEMO: 步骤一:新建表STUDENTS 字段有: Stu_Id.Stu_Name.Stu_Age.Stu_Birthday 1 CREATE TABLE `student` ( 2 `Stu_Id` bigint(20) NOT NULL AUTO_INCREMENT , 3 `Stu_Name` varchar(30) CHARACTER SET utf8 COLLATE utf8_bin NULL DEFAULT NULL , 4

mybatis 延迟加载学习

一.什么是延迟加载 resultMap可实现高级映射(使用association.collection实现一对一及一对多映射),association.collection具备延迟加载功能. 需求: 如果查询订单并且关联查询用户信息.如果先查询订单信息即可满足要求,当我们需要查询用户信息时再查询用户信息.把对用户信息的按需去查询就是延迟加载. 延迟加载:先从单表查询,需要时再从关联表去关联查询,大大提高数据库性能,因为查询单表要比关联查询多张表速度要快. 二.使用association实现延迟加

mybatis延迟加载——(十二)

1.     什么是延迟加载 resultMap可以实现高级映射(使用association.collection实现一对一及一对多映射),association.collection具备延迟加载功能. 需求: 如果查询订单并且关联查询用户信息.如果先查询订单信息即可满足要求,当我们需要查询用户信息时再查询用户信息.把对用户信息的按需去查询就是延迟加载. 延迟加载:先从单表查询.需要时再从关联表去关联查询,大大提高 数据库性能,因为查询单表要比关联查询多张表速度要快. 2.    打开延迟加载开

10.MyBatis 延迟加载,一级缓存,二级缓存 设置

什么是延迟加载  resultMap中的association和collection标签具有延迟加载的功能. 延迟加载的意思是说,在关联查询时,利用延迟加载,先加载主信息.使用关联信息时再去加载关联信息. 设置延迟加载 需要在SqlMapConfig.xml文件中,在<settings>标签中设置下延迟加载. lazyLoadingEnabled.aggressiveLazyLoading 设置项 描述 允许值 默认值 lazyLoadingEnabled 全局性设置懒加载.如果设为'fals

最基础的mybatis入门demo

demo结构 数据库情况 (不会转sql语句 骚瑞) 数据库连接信息 jdbc.properties jdbc.driver=com.mysql.jdbc.Driver jdbc.url=jdbc:mysql://localhost:3306/mysql_demo jdbc.username=root jdbc.password=root javabean Student.class package entity; public class Student { private Integer i