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

            逛奔的蝸牛

            我不聰明,但我會很努力

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

            簡介: 

            jar包

            普通的javaBean: domain.User

            與bean對應的SQL映射文件: maps/User.xml

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

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


            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. 類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">

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

                <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訪問數據庫:

            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, 獲得一個SqlMapClient對象

                    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 逛奔的蝸牛 閱讀(5450) 評論(2)  編輯 收藏 引用 所屬分類: Java

            評論

            # re: Java:iBatis簡單入門 2010-10-24 13:54 逛奔的蝸牛
            特點:動態SQL放置在xml文件中,可以隨時修改.  回復  更多評論
              

            # re: Java:iBatis簡單入門 2010-10-24 14:11 逛奔的蝸牛
            iBatis在以下情況中更顯得適合,這時Hibernate甚至毫無辦法:
            1. 系統的部分或全部數據來自現有數據庫,處于安全考慮,只對開發團隊提供幾
            條 Select SQL(或存儲過程)以獲取所需數據,具體的表結構不予公開。

            2. 開發規范中要求,所有牽涉到業務邏輯部分的數據庫操作,必須在數據庫層由 存儲過程實現(就筆者工作所面向的金融行業而言,工商銀行、中國銀行、交
            通銀行,都在開發規范中嚴格指定)

            3. 系統數據處理量巨大,性能要求極為苛刻,這往往意味著我們必須通過經過高
            度優化的 SQL 語句(或存儲過程)才能達到系統性能設計指標。  回復  更多評論
              

            国产成人综合久久综合 | 精品久久人人妻人人做精品| 久久超乳爆乳中文字幕| 久久精品99久久香蕉国产色戒| 久久精品国产亚洲AV嫖农村妇女| 青青草原综合久久大伊人精品| 久久亚洲国产成人影院网站| 亚洲人成伊人成综合网久久久| 久久青青草原精品影院| 久久精品免费全国观看国产| 九九久久自然熟的香蕉图片| 久久九九久精品国产免费直播| 亚洲国产另类久久久精品黑人| 精品久久久久久国产牛牛app | 亚洲午夜福利精品久久| 久久亚洲精精品中文字幕| 国产精品99久久久久久猫咪| 久久天天躁狠狠躁夜夜躁2014| 国产成人精品久久亚洲高清不卡 | 久久精品国产亚洲AV忘忧草18| 国产女人aaa级久久久级| 久久人人爽人人爽人人AV| 色综合合久久天天给综看| 国产精品久久久久影院嫩草| 综合网日日天干夜夜久久| 久久久久国产日韩精品网站| 99国产精品久久| 久久99精品久久久久久久久久| 久久久久高潮综合影院| 婷婷久久综合九色综合绿巨人| 9999国产精品欧美久久久久久| 99精品久久精品| 国产精品99久久精品| 国产精品99久久免费观看| 久久婷婷五月综合国产尤物app| 香蕉99久久国产综合精品宅男自 | 久久久久国产日韩精品网站| 亚洲AV无码久久精品狠狠爱浪潮| 欧美日韩精品久久久久| 久久人人爽人人澡人人高潮AV| 国产三级观看久久|