點滴

          BlogJava 首頁 新隨筆 聯(lián)系 聚合 管理
            7 Posts :: 0 Stories :: 1 Comments :: 0 Trackbacks

          2008年11月19日 #

          關(guān)于spring事務管理以及異常處理的帖子,本論壇爭論頗多,各有各的測試代碼,也各有各的測試結(jié)果,
          不知道是spring版本的不同還是各測試的例子的不同而導致測試結(jié)果出現(xiàn)差異.
          本人也很想弄清楚spring是如何對Service進行事務管理的,并且還去看了一下spring框架關(guān)于事務管理幾個相關(guān)類的源碼,可惜由于本人功力有限,只看懂了皮毛.
          既然源代碼看不懂,那么只有運用例子進行測試,雖然笨了點,不過管是白貓還是黑貓,能捉老鼠就是好貓.:)
          為引起不必要的爭論,本帖子只針對本案例的測試結(jié)果進行小結(jié),并保證此測試代碼在本人的運行環(huán)境絕對正確.

          開發(fā)環(huán)境:
          OS:windows 2003 Server
          Web Server: jakarta-tomcat-5.0.28
          DataBase Server: MS SQL Server 2000 (打了SP3補丁)
          IDE:  Eclipse 3.2.0+MyEclipse 5.0GA

          測試案例系統(tǒng)結(jié)構(gòu):
          web層<---->Service層<---->DAO層

          web層使用struts 1.1,DAO使用的spring的JDBC,spring版本1.2

          數(shù)據(jù)庫中有兩張表:
          student1和Student2,表結(jié)構(gòu)相同:id,name,address.其中id為主鍵且為自增長型.
          student1表中有一條記錄:
          Java代碼 
          1.    id  name       address 
          2.    1   xiaoming    wuhan 
          3.     
          4.    student2表中記錄為空 


          測試情形一:
          web層捕獲異常并處理,DAO層不捕獲異常,Service也不捕獲異常.

          Service層接口:
          Java代碼 
          1.    public interface StudentManagerService { 
          2.       
          3.        public void  bus_method(); 
          4.    } 


          DAO層接口
          Java代碼 
          1.    public interface StudentDAO { 
          2.       
          3.        public void  deleteStudent1(); 
          4.        public void  insertStudent2(); 
          5.    } 


          StudentDAO接口的實現(xiàn):
          Java代碼 
          1.    public class StudentDAOImp extends JdbcDaoSupport implements StudentDAO{ 
          2.         //刪除student1表中的id=1的記錄 
          3.         public void  deleteStudent1(){ 
          4.         JdbcTemplate jt=this.getJdbcTemplate(); 
          5.         jt.update("delete from student1 where id=1");      
          6.       } 
          7.          
          8.         //將student1表中刪除的記錄插入到student2中,但是此方法實現(xiàn)有錯,因為 
          9.       //id字段設(shè)置為自增長的,所以在插入記錄時我們不能指定值 
          10.          public void  insertStudent2(){ 
          11.           JdbcTemplate jt=this.getJdbcTemplate(); 
          12.                String arg[]=new String[3]; 
          13.           arg[0]="1"; 
          14.                arg[1]="xiaoming"; 
          15.           arg[2]="wuhan"; 
          16.                jt.update("insert student2(id,name,address) values(?,?,?)",arg); 
          17.         } 
          18.     
          19.    }  


          StudentManagerService 接口的實現(xiàn):
          Java代碼 
          1.    public class StudentManagerServiceImp implements StudentManagerService{ 
          2.      private StudentDAO  stdDAO; 
          3.      
          4.      public void setStdDAO(StudentDAO   stdDAO){ 
          5.         this.stdDAO=stdDAO; 
          6.      } 
          7.        
          8.      //此方法為事務型的:刪除student1中的記錄成功且插入student2的記錄也成功, 
          9.     //如果insertStudent2()方法執(zhí)行失敗,那么deleteStudent1()方法也應該會失敗 
          10.      public void  bus_method(){ 
          11.        this.stdDAO.deleteStudent1(); 
          12.        this.stdDAO.insertStudent2(); 
          13.      } 
          14.       
          15.    }  



          web層:
          三個jsp,一個action:
          index.jsp ==>首頁面.上面僅僅有一個超鏈接<a herf="test.do">執(zhí)行</a>
          chenggong.jsp ==>Service執(zhí)行成功后轉(zhuǎn)向的JSP頁面
          shibai.jsp ====>Service執(zhí)行失敗后轉(zhuǎn)向的JSP頁面

          action實現(xiàn):
          Java代碼 
          1.    public class StudentManagerAction  extends  Action{ 
          2.     
          3.         public ActionForward execute(ActionMapping mapping, ActionForm form, 
          4.        HttpServletRequest request, HttpServletResponse response) { 
          5.             try{ 
          6.                 WebApplicationContext appContext=WebApplicationContextUtils.  
          7.                      getWebApplicationContext(this.getServlet().getServletContext()); 
          8.            StudentManagerService stdm=(StudentManagerService)appContext. 
          9.                                            getBean("stdServiceManager"); 
          10.                stdm.bus_method(); 
          11.                return mapping.findForward("chenggong"); 
          12.         } 
          13.         catch(DataAccessException e){ 
          14.            System.err.println("action execute service exception!"); 
          15.            return mapping.findForward("shibai"); 
          16.          } 
          17.     
          18.        } 
          19.    } 



          配置文件:

          web.xml
          Java代碼 
          1.    <?xml version="1.0" encoding="UTF-8"?> 
          2.    <web-app xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" version="2.4" xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee   http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"> 
          3.      <context-param> 
          4.        <param-name>log4jConfigLocation</param-name> 
          5.        <param-value>/WEB-INF/log4j.properties</param-value> 
          6.      </context-param> 
          7.      <context-param> 
          8.        <param-name>contextConfigLocation</param-name> 
          9.        <param-value>/WEB-INF/applicationContext.xml</param-value> 
          10.      </context-param> 
          11.      <listener> 
          12.        <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class> 
          13.      </listener> 
          14.      <listener> 
          15.        <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> 
          16.      </listener> 
          17.      <servlet> 
          18.        <servlet-name>action</servlet-name> 
          19.        <servlet-class>org.apache.struts.action.ActionServlet</servlet-class> 
          20.        <init-param> 
          21.          <param-name>config</param-name> 
          22.          <param-value>/WEB-INF/struts-config.xml</param-value> 
          23.        </init-param> 
          24.        <init-param> 
          25.          <param-name>debug</param-name> 
          26.          <param-value>3</param-value> 
          27.        </init-param> 
          28.        <init-param> 
          29.          <param-name>detail</param-name> 
          30.          <param-value>3</param-value> 
          31.        </init-param> 
          32.        <load-on-startup>0</load-on-startup> 
          33.      </servlet> 
          34.      <servlet-mapping> 
          35.        <servlet-name>action</servlet-name> 
          36.        <url-pattern>*.do</url-pattern> 
          37.      </servlet-mapping> 
          38.    </web-app> 


          sturts-config.xml
          Java代碼 
          1.    <struts-config> 
          2.      <action-mappings > 
          3.        <action  input="/index.jsp"  path="/test"  type="test.StudentManagerAction   > 
          4.          <forward name="chenggong" path="/chenggong.jsp" /> 
          5.          <forward name="shibai" path="/shibai.jsp" /> 
          6.        </action> 
          7.      </action-mappings> 
          8.      <message-resources parameter="test.ApplicationResources" /> 
          9.    </struts-config> 



          applicationContext.xml
          Java代碼 
          1.    <?xml version="1.0" encoding="UTF-8"?> 
          2.    <!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/spring-beans.dtd"> 
          3.    <beans> 
          4.        <bean id="dataSource" 
          5.          class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close" > 
          6.          <property name="driverClassName" value="com.microsoft.jdbc.sqlserver.SQLServerDriver"></property> 
          7.          <property name="url" value="jdbc:microsoft:sqlserver://127.0.0.1:1433;databasename=test"></property> 
          8.           <property name="username" value="sa"></property> 
          9.           <property name="password" value="sa"></property> 
          10.        </bean> 
          11.         
          12.         <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> 
          13.            <property name="dataSource" ref="dataSource"/> 
          14.         </bean> 
          15.             
          16.        <bean id="baseTxProxy" class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean"  lazy-init="true"> 
          17.            <property name="transactionManager"> 
          18.            <ref bean="transactionManager" /> 
          19.             </property> 
          20.             <property name="transactionAttributes"> 
          21.             <props> 
          22.                 <prop key="*">PROPAGATION_REQUIRED</prop> 
          23.            </props> 
          24.             </property> 
          25.        </bean> 
          26.     
          27.        <bean id="stdServiceManager"  parent="baseTxProxy" > 
          28.            <property name="target"> 
          29.                 <bean class="test.StudentManagerServiceImp">     
          30.                           <property name="stdDAO"> 
          31.                          <ref bean="stdDAO"/> 
          32.                           </property>     
          33.                      </bean>  
          34.            </property>  
          35.        </bean> 
          36.     
          37.        <bean id="stdDAO" class="test.StudentDAOImp"> 
          38.           <property name="dataSource" ref="dataSource"/> 
          39.        </bean> 
          40.    </beans> 


          運行程序:啟動服務器,并部署.進入index.jsp頁面,點擊"執(zhí)行"超鏈接"---->頁面跳向shibai.jsp
          查看控制臺:打印有:action execute service exception!
          查看數(shù)據(jù)庫: student1表中的[1 xiaoming  wuhan] 記錄仍然存在,student2表仍然為空.
          小結(jié):如果DAO層和Service不捕獲異常而在web層捕獲異常,web成功捕獲異常,spring事務管理成功!


          測試情形二:
          web層捕獲異常并處理,Service捕獲異常并處理,DAO層不捕獲異常.

          修改StudentManagerServiceImp類
          Java代碼 
          1.    public class StudentManagerServiceImp implements StudentManagerService{ 
          2.      private StudentDAO  stdDAO; 
          3.      
          4.      public void setStdDAO(StudentDAO   stdDAO){ 
          5.         this.stdDAO=stdDAO; 
          6.      } 
          7.        
          8.      //此方法為事務型的,刪除student1中的記錄成功且插入student2的記錄也成功 
          9.     //如果insertStudent2()方法執(zhí)行失敗,那么deleteStudent1()也應該會失敗 
          10.      public void  bus_method(){ 
          11.       try{ 
          12.          this.stdDAO.deleteStudent1(); 
          13.          this.stdDAO.insertStudent2(); 
          14.       } 
          15.       catch(DataAccessException de) 
          16.           System.err.println("service execute exception!"); 
          17.        } 
          18.      } 
          19.       
          20.    } 


          運行程序:啟動服務器,并部署.進入index.jsp頁面,點擊"執(zhí)行"超鏈接"---->頁面跳向chenggong.jsp
          查看控制臺:打印有:service execute exception!
          查看數(shù)據(jù)庫: student1表中的[1  xiaoming  wuhan] 記錄不存在,student2表仍然為空.
          小結(jié):如果Service捕獲異常并處理而不向外拋出,web層捕獲不到異常,spring事務管理失敗!


          測試情形(還原表中的數(shù)據(jù))三:
          web層捕獲異常,Service捕獲異常,DAO層也捕獲異常.

          修改StudentDAOImp類代碼
          Java代碼 
          1.    public class StudentDAOImp extends JdbcDaoSupport implements StudentDAO{ 
          2.         //刪除student1表中的id=1的記錄 
          3.         public void  deleteStudent1(){ 
          4.            try{ 
          5.         JdbcTemplate jt=this.getJdbcTemplate(); 
          6.         jt.update("delete from student1 where id=1"); 
          7.           } 
          8.           catch(DataAccessException e){ 
          9.             System.err.println("dao deleteStudent1 execute exception!"); 
          10.           }      
          11.       } 
          12.          
          13.         //將student1表中刪除的記錄插入到student2中,但是此方法實現(xiàn)有錯,因為 
          14.       //id字段設(shè)置為自增長的,所以在插入記錄時我們不能指定值 
          15.          public void  insertStudent2(){ 
          16.              try{ 
          17.           JdbcTemplate jt=this.getJdbcTemplate(); 
          18.                String arg[]=new String[3]; 
          19.           arg[0]="1"; 
          20.                arg[1]="xiaoming"; 
          21.           arg[2]="wuhan"; 
          22.                jt.update("insert student2(id,name,address) values(?,?,?)",arg); 
          23.             } 
          24.             catch(DataAccessException  e){ 
          25.                System.err.println("dao insertStudent2  execute exception!"); 
          26.     
          27.             } 
          28.         } 
          29.     
          30.    }  


          運行程序:啟動服務器,并部署.進入index.jsp頁面,點擊"執(zhí)行"超鏈接"---->頁面跳向chenggong.jsp
          查看控制臺:打印有:dao insertStudent2  execute exception!
          查看數(shù)據(jù)庫: student1表中的 1,xiaoming,wuhan 記錄不存在,student2表仍然為空.
          小結(jié)如果DAO的每一個方法自己捕獲異常并處理而不向外拋出,Service層捕獲不到異常,Web層同樣捕獲不到異常,spring事務管理失敗!


          測試情形四:

          還原數(shù)據(jù)庫中的數(shù)據(jù)
          還原StudentDAOImp類中的方法為測試情形一中的實現(xiàn)
          web層捕獲異常Service拋出的自定義異常StudentManagerException
          Service捕獲DataAccessException并拋出StudentManagerException,
          StudentManagerException為DataAccessException的子類
          DAO層不捕獲異常

          修改StudentManagerServiceImp類的實現(xiàn):
          Java代碼 
          1.    public class StudentManagerServiceImp implements StudentManagerService{ 
          2.      private StudentDAO  stdDAO; 
          3.      
          4.      public void setStdDAO(StudentDAO   stdDAO){ 
          5.         this.stdDAO=stdDAO; 
          6.      } 
          7.        
          8.      //此方法為事務型的,刪除student1中的記錄成功且插入student2的記錄也成功 
          9.     //如果insertStudent2()方法執(zhí)行失敗,那么deleteStudent1()也應該會失敗 
          10.      public void  bus_method() throws StudentManagerException{ 
          11.       try{ 
          12.          this.stdDAO.deleteStudent1(); 
          13.          this.stdDAO.insertStudent2(); 
          14.       } 
          15.       catch(DataAccessException de) 
          16.           System.err.println("service execute exception!"); 
          17.         throw new StudentManagerException();//StudentManagerException類繼承DataAcce                          //ssException異常 
          18.        } 
          19.      } 
          20.    } 



          修改StudentManagerAction 
          Java代碼 
          1.    public class StudentManagerAction  extends  Action{ 
          2.     
          3.         public ActionForward execute(ActionMapping mapping, ActionForm form, 
          4.        HttpServletRequest request, HttpServletResponse response) { 
          5.             try{ 
          6.                 WebApplicationContext appContext=WebApplicationContextUtils.  
          7.                      getWebApplicationContext(this.getServlet().getServletContext()); 
          8.            StudentManagerService stdm=(StudentManagerService)appContext. 
          9.                                            getBean("stdServiceManager"); 
          10.                stdm.bus_method(); 
          11.                return mapping.findForward("chenggong"); 
          12.         } 
          13.         catch(StudentManagerException e){ 
          14.            System.err.println("action execute service exception!"); 
          15.            return mapping.findForward("shibai"); 
          16.          } 
          17.     
          18.        } 
          19.    } 

          運行程序:啟動服務器,并部署.進入index.jsp頁面,點擊"執(zhí)行"超鏈接"---->頁面跳向shibai.jsp
          查看控制臺:打印有:service execute exception!
          action execute service exception!
          查看數(shù)據(jù)庫: student1表中的 [1,xiaoming,wuhan] 記錄仍然存在,student2表仍然為空.
          小結(jié)如果DAO的每一個方法不捕獲異常,Service層捕獲DataAccessException異常并拋出自己定義異常(自定義異常為DataAccessException的子類),Web層可以捕獲到異常,spring事務管理成功!



          結(jié)合源碼總結(jié):
          1.spring在進行聲明時事務管理時,通過捕獲Service層方法的DataAccessException來提交和回滾事務的,而Service層方法的DataAccessException又是來自調(diào)用DAO層方法所產(chǎn)生的異常.

          2.我們一般在寫DAO層代碼時,如果繼承JdbcDaoSupport 類,并使用此類所實現(xiàn)的JdbcTemplate來執(zhí)行數(shù)據(jù)庫操作,此類會自動把低層的SQLException轉(zhuǎn)化成 DataAccessException以及DataAccessException
          的子類.

          3.一般在Service層我們可以自己捕獲DAO方法所產(chǎn)成的DataAccessException,然后再拋出一個業(yè)務方法有意義的異常 (ps:此異常最好繼承DataAccessException),然后在Web層捕獲,這樣我們就可以手動編碼的靈活實現(xiàn)通過業(yè)務方法執(zhí)行的成功和失敗 來向用戶轉(zhuǎn)發(fā)不同的頁面.

          posted @ 2008-12-15 23:01 developer 閱讀(364) | 評論 (0)編輯 收藏

          Java編程語言和JDBC開發(fā)的程序是可以跨平臺運行的,并且是不受供應商限制的.

          4.1 JDBC的設(shè)計

          JDBC由兩層組成,上面一層是JDBC API,負責與JDBC管理器驅(qū)動程序API進行通信,將各個不同的SQL語句發(fā)送給它;該管理器(對程序員是透明的)再與實際連接到數(shù)據(jù)庫的各個第三方驅(qū)動程序進行通信,并且返回查詢的信息,或者執(zhí)行由查詢規(guī)定的操作.

          JDBC驅(qū)動程序分為以下幾種類型:

          類型1驅(qū)動程序

          負責將JDBC轉(zhuǎn)換為ODBC,并且使用一個ODBC驅(qū)動程序與數(shù)據(jù)庫進行通信

          類型2驅(qū)動程序

          部分使用Java編程語言編寫的和部分使用本機代碼編寫的驅(qū)動程序,用于與數(shù)據(jù)庫的客戶機API進行通信

          類型3驅(qū)動程序

          純粹的Java客戶程序庫,它使用跨數(shù)據(jù)庫協(xié)議,將數(shù)據(jù)庫訪問請求傳輸給服務器組件,然后該服務器組件將訪問請求轉(zhuǎn)換成特定的數(shù)據(jù)庫協(xié)議

          類型4驅(qū)動程序

          純粹的Java,用于JDBC訪問請求直接轉(zhuǎn)換成特定數(shù)據(jù)庫協(xié)議

          4.2 結(jié)構(gòu)化查詢語言

          JDBC是個到SQL(結(jié)構(gòu)化查詢語言)的接口,SQL實際上是與所有最新型的關(guān)系數(shù)據(jù)庫之間的接口.

          4.3 安裝JDBC

          建議最好不要使用Java2 SDK配備的JDBC/ODBC橋接器驅(qū)動程序,更加反對將該驅(qū)動程序用于Access這樣的桌面數(shù)據(jù)庫.

          4.4 JDBC編程的基本概念

          1. 數(shù)據(jù)庫URL

          語法: jdbc:subprotocol name:other stuff

          其中subprotocol特定驅(qū)動程序, other stuff參數(shù)的格式要根據(jù)它使用的子協(xié)議而定.

          2. 建立連接

          Class.forName(驅(qū)動程序類); 注冊驅(qū)動程序

          String url = …;

          String username = …;

          String password = …;

          Connetion conn = DriverManager.getConnection(url, username, password);

          讀取屬性文件建立連接

          Properties props = new Properties();

          FileInputStream in = new FileInputStream(“database.properties”);

          props.load(in);

          in.close();

          String drivers = props.getProperty(“jdbc.drivers”);

          String url = props.getProperty(“jdbc.drivers”);

          String username = props.getProperty(“jdbc.username”);

          String password = props.getProperty(“jdbc.password”);

          Connetion conn = DriverManager.getConnection(url, username, password);

          3. 執(zhí)行SQL命令

          Statement stat = conn.createStatement();

          String sql = …;

          ResultSet rs = stat.executeQuery(sql);/stat.executeUpdate(sql);

          while(rs.next()){

          }

          4. 高級SQL類型

          Blob b=resultSet.getBlob(1);
          InputStream bin=b.getBinaryStryeam();
          Clob c=resultSet.getClob(2);
          Reader cReader=c.getCharacterStream();

          寫入:

          FileInputStream fis=new FileInputStream(f,Connection conn);
          byte[] buffer=new byte[1024];
          data=null;
          int sept=0;int len=0;

          while((sept=fis.read(buffer))!=-1){
          if(data==null){
          len=sept;
          data=buffer;
          }else{
          byte[] temp;
          int tempLength;
          tempLength=len+sept;
          temp=new byte[tempLength];
          data=temp;
          len=tempLength;
          }
          if(len!=data.length()){
          byte temp=new byte[len];
          data=temp;
          }
          }
          String sql="insert into fileData (filename,blobData) value(?,?)";
          PreparedStatement ps=conn.prepareStatement(sql);
          ps.setString(1,f.getName());
          ps.setObject(2,data);
          ps.executeUpdate();

          讀出:

          try {

          Clob c=resultSet.getClob(2);

          Reader reader=c.getCharacterStream():

          if (reader == null) {

          return null;

          }

          StringBuffer sb = new StringBuffer();

          char[] charbuf = new char[4096];

          for (int i = reader.read(charbuf); i > 0; i = reader.read(charbuf)) {
          sb.append(charbuf, 0, i);

          }

          return sb.toString();

          } catch (Exception e) {

          return "";

          }

          4.5 執(zhí)行查詢操作

          采用宿主變量方式:

          String userId = 1;

          String sql = “select * form user where user_id=?”;

          PreparedStatement pStat = conn.prepareStatement(sql);

          pStat.setString(1,userId);

          ResultSet rs = pStat.executeQuery();

          4.6 可滾動的和可更新的結(jié)果集

          1. 可滾動的結(jié)果集

          Statement stat = conn.createStatement(type,concurrency);

          PreparedStatement stat = conn.prepareStatement(command,type, concurrency);

          其中

          Type包括:

          ResultSet.TYPE_FORWARD_ONLY 不能滾動

          ResultSet.TYPE_SCROLL_INSENSITIVE 可以滾動,但變化不敏感

          ResultSet.TYPE_SCROLL_SENSITIVE 可以滾動,但變化敏感

          Concurrency包括:

          ResultSet.CONCUR_READ_ONLY 不能更新

          ResultSet.CONCUR_UPDATABLE 可以更新

          常用方法:

          rs.previous() 滾動結(jié)果集

          rs.relative(n) 將光標向后或向前移動n

          rs.absolute(n) 將光標設(shè)置到某個特定的行號上

          rs.getRow() 獲得當前的行號

          2. 可更新的結(jié)果集

          常用方法:

          rs.getConcurrency() 查看結(jié)果集是否可更新

          rs.updateXxx() 只能用于修改行的值,不能修改數(shù)據(jù)庫

          rs.updateRow() 將當前行中所有信息更新發(fā)送給數(shù)據(jù)庫

          rs.cancelRowUpdates() 撤銷對當前行的更新

          rs.moveToInsertRow() 將光標移到一個特定的位置

          rs.insertRow() 將該新行傳遞給數(shù)據(jù)庫

          rs.moveToCurrentRow() 將光標移回之前位置

          rs.deleteRow() 刪除光標下的行

          例子:

          rs. moveToInsertRow();

          rs.updateString(“Title”,title);

          rs.updateString(“Isbn”,isbn);

          rs.insertRow();

          rs.moveToCurrentRow();

          4.7 元數(shù)據(jù)

          元數(shù)據(jù)是在SQL中用于描述數(shù)據(jù)庫或者它的各個部分之一的數(shù)據(jù);分為關(guān)于數(shù)據(jù)庫的元數(shù)據(jù)和關(guān)于結(jié)構(gòu)集合的元數(shù)據(jù).

          DatabaseMetaData conn.getMetaData() 用于提供關(guān)于數(shù)據(jù)庫的元數(shù)據(jù)

          ResultSetMetaData rs.getMetaData() 用于提供關(guān)于結(jié)構(gòu)集合的元數(shù)據(jù)

          4.8 事務

          如果將各個更新命令組合成一個事務,可以實現(xiàn)數(shù)據(jù)庫數(shù)據(jù)的完整性;在提交事務時,如果在它中間某個位置上運行失敗,它可以執(zhí)行回退操作,并且該數(shù)據(jù)庫將自動撤銷提交事務以來進行的所有更新及所產(chǎn)生的影響.

          在默認情況下,數(shù)據(jù)庫連接處于自動提交方式,并且每個SQL命令一旦被執(zhí)行,便被提交給該數(shù)據(jù)庫.一旦命令被提交,就無法進行回退操作.

          批量更新: 一序列命令將作為一個批量來集中和提交,命令不包括Select查詢.

          String sql = …;

          stat.addBatch(sql);

          while(…){

          sql = …

          stat.addBatch(sql);

          }

          stat.executeBatch();

          4.9    高級連接管理

          在企業(yè)級環(huán)境中部署JDBC應用程序時,數(shù)據(jù)庫連接的管理納入了JNDI(Java命令與目錄接口)之中.一個目錄負責管理整個企業(yè)中的數(shù)據(jù)源的位置.使用目錄后,就可以對用戶名、口令、數(shù)據(jù)庫名字和JDBC URL實施集中管理.

          Context jndi = …;

          DataSource source = (DataSource)jndi.lookup(“jdbc/corejava”);

          Connection conn = source.getConnection(username,password);

           

          posted @ 2008-11-20 13:31 developer 閱讀(344) | 評論 (0)編輯 收藏

          1,先檢測環(huán)境、如果有不符合的組建到K3 SOURCE這個文件夾下安裝好,但是mdac這個東西在XP下
          好像總提示版本不兼容,就這樣過去,不用管它,在安裝其他組件的時候在跳過那打鉤直接安裝
          2,先安裝數(shù)據(jù)庫服務部件
          3,安裝中間層,安裝完畢后提示是否安裝行業(yè)版,選擇不安裝,這個東西是干啥的目前未知
          然后它繼續(xù)注冊組件,要稍微等上一會,安裝完畢后提示立即注冊中間層,把那個勾挑掉,就代表
          不立即注冊中間層,然后點擊完成。
          4,安裝客戶端,選擇完整安裝,然后還問你是否安裝行業(yè)版,選擇不安裝,之后又開始注冊組件。完畢后重新啟動機器。
          5,上面三項都安裝完畢后,開始,金蝶-》中間層服務部件-》系統(tǒng)工具-》注冊中間層,時間比較長
          6,引回帳套,在帳套管理里面點擊恢復,找到需要引回的帳套,后綴名是DBB,然后起一個帳套號,比如001,確定就可以了
          比較慢,要是有兩個帳套就引回兩個帳套
          7,然后點擊K3主控制臺會發(fā)現(xiàn)需要輸入用戶名和密碼,然后用戶名就是administrator,但是此時
          由于你不知道密碼,因此要到系統(tǒng)管理里面清楚一下密碼,金蝶-》中間層服務部件-》帳套管理,
          點擊帳套名,然后點擊“用戶”,然后清楚密碼
          8,關(guān)閉相應的K3服務進程,然后打狗,類型選擇supperpro,然后版本選擇10.1,然后選擇
          “加密單元數(shù)據(jù)設(shè)置”,把所有的訪問碼改為1,安裝,就可以了。
          posted @ 2008-11-19 11:35 developer 閱讀(1571) | 評論 (1)編輯 收藏

          主站蜘蛛池模板: 天柱县| 凌源市| 鲁甸县| 张家界市| 华阴市| 湖北省| 永靖县| 封开县| 壶关县| 武定县| 河源市| 尖扎县| 和平区| 湘阴县| 拉萨市| 德惠市| 青浦区| 松阳县| 溧阳市| 新竹市| 定边县| 清水县| 城固县| 平度市| 哈巴河县| 疏勒县| 竹山县| 澎湖县| 南乐县| 桦川县| 屏东县| 沂南县| 清徐县| 雷州市| 运城市| 濮阳市| 上饶市| 梁平县| 岐山县| 于田县| 奉贤区|