MyEclipse不提供自己主动生成,这里提供mybatis文件包和开发文档 http://download.csdn.net/detail/u010026901/7489319

自己建立配置文件,

<?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>

<environments default="development">

<environment id="development">

<transactionManager type="JDBC" />

<dataSource type="POOLED">

<property name="driver" value="oracle.jdbc.driver.OracleDriver" />

<property name="url" value="jdbc:oracle:thin:@192.168.2.55:ORCL" />

<property name="username" value="ysk" />

<property name="password" value="123" />

</dataSource>

</environment>

</environments>

<mappers>

<!--这里填写dao接口映射的daoImpl,mybatis不是映射pojo(vo)类,而是dao类-->

<mapper resource="com/kane/dao/NewsDAOImpl.xml" />

</mappers>

</configuration>

自己配置链接的sqlsessionFactory类,相当于hibernate的sessionFactory相应一个数据库

package com.kane.dbc;





import java.io.InputStream;





import org.apache.ibatis.io.Resources;

import org.apache.ibatis.session.SqlSession;

import org.apache.ibatis.session.SqlSessionFactory;

import org.apache.ibatis.session.SqlSessionFactoryBuilder;





public class MyBATISSqlSessionFactory {





// 配置文件的所在位置和名称

private static String CONFIG_FILE_LOCATION = "mybatis-conf.xml";





// 用来实现连接池的,该类类似Map集合。

private static final ThreadLocal<SqlSession> threadLocal = new ThreadLocal<SqlSession>();

// MyBATIS用来读取配置文件的类

private static InputStream is;

// 用来建立连接的,该类就是连接池,使用单例设计模式

private static SqlSessionFactory sqlsessionFactory;

// 备用的配置文件位置

private static String configFile = CONFIG_FILE_LOCATION;





// 静态块,类载入时最先运行

static {

try {

// 载入配置文件到内存中

is = Resources.getResourceAsStream(configFile);

// 建立连接池以及里面的连接

sqlsessionFactory = new SqlSessionFactoryBuilder().build(is);

} catch (Exception e) {

System.err.println("%%%% Error Creating SessionFactory %%%%");

e.printStackTrace();

}

}





private MyBATISSqlSessionFactory() {

}





/**

* 取得数据库连接对象



* @return Session

* @throws HibernateException

*/

public static SqlSession getSession() {

// 先从ThreadLocal中取得连接。

SqlSession session = (SqlSession) threadLocal.get();





// 假设手头没有连接,则取得一个新的连接

if (session == null) {

session = sqlsessionFactory.openSession();

// 把取得出的连接记录到ThreadLocal中,以便下次使用。

threadLocal.set(session);

}





return session;

}





/**

* 连接关闭的方法



* @throws HibernateException

*/

public static void closeSession() {

SqlSession session = (SqlSession) threadLocal.get();

// 将ThreadLocal清空。表示当前线程已经没有连接。

threadLocal.set(null);

// 连接放回到连接池

if (session != null) {

session.close();

}

}

}

通过配置文件实现daoimpl而不是java类

<?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.kane.dao.INewsDAO">

<insert id="doCreate" parameterType="News">

<!--jdbcType表示这个内容同意为空,为Oracle指明类型

若表中的列名与vo中列名不同,能够重命名

SELECT

id,title,content,pub_date AS pubDate,type_id AS typeId,photo,tname FROM news n,news_type nt

WHERE id = #{id} AND n.type_id = nt.tid -->

INSERT INTO NEWS(news_id,news_title,image_id,news_content,news_time) VALUES

(sys_guid(),#{news_title},#{image_id},#{news_content,jdbcType=VARCHAR},#{news_time,jdbcType=DATE})

</insert>

<delete id="doRemove" parameterType="java.lang.Integer">

DELETE FRON News WHEER news_id=#{id}

</delete>

<update id="doUpdate" parameterType="News">

UPDATE News SET news_title=#{news_title},image_id=#{image_id},news_content=#{news_content},news_time=#{news_time}

WHERE news_id=#{news_id}

</update>

<select id="findAll" resultType="News">

SELECT news_id,news_title,image_id,news_content,news_time FROM News

</select>

<select id="findById" resultType="News">

SELECT news_id,news_title,image_id,news_content,news_time FROM News=#{id}

</select>

<select id="findAllSplit" resultType="News" parameterType="java.util.Map">

SELECT temp.* FROM (SELECT news_id,news_title,image_id,news_content,news_time,ROWNUM rn 

FROM News WHERE ${column} LIKE #{keyword} AND ROWNUM &lt;=#{endNum})

temp WHERE temp.rn>#{startNum}

</select>

<select id="getAllCount" resultType="java.lang.Integer" parameterType="java.util.Map">

SELECT COUNT(*) FROM News WHERE ${column} LIKE #{keyword}

</select>

</mapper>

接着service。在serviceImpl中

package com.kane.service.impl;

import java.util.HashMap;

import java.util.List;

import java.util.Map;

import com.kane.dao.INewsDAO;

import com.kane.dbc.MyBATISSqlSessionFactory;

import com.kane.service.INewsService;

import com.kane.vo.News;





public class NewsServiceImpl implements INewsService{





public List<News> findAll(){

List<News> all=null;

try {

all=MyBATISSqlSessionFactory.getSession().getMapper(INewsDAO.class).findAll();

} catch (Exception e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

finally{

MyBATISSqlSessionFactory.closeSession();

}

return all;

}

public void insert(News news) throws Exception {

try {

MyBATISSqlSessionFactory.getSession().getMapper(INewsDAO.class).doCreate(news);

MyBATISSqlSessionFactory.getSession().commit();

} catch (Exception e) {

MyBATISSqlSessionFactory.getSession().rollback();

e.printStackTrace();

}

finally{

MyBATISSqlSessionFactory.closeSession();

}

}

public Map<String, Object> list(int pageNo, int pageSize, String column,String keyword){

Map<String,Object> map=new HashMap<String,Object>();

Map<String,Object> params=new HashMap<String, Object>();

params.put("column",column);

params.put("keyword",keyword);

params.put("endNum",pageSize*pageNo);

params.put("startNum",(pageNo-1)*pageSize);

try {

map.put("allNews", MyBATISSqlSessionFactory.getSession().getMapper(INewsDAO.class)

.findAllSplit(params));

map.put("count", MyBATISSqlSessionFactory.getSession().getMapper(INewsDAO.class)

.getAllCount(params));

} catch (Exception e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

finally{

MyBATISSqlSessionFactory.closeSession();

}

return map;

}

public void remove(int id) throws Exception {

// TODO Auto-generated method stub



}

public void update(News news) throws Exception {

// TODO Auto-generated method stub



}

public News findById(int id){

News news=null;

try {

news=MyBATISSqlSessionFactory.getSession().getMapper(INewsDAO.class).findById(id);

} catch (Exception e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

finally{

MyBATISSqlSessionFactory.closeSession();

}

return news;

}

}

然后junit測试

@Test

public void testList() throws Exception {

System.out.println(ServiceFactory.getNewsServiceInstance().list(1, 5,

"news_title", "12"));

}

MyBATIS使用CRUD的更多相关文章

  1. MyBatis:CRUD功能

    在前面已经自动生成了mapper和pojo,接下来我们实现mybatis的CRUD功能,先新建service.controller层的方法. 这里的sid是一个开源的id生成类,写完后,我们还需要在启 ...

  2. Mybatis的CRUD案例

    一.Mybatis增删改查案例 上一节<Mybatis入门和简单Demo>讲了如何Mybatis的由来,工作流程和一个简单的插入案例,本节主要继上一讲完整的展示Mybatis的CRUD操作 ...

  3. 【MyBatis】MyBatis实现CRUD操作

    1.实现基本CRUD功能 使用MyBatis对数据完整的操作,也就是CRUD功能的实现.根据之前的内容,要想实现CRUD,只需要进行映射文件的配置. 范例:修改EmpMapper.xml文件,实现CR ...

  4. SpringBoot 整合 Mybatis 进行CRUD测试开发

    今天来和大家分享下 Spring Boot 整合 MyBatis 的 CRUD 测试方法开发.因为 MyBaits 有两种开发形式,一种基于注解,一种基于 xml . SpringBoot配置文件也有 ...

  5. 基于mybatis的CRUD

    u  基于Mybatis的CRUD u  掌握MyBatis的结果类型-resultMap和resultType u  掌握MyBatis的参数类型 u  掌握#和$两种语法 1      基于myb ...

  6. 05 Mybatis的CRUD操作和Mybatis连接池

    1.CRUD的含义 CRUD是指在做计算处理时的增加(Create).读取(Retrieve)(重新得到数据).更新(Update)和删除(Delete)几个单词的首字母简写.主要被用在描述软件系统中 ...

  7. 03 Mybatis:05.使用Mybatis完成CRUD

    mybatis框架:共四天 明确:我们在实际开发中,都是越简便越好,所以都是采用不写dao实现类的方式.不管使用XML还是注解配置. 第二天:mybatis基本使用 mybatis的单表crud操作 ...

  8. mybatis(CRUD)

    3.mybatis(CRUD) 有了mybatis,我们要对数据库进行增删改查只需要操作接口和mapper.xml文件,然后进行测试就可以了. 实例代码如下: 接口 public interface ...

  9. MyBatis之CRUD

    1 mybatis框架介绍 1.1回顾jdbc操作数据库的过程 1.2 mybatis开发步骤 A.提供一个SqlMapperConfig.xml(src目录下),该文件主要配置数据库连接,事务,二级 ...

  10. MyBatis Tutorial – CRUD Operations and Mapping Relationships – Part 1---- reference

    http://www.javacodegeeks.com/2012/11/mybatis-tutorial-crud-operations-and-mapping-relationships-part ...

随机推荐

  1. Domain(AD) 管理

    新建账户 文件夹权限管理

  2. 边框圆角化方式(原文链接http://www.cnblogs.com/SJP666/p/4678730.html)

    第一种方法:如果是CSS2.2的话,可以简单写一个制作圆角矩形,分上中下裁成三张图 <title>CSS3实现圆角</title> <style type="t ...

  3. c#--foreach遍历的用法与split的用法

    一. foreach循环用于列举出集合中所有的元素,foreach语句中的表达式由关键字in隔开的两个项组成.in右边的项是集合名,in左边的项是变量名,用来存放该集合中的每个元素.      该循环 ...

  4. linux学习过程中所需要看的一些书籍

    入门类 一直认为,在一个系统上学习开发之前,首先需要熟悉这个系统的使用.鉴于天朝的国情,绝大部分人第一个接触的操作系统就是Windows,因此对于这绝大部分人来说,如果要学习Linux开发,学会使用这 ...

  5. QLinkedList和std::forward_list(都是双向链表,不支持operator[],好处可能是插入和删除都比较快)

    forward_list forward_list是C++11版本才有的.forward_list被实现为单链表,而list是一个双向链表,所以forward_list要比list高效一些.forwa ...

  6. 用PowerMockito来mock私有方法(转)

    话说我们做的所谓的接口测试真的是不伦不类啊,测的是controller层,那叫接口木??!!可是老大们说写的是接口测试,那就接口吧! 自接手写这个接口测试不久,很多人,包括一个关系比较好的架构师就跟我 ...

  7. linux网络体系架构

    原创kylin_zeng:http://blog.csdn.net/kylin_fire_zeng  本文参考国嵌视频教程,再此感谢国嵌教育. 一.协议栈层次对比: 1)网络接口层把数据链路层和物理层 ...

  8. 使用ItextSharp产PDF完整操作

    原文 使用ItextSharp产PDF完整操作 记得上回有写到用C#操作Excel(.net 4.0) 很多朋友说推荐用NPOI,的确,用微软自带的操作execl会有很大的问题.客户的主机不愿意安装e ...

  9. VS2008+Qt 项目目录

    1.项目开发环境:VS2008,QT4.7 2.项目的目录: 1)PETCT是解决方案名字 2)Bin目录存放所有动态链接库和执行档,包括自己的产出和第三方库,区分Release和Debug两个版本. ...

  10. 使用POI创建Excel文件下载

    POIExcelUtils.java: package com.saicfc.pmpf.internal.manage.utils; import java.io.File; import java. ...