java项目集成mybatis_JAVA应用程序单独集成Mybatis使用Demo

参考博客:http://www.cnblogs.com/magialmoon/archive/2013/10/30/3397828.html

整体结构

dd54efd022f417be234e6aeadf861a0e.png

POM依赖

org.mybatis

mybatis

3.2.3

mysql

mysql-connector-java

5.1.26

数据准备

CREATE TABLE `t_migu_top_data` (

`music_id` int(11) DEFAULT NULL,

`music_name` varchar(100) DEFAULT NULL,

`music_author` varchar(100) DEFAULT NULL,

) ENGINE=InnoDB DEFAULT CHARSET=utf8;

配置文件

mybatis-config.xml

TopDataMapper.xml

t_migu_top_data

music_id,

music_name,

music_author

insert into(

music_id,

music_name,

music_author

)

values

(

#{musicId},

#{musicName},

#{musicAuthor}

)

insert into(

music_id,

music_name,

music_author

)

values(

#{item.musicId},

#{item.musicName},

#{item.musicAuthor}

)

selectfrom

and music_id = #{musicId}

and music_name like '%${musicName}%'

and music_author like '%${musicAuthor}%'

and music_language = #{musicLanguage}

and music_style = #{musicStyle}

and create_time >= '${startDate}'

and '${endDate}' >= create_time

update

music_status = #{musicStatus},

customer_file_path = #{customerFilePath},

where music_id = #{musicId}

实体对象

public classTopData {privateString musicId;privateString musicName;privateString musicAuthor;

...

}

接口Dao

public interfaceTopDataDao {public voidcreateTopData(TopData topData);public void createTopDataByBatch(ListtopDataList);public voidupdateTopData(TopData topData);//public void updateTopDataByBatch(List topDataList);

public List getTopDataList(MapqueryMap);

}

manager

public classTopDataManager {private staticSqlSession sqlSession;private staticTopDataDao topDataDao;public static voidinitialConnection() {try{

String resource= "mybatis-config.xml";

Reader reader=Resources.getResourceAsReader(resource);

SqlSessionFactory ssf= newSqlSessionFactoryBuilder().build(reader);

sqlSession=ssf.openSession();

topDataDao= sqlSession.getMapper(TopDataDao.class);

}catch(Exception e) {

e.printStackTrace();

}

}public static voiddestroyConnection() {

sqlSession.close();

}public static voidcreateTopData(TopData topData) {

topDataDao.createTopData(topData);

sqlSession.commit();

}public static void createTopDataByBatch(ListtopDataList) {

topDataDao.createTopDataByBatch(topDataList);

sqlSession.commit();

}public static voidupdateTopData(TopData topData) {

topDataDao.updateTopData(topData);

sqlSession.commit();

}public static List getTopDataList(MapqueryMap) {returntopDataDao.getTopDataList(queryMap);

}

}

测试

main 方法访问即可

注意事项

1、mybatis会用log4j记录日志,但是开启debug模式貌似对性能影响非常厉害。

2、mybatis的查询缓存对性能的影响非常大,启用和不启用差距非常大

020c18febfe6e151545f7c8792a9096e.png

72cde07974100c4633ec7a0fdaf2753b.png

注意:mapper文件中一定要加上cache这一行,否则不生效。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值