青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

逛奔的蝸牛

我不聰明,但我會(huì)很努力

   ::  :: 新隨筆 ::  ::  :: 管理 ::

簡(jiǎn)介: 

jar包

普通的javaBean: domain.User

與bean對(duì)應(yīng)的SQL映射文件: maps/User.xml

iBatis需要的配置文件: SqlMapConfig.xml

加載iBatis配置文件SqlMapConfig.xml是相對(duì)于class loader所在目錄的相對(duì)路徑. 如在Web程序中,例如Tomcat下時(shí),class loader所對(duì)應(yīng)的目錄是WEB-INF/classes目錄. 如在普通的單機(jī)運(yùn)用程序中,class loader對(duì)應(yīng)的目錄是編譯生成class的bin目錄(把src和bin分開(kāi)存放時(shí)).


1. 需要的jar包(暫且先用下面的,可到http://www.javaeye.com/topic/26433示例中一起下載):

commons-dbcp.jar, commons-logging-api.jar, commons-logging.jar, commons-pool.jar, 

hsqldb.jar, ibatis-common-2.jar, ibatis-dao-2.jar, ibatis-sqlmap-2.jar,

mysql-connector-java-3.1.12-bin.jar


2. 類(lèi)User:

package domain;


public class User {

    private int id;

    private String name;


    public User() {}


    public User(String name) { this(0, name); }


    public User(int id, String name) {

        this.id = id;

        this.name = name;

    }


    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; }


    @Override

    public String toString() { return "ID: " + id + ", Name: " + name; }

}

 


3. User.xml映射文件:

<?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="User">

    <!-- 設(shè)置本映射中的別名: 方便使用 -->

    <typeAlias alias="user" type="domain.User" />

    <typeAlias alias="string" type="java.lang.String" />

    <typeAlias alias="integer" type="java.lang.Integer" />

    

    <!-- 增刪查改的Statement配置 -->

    <select id="getAllUsers" resultClass="user"><![CDATA[

        SELECT id, name FROM user ORDER BY id

    ]]></select>

    

    <select id="getUser" resultClass="user" parameterClass="integer"><![CDATA[

        SELECT id, name FROM user WHERE id=#id#

    ]]></select>

    

    <update id="updateUser" parameterClass="user"><![CDATA[

        UPDATE user SET name=#name# WHERE id=#id#

    ]]></update>

    

    <insert id="insertUser" parameterClass="user"><![CDATA[

        INSERT INTO user (name) VALUES (#name#)

    ]]></insert>

    

    <delete id="deleteUser" parameterClass="integer"><![CDATA[

        DELETE FROM user WHERE id=#id#

    ]]></delete>

</sqlMap>

 


4. iBatis需要的配置文件:

<?xml version="1.0" encoding="UTF-8" ?>

<!DOCTYPE sqlMapConfig 

    PUBLIC "-//iBATIS.com//DTD SQL Map Config 2.0//EN" 

    "http://www.ibatis.com/dtd/sql-map-config-2.dtd">


<sqlMapConfig>

    <settings cacheModelsEnabled="true" enhancementEnabled="true"

        lazyLoadingEnabled="true" errorTracingEnabled="true" maxRequests="32"

        maxSessions="10" maxTransactions="5" useStatementNamespaces="false" />


    <transactionManager type="JDBC">

        <dataSource type="SIMPLE">

            <!-- JDBC連接需要的配置 -->

            <property name="JDBC.Driver" value="com.mysql.jdbc.Driver" />

            <property name="JDBC.ConnectionURL"

                value="jdbc:mysql://localhost:3306/test?useUnicode=true&amp;characterEncoding=UTF-8" />

            <property name="JDBC.Username" value="root" />

            <property name="JDBC.Password" value="" />

            

            <!-- 連接池配置 -->

            <property name="Pool.MaximumActiveConnections" value="10" />

            <property name="Pool.MaximumIdleConnections" value="5" />

            <property name="Pool.MaximumCheckoutTime" value="120000" />

            <property name="Pool.TimeToWait" value="500" />

            <property name="Pool.PingQuery" value="select 1 from sample" />

            <property name="Pool.PingEnabled" value="false" />

            <property name="Pool.PingConnectionsOlderThan" value="1" />

            <property name="Pool.PingConnectionsNotUsedFor" value="1" />

        </dataSource>

    </transactionManager>


    <!-- 映射文件 -->

    <sqlMap resource="maps/User.xml" />

</sqlMapConfig>

 


5. 使用iBatis訪問(wèn)數(shù)據(jù)庫(kù):

package test;


import java.io.IOException;

import java.io.Reader;

import java.util.List;


import com.ibatis.common.resources.Resources;

import com.ibatis.sqlmap.client.SqlMapClient;

import com.ibatis.sqlmap.client.SqlMapClientBuilder;


import domain.User;


public class Test {

    public static enum Mode {

        INSERT, UPDATE, DELETE

    }


    public void update(Object arg, Mode mode) {

        SqlMapClient smc = null;

        

        try {

            smc = getSqlMapClient();

            smc.startTransaction();


            switch (mode) {

            case INSERT: smc.insert("insertUser", arg); break;

            case UPDATE: smc.update("updateUser", arg); break;

            case DELETE: smc.delete("deleteUser", arg); break;

            }

            smc.commitTransaction();

        } catch (Exception e) {

            e.printStackTrace();

        } finally {

            endTransaction(smc);

        }

    }


    public void listUsers() {

        SqlMapClient smc = null;


        try {

            smc = getSqlMapClient();

            smc.startTransaction();

            List users = smc.queryForList("getAllUsers", null);

            System.out.println(users);

            smc.commitTransaction();

        } catch (Exception e) {

            e.printStackTrace();

        } finally {

            endTransaction(smc);

        }

    }


    public User selectUser(int id) {

        User user = null;

        SqlMapClient smc = null;


        try {

            smc = getSqlMapClient();

            smc.startTransaction();

            user = (User) smc.queryForObject("getUser", id);

            smc.commitTransaction();

        } catch (Exception e) {

            e.printStackTrace();

        } finally {

            endTransaction(smc);

        }


        return user;

    }


    // ////////////////////////////////////////////////////////////////////////

    // Don't care

    // ////////////////////////////////////////////////////////////////////////

    private SqlMapClient getSqlMapClient() throws IOException {

        // 初始化ibatis, 獲得一個(gè)SqlMapClient對(duì)象

        String resource = "SqlMapConfig.xml";

        Reader reader = Resources.getResourceAsReader(resource);

        return SqlMapClientBuilder.buildSqlMapClient(reader);

    }


    private void endTransaction(SqlMapClient smc) {

        if (smc == null) { return; }


        try {

            smc.endTransaction();

        } catch (Exception e2) {

            e2.printStackTrace();

        }

    }


    public static void main(String[] args) {

        Test t = new Test();

        t.listUsers();


        User user = new User("Biao");

        user = t.selectUser(7);

        user.setName("Biao 黃河");

        t.update(user, Mode.UPDATE);

        // t.update(user, Mode.INSERT);

        // t.update(Integer.valueOf(7), Mode.DELETE);

        t.listUsers();

    }

}

 


posted on 2010-10-24 13:46 逛奔的蝸牛 閱讀(5458) 評(píng)論(2)  編輯 收藏 引用 所屬分類(lèi): Java

評(píng)論

# re: Java:iBatis簡(jiǎn)單入門(mén) 2010-10-24 13:54 逛奔的蝸牛
特點(diǎn):動(dòng)態(tài)SQL放置在xml文件中,可以隨時(shí)修改.  回復(fù)  更多評(píng)論
  

# re: Java:iBatis簡(jiǎn)單入門(mén) 2010-10-24 14:11 逛奔的蝸牛
iBatis在以下情況中更顯得適合,這時(shí)Hibernate甚至毫無(wú)辦法:
1. 系統(tǒng)的部分或全部數(shù)據(jù)來(lái)自現(xiàn)有數(shù)據(jù)庫(kù),處于安全考慮,只對(duì)開(kāi)發(fā)團(tuán)隊(duì)提供幾
條 Select SQL(或存儲(chǔ)過(guò)程)以獲取所需數(shù)據(jù),具體的表結(jié)構(gòu)不予公開(kāi)。

2. 開(kāi)發(fā)規(guī)范中要求,所有牽涉到業(yè)務(wù)邏輯部分的數(shù)據(jù)庫(kù)操作,必須在數(shù)據(jù)庫(kù)層由 存儲(chǔ)過(guò)程實(shí)現(xiàn)(就筆者工作所面向的金融行業(yè)而言,工商銀行、中國(guó)銀行、交
通銀行,都在開(kāi)發(fā)規(guī)范中嚴(yán)格指定)

3. 系統(tǒng)數(shù)據(jù)處理量巨大,性能要求極為苛刻,這往往意味著我們必須通過(guò)經(jīng)過(guò)高
度優(yōu)化的 SQL 語(yǔ)句(或存儲(chǔ)過(guò)程)才能達(dá)到系統(tǒng)性能設(shè)計(jì)指標(biāo)。  回復(fù)  更多評(píng)論
  

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            一区二区不卡在线视频 午夜欧美不卡在 | 亚洲一区二区久久| 久久久久久久久岛国免费| 亚洲人永久免费| 久久国产精品久久w女人spa| 国产精品swag| 一区二区三区高清在线| 亚洲激情在线播放| 欧美a级一区二区| 亚洲韩日在线| 亚洲国产福利在线| 麻豆国产精品一区二区三区| 在线观看国产精品网站| 毛片av中文字幕一区二区| 久久国产日韩欧美| 激情五月婷婷综合| 蜜桃av一区二区三区| 久久免费99精品久久久久久| 在线成人免费观看| 免费日韩av| 欧美成人a∨高清免费观看| 亚洲欧洲久久| 亚洲精选在线| 国产精品系列在线| 久久久久久亚洲精品中文字幕| 欧美亚洲尤物久久| 影音先锋一区| 亚洲三级色网| 国产精品永久入口久久久| 久久丁香综合五月国产三级网站| 在线视频精品一区| 91久久精品一区二区别| 免费观看30秒视频久久| 麻豆精品在线观看| 日韩亚洲在线| 亚洲午夜一区二区三区| 国产日韩av一区二区| 免费看黄裸体一级大秀欧美| 欧美激情精品久久久久久黑人| 中日韩午夜理伦电影免费| 亚洲字幕一区二区| 永久91嫩草亚洲精品人人| 亚洲经典视频在线观看| 国产精品久久久久久久久果冻传媒| 欧美一区二区成人| 久久亚洲春色中文字幕久久久| 亚洲精品一品区二品区三品区| 日韩一级二级三级| 狠狠色伊人亚洲综合成人| 亚洲国产福利在线| 国产女主播一区| 亚洲国产成人久久综合| 国产日韩欧美亚洲| 亚洲黄色成人网| 国产亚洲欧美色| 亚洲久久成人| 在线播放日韩| 午夜精品福利一区二区三区av| 91久久中文| 性久久久久久久久久久久| 日韩一级黄色av| 久久久精品一区二区三区| 亚洲一本视频| 欧美高清在线观看| 久久亚洲春色中文字幕| 欧美视频亚洲视频| 欧美成人性生活| 国产日韩欧美日韩| 亚洲亚洲精品在线观看| 亚洲欧洲偷拍精品| 久久久免费精品视频| 久久爱www久久做| 欧美视频三区在线播放| 亚洲精品久久久久久久久久久久久| 一区二区三区在线高清| 亚洲欧美日韩成人| 亚洲欧美日韩国产中文| 欧美日韩国产麻豆| 亚洲国产精品t66y| 亚洲国产综合在线| 久久午夜电影网| 久久天天躁狠狠躁夜夜av| 国产情侣一区| 欧美亚洲一区二区在线观看| 久久av一区二区三区| 国产精品日日做人人爱| 亚洲线精品一区二区三区八戒| 亚洲色图在线视频| 欧美区日韩区| 亚洲美女色禁图| 亚洲日韩成人| 欧美日本亚洲韩国国产| 亚洲青涩在线| 一区二区三区高清视频在线观看| 欧美精品1区2区| aaa亚洲精品一二三区| 亚洲国产精品久久久| 亚洲国产日日夜夜| 男女激情久久| 亚洲国产精品久久久久秋霞蜜臀 | 亚洲天堂av综合网| 亚洲午夜伦理| 国产精品一区免费观看| 午夜国产精品影院在线观看| 欧美一区二区日韩| 国产亚洲一区在线播放| 久久激情五月激情| 免费不卡视频| 99精品国产福利在线观看免费| 欧美日韩国产精品一区| 亚洲神马久久| 久久久久久久网| 亚洲黄页一区| 国产精品成人在线观看| 欧美一区二区视频免费观看| 欧美成人福利视频| 一本在线高清不卡dvd | 亚洲专区欧美专区| 国产日韩精品一区二区三区在线| 久久国产乱子精品免费女 | 国产精品美女午夜av| 欧美一区二区三区成人| 你懂的视频欧美| 亚洲天天影视| 黄色成人在线| 欧美三级黄美女| 久久成人这里只有精品| 亚洲国产精品视频| 欧美一区二区成人6969| 91久久精品一区二区别| 国产精品免费看| 久久综合九色综合网站| 一本久道久久综合婷婷鲸鱼| 久久久综合激的五月天| 亚洲网站视频| 亚洲大胆女人| 国产精品一卡| 欧美精品一区二区三区四区| 午夜综合激情| 一本大道久久a久久综合婷婷 | 亚洲一区二区三区免费在线观看 | 欧美一级在线视频| 亚洲精品少妇网址| 乱中年女人伦av一区二区| 亚洲香蕉伊综合在人在线视看| 一区二区视频免费完整版观看| 欧美日韩国产高清视频| 另类综合日韩欧美亚洲| 香蕉乱码成人久久天堂爱免费| 亚洲三级免费电影| 欧美肥婆bbw| 久久乐国产精品| 久久er99精品| 欧美一区2区三区4区公司二百| 这里只有精品丝袜| 午夜久久tv| 亚洲国产高清在线| 久久岛国电影| 欧美一区二区视频网站| 一本色道久久综合亚洲精品不| 精久久久久久久久久久| 国产精品推荐精品| 欧美日本中文| 欧美理论在线播放| 欧美福利在线观看| 免费观看欧美在线视频的网站| 欧美在线一二三四区| 亚洲一区美女视频在线观看免费| 亚洲精品在线观| 亚洲三级色网| 一区二区不卡在线视频 午夜欧美不卡' | 亚洲在线播放| 亚洲影院免费观看| 在线亚洲电影| 一本一本久久a久久精品综合麻豆| 亚洲激情偷拍| 亚洲精品视频在线看| 亚洲国语精品自产拍在线观看| 亚洲成人资源网| 最新日韩在线视频| 亚洲人www| 日韩一级精品| 亚洲午夜久久久久久久久电影院| 亚洲图片欧美日产| 亚洲欧美99| 欧美影院成年免费版| 午夜精品久久久久久| 欧美一区二区成人| 久久综合狠狠| 亚洲国产婷婷| 中文日韩在线视频| 小黄鸭精品密入口导航| 久久精品盗摄| 欧美黑人在线播放| 国产精品videosex极品| 国产九九视频一区二区三区| 国产精品另类一区| 国产欧美日韩亚洲一区二区三区| 国产一区在线免费观看| 亚洲国产精品久久久久秋霞影院 |