项目结构:

依赖jar:

数据库依赖:

 CREATE TABLE `person` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(45) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 CREATE TABLE `user_account` (
`userid` int(11) NOT NULL AUTO_INCREMENT,
`username` varchar(30) NOT NULL,
`password` varchar(30) NOT NULL,
`groupname` varchar(10) NOT NULL,
PRIMARY KEY (`userid`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8
 INSERT INTO ssi.user_account (userid, username, password, groupname) VALUES (1, 'LMEADORS', 'PICKLE', 'EMPLOYEE');
INSERT INTO ssi.user_account (userid, username, password, groupname) VALUES (2, 'JDOE', 'TEST', 'EMPLOYEE');

数据库连接信息:db.properties

driverClass=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/ssi
username=root
password=

主配置文件:sqlMapConfig.xml

 <?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE sqlMapConfig
PUBLIC "-//ibatis.apache.org//DTD SQL Map Config 2.0//EN"
"http://ibatis.apache.org/dtd/sql-map-config-2.dtd">
<sqlMapConfig>
<properties resource="db.properties"/>
<!--iBatis配置信息-->
<settings enhancementEnabled="true"
useStatementNamespaces="true"
cacheModelsEnabled="true"
lazyLoadingEnabled="true"/> <!--事务管理器-->
<transactionManager type="JDBC">
<!--数据库连接信息-->
<dataSource type="SIMPLE">
<property name="JDBC.Driver" value="${driverClass}"/>
<property name="JDBC.ConnectionURL" value="${url}"/>
<property name="JDBC.Username" value="${username}"/>
<property name="JDBC.Password" value="${password}"/>
</dataSource>
</transactionManager>
<!-- 映射文件位置 -->
<sqlMap resource="org/zln/ibatis/sqlmaps/Person.xml" />
<sqlMap resource="org/zln/ibatis/sqlmaps/UserAccount.xml" />
</sqlMapConfig>

初始化配置文件

 package org.zln.ibatis.utils;

 import com.ibatis.common.resources.Resources;
import com.ibatis.sqlmap.client.SqlMapClient;
import com.ibatis.sqlmap.client.SqlMapClientBuilder; import java.io.IOException;
import java.io.Reader; /**
* Created by sherry on 000008/6/8 14:36.
*/
public class SqlMapUtils {
private static final String resource = "sqlMapConfig.xml";
public static SqlMapClient sqlMapClient = null; public static SqlMapClient getSqlMapClient() throws IOException {
Reader reader = Resources.getResourceAsReader(resource);
sqlMapClient = SqlMapClientBuilder.buildSqlMapClient(reader);
return sqlMapClient;
}
}

映射文件

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE sqlMap
PUBLIC "-//iBATIS.com//DTD SQL Map 2.0//EN"
"http://www.ibatis.com/dtd/sql-map-2.dtd"> <!-- 设置命名空间 -->
<sqlMap namespace="org.zln.ibatis.domain.UserAccount"> <typeAlias alias="UserAccount" type="org.zln.ibatis.domain.UserAccount"/> /*外部参数映射*/
<parameterMap id="fullUserAccountMapExport" class="UserAccount">
<parameter property="userid" jdbcType="INTEGER"/>
<parameter property="username" jdbcType="VARCHAR"/>
<parameter property="password" jdbcType="VARCHAR"/>
<parameter property="groupname" jdbcType="VARCHAR"/>
</parameterMap>
/*结果集映射*/
<resultMap id="UserAccountMap" class="UserAccount">
<result property="userid" column="userid"/>
<result property="username" column="username"/>
<result property="password" column="password"/>
<result property="groupname" column="groupname"/>
<!--当查询tt的时候,会查询select-id对应的SQL,然后映射到JavaBean中的listColl,-->
<!--<result column="tt" property="listColl" select="select-id"/>-->
</resultMap> <select id="getUserAccountList" parameterClass="UserAccount" resultClass="UserAccount">
SELECT userid,username,password,groupname FROM user_account
<dynamic prepend="WHERE">
<isNotEmpty property="username" prepend="AND">
username LIKE '%'||#username#||'%'
</isNotEmpty>
<isNotEmpty property="password" prepend="AND">
password = #password#
</isNotEmpty>
<isNotEmpty property="groupname" prepend="AND">
groupname LIKE '%'||#groupname#||'%'
</isNotEmpty>
<!--循环标签-->
<iterate property="ids" open="(" close=")" conjunction=",">
userid = #userid#
</iterate>
</dynamic>
</select> <insert id="insertUserAccount" parameterClass="UserAccount">
INSERT INTO user_account (username,password,groupname) VALUES (#username#,#password#,#groupname#)
</insert>
/*使用外部映射*/
<insert id="insertUserAccount_1" parameterMap="fullUserAccountMapExport">
INSERT INTO user_account (username,password,groupname) VALUES (?,?,?)
</insert>
/*Oracle的序列使用演示*/
<!--<insert id="insertUserAccount_2" parameterMap="fullUserAccountMapExport">
<selectKey keyProperty="userid" resultClass="int">
SELECT nextVal(#序列#) FROM dual
</selectKey>
INSERT INTO user_account (userid,username,password,groupname) VALUES (?,?,?,?)
</insert>--> <update id="updateUserAccount" parameterClass="UserAccount">
UPDATE user_account set userid = #userid#
<dynamic>
<isNotEmpty prepend="," property="username">
username = #username#
</isNotEmpty>
<isNotEmpty prepend="," property="password">
password = #password#
</isNotEmpty>
<isNotEmpty prepend="," property="groupname">
groupname = #groupname#
</isNotEmpty>
</dynamic>
WHERE userid = #userid#
</update> <sql id="select-user_account-list">
SELECT userid,username,password,groupname FROM user_account
</sql>
<sql id="select-user_account-count">
SELECT COUNT(1) FROM user_account
</sql>
<sql id="where-user_account">
<![CDATA[
WHERE userid > #userid:INTEGER#
]]>
</sql>
<select id="selectUserAccountsAfterId" parameterClass="UserAccount" resultClass="UserAccount">
<include refid="select-user_account-list"/>
<include refid="where-user_account"/>
</select> /*调用存储过程演示*/
<!--<procedure id="callProDemo" parameterClass="string" resultClass="int">
{call product(?)}
</procedure>--> </sqlMap>

BaseDao.java

 package org.zln.ibatis.dao.base;

 import com.ibatis.sqlmap.client.SqlMapClient;
import org.zln.ibatis.utils.SqlMapUtils; import java.io.IOException; /**
* Created by sherry on 000008/6/8 15:16.
*/
public class BaseDao {
public SqlMapClient sqlMapClient; {
try {
sqlMapClient = SqlMapUtils.getSqlMapClient();
} catch (IOException e) {
e.printStackTrace();
}
}
}

UserAccountDaoImpl.java

 package org.zln.ibatis.dao.impl;

 import org.zln.ibatis.dao.UserAccountDao;
import org.zln.ibatis.dao.base.BaseDao;
import org.zln.ibatis.domain.UserAccount; import java.sql.SQLException;
import java.util.List;
import java.util.Map; /**
* Created by sherry on 000008/6/8 15:15.
*/
public class UserAccountDaoImpl extends BaseDao implements UserAccountDao { @Override
public List<UserAccount> getUserAccountList(UserAccount userAccount){
List<UserAccount> userAccounts = null;
try {
userAccounts = sqlMapClient.queryForList("org.zln.ibatis.domain.UserAccount.getUserAccountList",userAccount); //start test queryForMap
Map<String,UserAccount> map = sqlMapClient.queryForMap("org.zln.ibatis.domain.UserAccount.getUserAccountList",userAccount,"username");
System.out.println(map);
//end
} catch (SQLException e) {
e.printStackTrace();
}
return userAccounts;
} @Override
public List<UserAccount> getUserAccountListAfterId(UserAccount userAccount) {
List<UserAccount> userAccounts = null;
try {
userAccounts = sqlMapClient.queryForList("org.zln.ibatis.domain.UserAccount.selectUserAccountsAfterId",userAccount); } catch (SQLException e) {
e.printStackTrace();
}
return userAccounts;
} @Override
public void insertUserAccount(List<UserAccount> userAccounts) {
try {
/*批处理*/
sqlMapClient.startTransaction();
sqlMapClient.startBatch();
for (UserAccount userAccount:userAccounts){
sqlMapClient.insert("org.zln.ibatis.domain.UserAccount.insertUserAccount",userAccount);
}
sqlMapClient.executeBatch();
sqlMapClient.commitTransaction();
} catch (SQLException e) {
e.printStackTrace();
}finally {
try {
sqlMapClient.endTransaction();
} catch (SQLException e) {
e.printStackTrace();
}
}
} @Override
public void updateUserAccount(UserAccount userAccount) {
try {
sqlMapClient.update("org.zln.ibatis.domain.UserAccount.updateUserAccount",userAccount);
} catch (SQLException e) {
e.printStackTrace();
}
} }

日志配置文件:log4j.properties

## LOGGERS ##
#define a logger
#log4j.rootLogger=DEBUG,console,file
log4j.rootLogger=INFO,console
## APPENDERS ## log4j.appender.console=org.apache.log4j.ConsoleAppender
# define an appender named file, which is set to be a RollingFileAppender
log4j.appender.file=org.apache.log4j.RollingFileAppender
#set the log's size
log4j.appender.file.MaxFileSize=1000KB
log4j.appender.file.MaxBackupIndex=
## LAYOUTS ##
# assign a SimpleLayout to console appender
log4j.appender.console.layout=org.apache.log4j.SimpleLayout
# assign a PatternLayout to file appender
log4j.appender.file.layout=org.apache.log4j.PatternLayout
# For debug
# log4j.appender.file.layout.ConversionPattern=[%-5p][%t][%C][%d{yyyy-MM-dd HH:mm:ss}] %m%n
# For deployment
log4j.appender.file.layout.ConversionPattern=[%-5p][%d{yyyy-MM-dd HH:mm:ss}] %m%n
# show SQL Where ibatis run
log4j.logger.com.ibatis=DEBUG
log4j.logger.com.ibatis.common.jdbc.SimpleDataSource=DEBUG
log4j.logger.com.ibatis.common.jdbc.ScriptRunner=DEBUG
log4j.logger.com.ibatis.sqlmap.engine.impl.SqlMapClientDelegate=DEBUG
log4j.logger.java.sql.Connection=DEBUG
log4j.logger.java.sql.Statement=DEBUG
log4j.logger.java.sql.PreparedStatement=DEBUG

iBatis的基本使用的更多相关文章

  1. 值得注意的ibatis动态sql语法格式

    一.Ibatis常用动态sql语法,简单粗暴用一例子 <select id="iBatisSelectList" parameterClass="java.util ...

  2. org.apache.ibatis.binding.BindingException: Invalid bound statement (not found):

    org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): da.huying.usermanag ...

  3. [入门级] visual studio 2010 mvc4开发,用ibatis作为数据库访问媒介(一)

    [入门级] visual studio 2010 mvc4开发,用ibatis作为数据库访问媒介(一) Date  周二 06 一月 2015 By 钟谢伟 Tags mvc4 / asp.net 示 ...

  4. Spring+ibatis动态管理数据源

    Spring动态配置多数据源,即在大型应用中对数据进行切分,并且采用多个数据库实例进行管理,这样可以有效提高系统的水平伸缩性.而这样的方案就会不同于常见的单一数据实例的方案,这就要程序在运行时根据当时 ...

  5. iBatis.net 循环iterate,没有foreach

    3.9.4. Iterate Element This tag will iterate over a collection and repeat the body content for each ...

  6. ibatis 轻松入门

    1.总中的配置文件 <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE sqlMapConfig ...

  7. IBatis.Net使用总结(四)-- IBatis 调用存储过程

    IBatis 调用存储过程 http://www.cnblogs.com/jeffwongishandsome/archive/2010/01/10/1543219.html http://www.c ...

  8. MyBatis-Exception:org.apache.ibatis.exceptions.PersistenceException

    错误信息如下: HTTP Status 500 - org.mybatis.spring.MyBatisSystemException: nested exception is org.apache. ...

  9. Exception:HTTP Status 500 - org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)

    主要错误信息如下: HTTP Status 500 - org.apache.ibatis.binding.BindingException: Invalid bound statement (not ...

  10. ibatis 和 mybatis

    ibatis 在daoImpl 层 继承 SqlMapClientDaoSupport  实现 dao 层的接口. this.getSqlMapClientTemplate().queryForObj ...

随机推荐

  1. js中面向对象(创建对象的几种方式)

    1.面向对象编程(OOP)的特点: 抽象:抓住核心问题 封装:只能通过对象来访问方法 继承:从已有的对象下继承出新的对象 多态:多对象的不同形态 一.创建对象的几种方式 javascript 创建对象 ...

  2. EpiiServer 更快捷更方便的php+nginx环境定制化方案

    EpiiServer是什么 更快捷更方便的php+nginx多应用部署环境. github仓库首页 https://github.com/epaii/epii-server gitee仓库 https ...

  3. mysql 常用函数,基本使用

    1:选中排除表1 连接表2 表3 获取选中表1中部分选中表3 的部分 并且设置选中状态select t1.*,if(t2中t3id=t1.id,1,0)as checked from t1 lefet ...

  4. hive的load命令

    Hive Load语句不会在加载数据的时候做任何转换工作,而是纯粹的把数据文件复制/移动到Hive表对应的地址. 语法 LOAD DATA [LOCAL] INPATH 'filepath' [OVE ...

  5. mysql根据二进制日志恢复数据/公司事故实战经验

    根据二进制日志恢复 目的:恢复数据,根据二进制日志将数据恢复到今天任意时刻 增量恢复,回滚恢复 如果有备份好的数据,将备份好的数据导入新数据库时,会随着产生二进制日志 先准备一台初始化的数据库 mys ...

  6. python中的字符串(str)操作

    字符串是python中数据类型.一般就单引号(‘’)或双引号(“”)引起来的内容就是字符串. 例如:下面两个都是定义字符串 str1 = "hello world" str2 = ...

  7. (译)JavaScript 中的正则表达式(RegEx)实操——快速掌握正则表达式,伴有随手可练的例子————(翻译未完待续)

    (原文:https://blog.bitsrc.io/a-beginners-guide-to-regular-expressions-regex-in-javascript-9c58feb27eb4 ...

  8. hadoop jar x.jar 执行过程

    hadoop jar  x.jar  执行过程 Yarn框架执行内容 1,job.waitforcompletion() 启动 Runjar 进程  -> Resourcemanage申请一个j ...

  9. Yearning和inception搭建MySQL审核平台

    前言 采用开源Yearning和inception开源软件,搭建用于MYSQL审核及线上MYSQL语句更新的审核平台. 功能说明 Yearning: 基于Vue.js与Django的整套mysql-s ...

  10. LINQ查询操作符

    ·First - 返回集合中的第一个元素:不延迟 ·FirstOrDefault - 返回集合中的第一个元素(如果没有则返回默认值):不延迟 ·Last - 返回集合中的最后一个元素:不延迟 ·Las ...