学习来源:黑马程序员

先总结一下遇到的问题

问题1:
1,resultMap 可以不写,比如配置1
配置1:
<typeAlias alias="puser" type="com.loong.config.PUser"/>
<select id="selectAllPUser" resultClass="puser"></select>
select *
from p_user
</select> 2resultMap 写的情况下,select语句可以有两种
比如--1,--2,检索时,结果一样
<typeAlias alias="puser" type="com.loong.config.PUser"/>
<resultMap class="puser" id="puserResult">
<result property="id" column="ID"/>
<result property="name" column="NAME"/>
<result property="password" column="PASSWORD"/>
<result property="age" column="AGE"/>
</resultMap> <!-- 1. 也可以实现-->
<!-- <select id="selectAllPUser" resultClass="puser"></select> -->
<!-- 2. -->
<select id="selectAllPUser" resultMap="puserResult" >
select *
from p_user
</select>
问题2:
模糊查询有两种方法
方法1:
java:dao.selectPUserByName("test")
<select id="selectPUserByName" resultClass="puser" parameterClass="String">
select id,name,password,age
from p_user
where name like '%$name$%'
</select> 方式2
java:dao.selectPUserByName("%test%")
<select id="selectPUserByName" resultClass="puser" parameterClass="String">
select id,name,password,age
from p_user
where name like '$name$'
</select>
问题3:
如果是普通方式创建自动ID的话,通过selectKey的方式,添加ID
比如:
创建自增长语句:create sequence p_user_Sequence start with 1 increment by 1;
<insert id="insertPUserBySequence" parameterClass="PUser">
<selectKey resultClass="java.lang.String" keyProperty="id">
select p_user_Sequence.nextVal as id
from dual
</selectKey> -->
insert into p_user(id, name, password, age)
values(#id#,#name#,#password#,#age#)
</insert> 如果是特殊自增ID的话,比如
create sequence p_user_Sequence
increment by 1
start with 1
nomaxvalue
nocycle
cache 10;
create or replace trigger p_user before
insert on p_user for each row
begin
select p_user_Sequence.nextval into:New.id from dual;
end;
就不必在添加selectKey,会自动实现。
<insert id="insertPUserBySequence" parameterClass="PUser">
insert into p_user(id, name, password, age)
values(#id#,#name#,#password#,#age#)
</insert>
需要三个配置文件:
1.SqlMapConfig.xml 总配置文件
2.PUser.xml 表映射文件
3.jdbc.properties 数据库配置文件
1. 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="com/loong/config/jdbc.properties"/> <transactionManager type="JDBC">
<dataSource type="SIMPLE">
<property value="${driver}" name="JDBC.Driver"/>
<property value="${url}" name="JDBC.ConnectionURL"/>
<property value="${username}" name="JDBC.Username"/>
<property value="${password}" name="JDBC.Password"/>
</dataSource>
</transactionManager> <sqlMap resource="com/loong/config/PUser.xml"/> </sqlMapConfig>
2. PUser.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE sqlMap
PUBLIC "-//ibatis.apache.org//DTD SQL Map 2.0//EN"
"http://ibatis.apache.org/dtd/sql-map-2.dtd"> <sqlMap>
<typeAlias alias="puser" type="com.loong.config.PUser"/> <resultMap class="puser" id="puserResult">
<result property="id" column="ID"/>
<result property="name" column="NAME"/>
<result property="password" column="PASSWORD"/>
<result property="age" column="AGE"/>
</resultMap> <!-- 1. 也可以实现-->
<!-- <select id="selectAllPUser" resultClass="puser"></select> -->
<!-- 2. -->
<select id="selectAllPUser" resultMap="puserResult" >
select *
from p_user
</select> <select id="selectPUserByName" resultClass="puser" parameterClass="String">
select id,name,password,age
from p_user
<!--方式1 where name like '$name$' java dao.selectPUserByName("%test%") -->
where name like '%$name$%'
</select> <insert id="insertPUserBySequence" parameterClass="PUser"> <!-- 3.如果是下面的创建sql语句,不用加selectKey,会自动创建ID
create sequence p_user_Sequence
increment by 1
start with 1
nomaxvalue
nocycle
cache 10;
create or replace trigger p_user before
insert on p_user for each row
begin
select p_user_Sequence.nextval into:New.id from dual;
end; -->
<!-- <selectKey resultClass="java.lang.String" keyProperty="id">
select p_user_Sequence.nextVal as id
from dual
还有一种简单创建自增长语句:create sequence p_user_Sequence start with 1 increment by 1;
</selectKey> -->
insert into p_user(id, name, password, age)
values(#id#,#name#,#password#,#age#)
</insert> <update id="updatePUserById" parameterClass="puser">
update p_user
set
name=#name#,
password=#password#,
age=#age#
where id=#id#
</update> <delete id="deletePUserById" parameterClass="int">
delete from p_user
where id=#id#
</delete>
</sqlMap>
3. jdbc.properties
driver=oracle.jdbc.driver.OracleDriver
url=jdbc:oracle:thin:@127.0.0.1:1521:orcl
username=scott
password=tiger
1.对象文件PUser.java
package com.loong.config; public class PUser { public int id;
public String name;
public String password;
public int age;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
} @Override
public String toString() {
String content = "ID = " + id + " name= " + name + " password= " + password + " age= "+ age;
return content;
} } 2.接口文件IPUserDao.java
package com.loong.config; import java.util.List; public interface IPUserDao { public List<PUser> selectAllPUser(); public List<PUser> selectPUserByName(String name); public void InsertPUserbySequence(PUser puser); public void deletePUserById( int id); public void updatePUserById(PUser puser); }
3. 实现类文件IPuserDaoImpl.java
package com.loong.config; import java.io.IOException;
import java.io.Reader;
import java.sql.SQLException;
import java.util.List; import com.ibatis.sqlmap.client.SqlMapClient; public class IPuserDaoImpl implements IPUserDao { private static SqlMapClient sqlMapClient= null; static {
try {
Reader reader = com.ibatis.common.resources.Resources.
getResourceAsReader("com/loong/config/SqlMapConfig.xml"); sqlMapClient = com.ibatis.sqlmap.client.SqlMapClientBuilder.buildSqlMapClient(reader); reader.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} } //1.
@Override
public List<PUser> selectAllPUser() { List<PUser> puserList = null;
try {
puserList = sqlMapClient.queryForList("selectAllPUser");
System.out.println("ddd");
} catch (SQLException e) {
e.printStackTrace();
} return puserList;
} @Override
public List<PUser> selectPUserByName(String name) {
List<PUser> puserList = null; try {
puserList = sqlMapClient.queryForList("selectPUserByName", name);
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return puserList;
} @Override
public void InsertPUserbySequence(PUser puser) {
try {
sqlMapClient.insert("insertPUserBySequence", puser);
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} } @Override
public void deletePUserById(int id) {
try {
sqlMapClient.delete("deletePUserById",id);
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} } @Override
public void updatePUserById(PUser puser) { try {
sqlMapClient.update("updatePUserById",puser);
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} } public static void main(String[] args) {
IPUserDao dao = new IPuserDaoImpl();
//1.
/*for(PUser puser : dao.selectAllPUser()){
System.out.println(puser.toString());
}*/ //2. /* for(PUser puser : dao.selectPUserByName("%test%")){ // 对应xml-->where name like '$name$'
*/ /*for(PUser puser : dao.selectPUserByName("test")){ // 对应xml-->where name like '%$name$%'
System.out.println(puser.toString());
}*/ //2.
PUser puser = new PUser();
puser.setName("intage");
puser.setPassword("123");
puser.setAge(1); dao.InsertPUserbySequence(puser); // 3.
/*PUser puser = new PUser();
puser.setId("16");
puser.setName("ageibatis");
puser.setPassword("123");
puser.setAge("1"); dao.updatePUserById(puser);*/ //4.
/*dao.deletePUserById(12);*/ } }

ibatsi学习总结的更多相关文章

  1. 从直播编程到直播教育:LiveEdu.tv开启多元化的在线学习直播时代

    2015年9月,一个叫Livecoding.tv的网站在互联网上引起了编程界的注意.缘于Pingwest品玩的一位编辑在上网时无意中发现了这个网站,并写了一篇文章<一个比直播睡觉更奇怪的网站:直 ...

  2. Angular2学习笔记(1)

    Angular2学习笔记(1) 1. 写在前面 之前基于Electron写过一个Markdown编辑器.就其功能而言,主要功能已经实现,一些小的不影响使用的功能由于时间关系还没有完成:但就代码而言,之 ...

  3. ABP入门系列(1)——学习Abp框架之实操演练

    作为.Net工地搬砖长工一名,一直致力于挖坑(Bug)填坑(Debug),但技术却不见长进.也曾热情于新技术的学习,憧憬过成为技术大拿.从前端到后端,从bootstrap到javascript,从py ...

  4. 消息队列——RabbitMQ学习笔记

    消息队列--RabbitMQ学习笔记 1. 写在前面 昨天简单学习了一个消息队列项目--RabbitMQ,今天趁热打铁,将学到的东西记录下来. 学习的资料主要是官网给出的6个基本的消息发送/接收模型, ...

  5. js学习笔记:webpack基础入门(一)

    之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...

  6. Unity3d学习 制作地形

    这周学习了如何在unity中制作地形,就是在一个Terrain的对象上盖几座小山,在山底种几棵树,那就讲一下如何完成上述内容. 1.在新键得项目的游戏的Hierarchy目录中新键一个Terrain对 ...

  7. 《Django By Example》第四章 中文 翻译 (个人学习,渣翻)

    书籍出处:https://www.packtpub.com/web-development/django-example 原作者:Antonio Melé (译者注:祝大家新年快乐,这次带来<D ...

  8. 菜鸟Python学习笔记第一天:关于一些函数库的使用

    2017年1月3日 星期二 大一学习一门新的计算机语言真的很难,有时候连函数拼写出错查错都能查半天,没办法,谁让我英语太渣. 关于计算机语言的学习我想还是从C语言学习开始为好,Python有很多语言的 ...

  9. 多线程爬坑之路-学习多线程需要来了解哪些东西?(concurrent并发包的数据结构和线程池,Locks锁,Atomic原子类)

    前言:刚学习了一段机器学习,最近需要重构一个java项目,又赶过来看java.大多是线程代码,没办法,那时候总觉得多线程是个很难的部分很少用到,所以一直没下决定去啃,那些年留下的坑,总是得自己跳进去填 ...

随机推荐

  1. 前端css之float浮动

    浮动的准则,先找前一个块标签,在确认有否清除浮动的条件或者是距离的情况下,如果这一行能摆得下,就继续紧贴前一个标签 如果摆不下,就会另起一行 浮动只有左边和右边 如果是块标签,设置浮动,先把displ ...

  2. Django图书管理系统(单表操作)

    以下内容需要掌握: Python3 以及前端:HTML,CSS,jQuery,BootStrap,Django,JavaScript 开启Django新项目: 1,settings.py 数据库选择: ...

  3. Java垃圾回收机制概述

    总览 本文会介绍垃圾回收的以下几个方面. 为什么要垃圾回收 在哪里回收 哪些对象需要回收 怎么回收 HotSpotJVM中有哪些具体的回收器可以直接用. 在开始讲垃圾回收之前,先通过一张图快速回忆一下 ...

  4. Java中的File.separator用法

    在Windows下的路径分隔符和Linux下的路径分隔符是不一样的,当直接使用绝对路径时,跨平台会暴出“No such file or diretory”的异常. 比如说要在temp目录下建立一个te ...

  5. 北京Uber优步司机奖励政策(3月23日)

    滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...

  6. 北京Uber优步司机奖励政策(2月24日)

    滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...

  7. 【LG1393】动态逆序对

    [LG1393]动态逆序对 题面 洛谷 题解 \(CDQ\)分治,按照时间来分治 应为一个删除不能对前面的操作贡献,所以考虑一个删除操作对它后面时间的操作的贡献 用上一个答案减去次贡献即可 代码 #i ...

  8. Unity2017 经典游戏开发教程 算法分析与实现 (张帆 著)

    https://meta.box.lenovo.com/link/view/82c451b41ce34e81a4b34cb46747d3d5 第1章 熟悉Unity软件的操作 第2章 打地鼠 (已看) ...

  9. 「赛后补题」Meeting(HDU-5521)

    题意 A,B两个人分别在1和n区.每个区有若干点(区之间的点可以重复,各个区内点间的距离一致),给出区之间有联系的图以及到达所需时间.求两个人见面最短时间以及在哪个区碰面(可有多个) 分析 隐式图搜索 ...

  10. Java Swing学习笔记——创建JFrame

    创建显示一个空JFrame import javax.swing.JFrame; public class JFrameDemo extends JFrame{ public JFrameDemo() ...