mybatis笔记 - 04

2017 06 13

包结构示意图:

image

建立 modle test util 包

modle包存放持久化对象和mapper映射文件

test包存放Junit单元测试文件

util包存放工具类

新建jdbc.proeprties属性文件 按照 KEY = VALUE 格式存放数据库连接信息

新建log4j.properties属性文件 存放sql语句显示配置

代码示例

jdbc.proeprties :

jdbc.mysql.driver = com.mysql.jdbc.Driver
jdbc.mysql.url = jdbc:mysql://127.0.0.1:3306/mybatis_test?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true
jdbc.mysql.username = root
jdbc.mysql.password = root

log4j.properties :

# Global logging configuration
# 级别 TRACE<DEBUG<INFO<WARN<ERROR
log4j.rootLogger=ERROR, stdout
# 想显示SQL语句,需要设置命名空间
log4j.logger.com.shxt.model.User=TRACE
# Console output...
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%5p [%t] - %m%n

主配置文件mybatis-config.xml文件中 数据库连接信息按照意义下代码示例进行配置

通过 ${KEY} 的形式来取值

<environments default="development_mysql">
    <environment id="development_mysql">
        <transactionManager type="JDBC" />
        <dataSource type="POOLED">
            <property name="driver" value="${jdbc.mysql.driver}" />
            <property name="url" value="${jdbc.mysql.url}" />
            <property name="username" value="${jdbc.mysql.username}" />
            <property name="password" value="${jdbc.mysql.password}" />
        </dataSource>
    </environment>
</environments>

单元测试注解说明 :

import org.junit.After;
import org.junit.Before;
import org.junit.Test;

public class test {
    //Before注解: 在运行每个方法前永远都首先执行本方法
    @Before
    public void Test01Method(){
        System.out.println("首先执行我!");
    }
    //after注解 : 在运行每个方法之后都会执行本方法
    @After
    public void Test02Method(){
        System.out.println("最后执行我!");
    }
    //Test注解: 调用JUnit框架测试方法是否通过
    @Test
    public void Test03Method(){
        System.out.println("测试通过!");
    }
}

在mapper映射文件中 存在<resultMap>标签 用于结果集处理

type 表示结果集最终处理类型

id 为当前resultMap指定名称方便调用

<resultMap type="User" id="BaseResultMapper" >
    <!-- 用于标记数据表中的主键 -->
    <!-- column 数据库字段名 -->
    <!-- jdbcType 数据库字段类型 --> 
    <!-- property 持久化类的属性 -->
    <!-- javaType java类型 需要书写类名 --> 
    <id column="user_id" jdbcType="INTEGER" property="userId" javaType="java.lang.Integer" />
    <result column="account" jdbcType="VARCHAR" property="account" javaType="java.lang.String" />
    <result column="password" jdbcType="VARCHAR" property="pwd" javaType="java.lang.String" />
    <result column="user_name" jdbcType="VARCHAR" property="userName" javaType="java.lang.String" />
</resultMap>

sql标签用于存放sql语句中公共的部分 减少代码量

在CRUD操作中通过<include>标签调用

下列 <select> 标签将会给出一个示例

<sql id="sys_user_columns">
    user_id,account,password,user_name
</sql>


    <select id="like01" resultMap="BaseResultMapper">
        SELECT
            <include refid="sys_user_columns" />
        FROM
            user
        WHERE
            user_name like '%管%'
        </select>
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 222,183评论 6 516
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 94,850评论 3 399
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 168,766评论 0 361
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,854评论 1 299
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,871评论 6 398
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 52,457评论 1 311
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,999评论 3 422
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,914评论 0 277
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 46,465评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,543评论 3 342
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,675评论 1 353
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 36,354评论 5 351
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 42,029评论 3 335
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,514评论 0 25
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,616评论 1 274
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 49,091评论 3 378
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,685评论 2 360

推荐阅读更多精彩内容

  • 1. 简介 1.1 什么是 MyBatis ? MyBatis 是支持定制化 SQL、存储过程以及高级映射的优秀的...
    笨鸟慢飞阅读 5,527评论 0 4
  • Java数据持久化之mybatis 一. mybatis简介 1.1 原始的JDBC操作: Java 通过 Jav...
    小Q逛逛阅读 4,929评论 0 16
  • 在应用程序中添加日志记录总的来说基于三个目的:监视代码中变量的变化情况,周期性的记录到文件中供其他应用进行统计分析...
    时待吾阅读 5,057评论 1 13
  • 在应用程序中添加日志记录总的来说基于三个目的:监视代码中变量的变化情况,周期性的记录到文件中供其他应用进行统计分析...
    时待吾阅读 4,991评论 0 6
  • #pragma mark - 类别是对原有类进行扩展 NSString+FilePath.h —>类名+类别名.h...
    nothing_c阅读 321评论 0 0