<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    如果下面的連接有出現(xiàn)class沒有找到的異常,有可能是沒有加裁到驅(qū)動程序,還有一種是驅(qū)動不對。
    1、Oracle8/8i/9i數(shù)據(jù)庫(thin模式)
    Class.forName("oracle.jdbc.driver.OracleDriver").newInstance();
    String url="jdbc:oracle:thin:@localhost:1521:rcl"; //orcl為數(shù)據(jù)庫的SID
    String user="test";
    String password="test";
    Connection conn= DriverManager.getConnection(url,user,password);

    2、DB2數(shù)據(jù)庫

    Class.forName("com.ibm.db2.jdbc.app.DB2Driver ").newInstance();
    String url="jdbc:db2://localhost:5000/sample"; //sample為你的數(shù)據(jù)庫名
    String user="admin";
    String password="";
    Connection conn= DriverManager.getConnection(url,user,password);

    3、Sql Server7.0/2000數(shù)據(jù)庫

    Class.forName("com.microsoft.jdbc.sqlserver.SQLServerDriver").newInstance();
    String url="jdbc:microsoft:sqlserver://lin56:1433;DatabaseName=pubs";
    //mydb為數(shù)據(jù)庫
    String user="sa";
    String password="";
    Connection conn= DriverManager.getConnection(url,user,password);

    4、Sybase數(shù)據(jù)庫

    Class.forName("com.sybase.jdbc.SybDriver").newInstance();
    String url =" jdbcybase:Tds:localhost:5007/myDB";//myDB為你的數(shù)據(jù)庫名
    Properties sysProps = System.getProperties();
    SysProps.put("user","userid");
    SysProps.put("password","user_password");
    Connection conn= DriverManager.getConnection(url, SysProps);
    5、Informix數(shù)據(jù)庫


    Class.forName("com.informix.jdbc.IfxDriver").newInstance();
    String url = "jdbc:informix-sqli://123.45.67.89:1533/myDB:INFORMIXSERVER=myserver;
    user=testuser;password=testpassword"; //myDB為數(shù)據(jù)庫名
    Connection conn= DriverManager.getConnection(url);

    6、MySQL數(shù)據(jù)庫

    Class.forName("org.gjt.mm.mysql.Driver").newInstance();
    String url ="jdbc:mysql://localhost/myDB?user=soft&password=soft1234&useUnicode=true&characterEncoding=8859_1"
    //myDB為數(shù)據(jù)庫名
    Connection conn= DriverManager.getConnection(url);

    7、PostgreSQL數(shù)據(jù)庫

    Class.forName("org.postgresql.Driver").newInstance();
    String url ="jdbcostgresql://localhost/myDB" //myDB為數(shù)據(jù)庫名
    String user="myuser";
    String password="mypassword";
    Connection conn= DriverManager.getConnection(url,user,password);

    8、access數(shù)據(jù)庫直連用ODBC的
    Class.forName("sun.jdbc.odbc.JdbcOdbcDriver") ;
    String url="jdbcdbc:Driver={MicroSoft Access Driver (*.mdb)};DBQ="+application.getRealPath("/Data/ReportDemo.mdb");
    Connection conn = DriverManager.getConnection(url,"","");
    Statement stmtNew=conn.createStatement() ;

    二、JDBC連接MySql方式
      下面是使用JDBC連接MySql的一個小的教程

    1、查找驅(qū)動程序
      MySQL目前提供的java驅(qū)動程序為Connection/J,可以從MySQL官方網(wǎng)站下載,并找到mysql-connector-java-3.0.15-ga-bin.jar文件,此驅(qū)動程序為純java驅(qū)動程序,不需做其他配置。

    2、動態(tài)指定classpath
      如果需要執(zhí)行時動態(tài)指定classpath,就在執(zhí)行時采用-cp方式。否則將上面的.jar文件加入到classpath環(huán)境變量中。

    3、加載驅(qū)動程序

    try{
     Class.forName(com.mysql.jdbc.Driver);
     System.out.println(Success loading Mysql Driver!);
    }catch(Exception e)
    {
     System.out.println(Error loading Mysql Driver!);
     e.printStackTrace();
    }
    


    4、設(shè)置連接的url
    jdbc:mysql://localhost/databasename[?pa=va][&pa=va]

    三、以下列出了在使用JDBC來連接Oracle數(shù)據(jù)庫時可以使用的一些技巧
    1、在客戶端軟件開發(fā)中使用Thin驅(qū)動程序
      在開發(fā)Java軟件方面,Oracle的數(shù)據(jù)庫提供了四種類型的驅(qū)動程序,二種用于應(yīng)用軟件、applets、servlets等客戶端軟件,另外二種用于數(shù)據(jù)庫中的Java存儲過程等服務(wù)器端軟件。在客戶機端軟件的開發(fā)中,我們可以選擇OCI驅(qū)動程序或Thin驅(qū)動程序。OCI驅(qū)動程序利用Java本地化接口(JNI),通過Oracle客戶端軟件與數(shù)據(jù)庫進行通訊。Thin驅(qū)動程序是純Java驅(qū)動程序,它直接與數(shù)據(jù)庫進行通訊。為了獲得最高的性能,Oracle建議在客戶端軟件的開發(fā)中使用OCI驅(qū)動程序,這似乎是正確的。但我建議使用Thin驅(qū)動程序,因為通過多次測試發(fā)現(xiàn),在通常情況下, Thin驅(qū)動程序的性能都超過了OCI驅(qū)動程序。

    2、關(guān)閉自動提交功能,提高系統(tǒng)性能
       在第一次建立與數(shù)據(jù)庫的連接時,在缺省情況下,連接是在自動提交模式下的。為了獲得更好的性能,可以通過調(diào)用帶布爾值false參數(shù)的Connection類的setAutoCommit()方法關(guān)閉自動提交功能,如下所示:

    conn.setAutoCommit(false);

      值得注意的是,一旦關(guān)閉了自動提交功能,我們就需要通過調(diào)用Connection類的commit()和rollback()方法來人工的方式對事務(wù)進行管理。

    3、在動態(tài)SQL或有時間限制的命令中使用Statement對象
      在執(zhí)行SQL命令時,我們有二種選擇:可以使用PreparedStatement對象,也可以使用Statement對象。無論多少次地使用同一個 SQL命令,PreparedStatement都只對它解析和編譯一次。當使用Statement對象時,每次執(zhí)行一個SQL命令時,都會對它進行解析和編譯。這可能會使你認為,使用PreparedStatement對象比使用Statement對象的速度更快。然而,我進行的測試表明,在客戶端軟件中,情況并非如此。因此,在有時間限制的SQL操作中,除非成批地處理SQL命令,我們應(yīng)當考慮使用Statement對象。

       此外,使用Statement對象也使得編寫動態(tài)SQL命令更加簡單,因為我們可以將字符串連接在一起,建立一個有效的SQL命令。因此,我認為,Statement對象可以使動態(tài)SQL命令的創(chuàng)建和執(zhí)行變得更加簡單。

    4、利用helper函數(shù)對動態(tài)SQL命令進行格式化
      在創(chuàng)建使用Statement對象執(zhí)行的動態(tài)SQL命令時,我們需要處理一些格式化方面的問題。例如,如果我們想創(chuàng)建一個將名字O'Reilly插入表中的SQL命令,則必須使用二個相連的“''”號替換O'Reilly中的“'”號。完成這些工作的最好的方法是創(chuàng)建一個完成替換操作的helper方法,然后在連接字符串心服用公式表達一個SQL命令時,使用創(chuàng)建的helper方法。與此類似的是,我們可以讓helper方法接受一個Date型的值,然后讓它輸出基于Oracle的to_date()函數(shù)的字符串表達式。

    5、利用PreparedStatement對象提高數(shù)據(jù)庫的總體效率
      在使用PreparedStatement對象執(zhí)行SQL命令時,命令被數(shù)據(jù)庫進行解析和編譯,然后被放到命令緩沖區(qū)。然后,每當執(zhí)行同一個 PreparedStatement對象時,它就會被再解析一次,但不會被再次編譯。在緩沖區(qū)中可以發(fā)現(xiàn)預編譯的命令,并且可以重新使用。在有大量用戶的企業(yè)級應(yīng)用軟件中,經(jīng)常會重復執(zhí)行相同的SQL命令,使用PreparedStatement對象帶來的編譯次數(shù)的減少能夠提高數(shù)據(jù)庫的總體性能。如果不是在客戶端創(chuàng)建、預備、執(zhí)行PreparedStatement任務(wù)需要的時間長于Statement任務(wù),我會建議在除動態(tài)SQL命令之外的所有情況下使用PreparedStatement對象。

    6、在成批處理重復的插入或更新操作中使用PreparedStatement對象
      如果成批地處理插入和更新操作,就能夠顯著地減少它們所需要的時間。Oracle提供的Statement和 CallableStatement并不真正地支持批處理,只有PreparedStatement對象才真正地支持批處理。我們可以使用 addBatch()和executeBatch()方法選擇標準的JDBC批處理,或者通過利用PreparedStatement對象的 setExecuteBatch()方法和標準的executeUpdate()方法選擇速度更快的Oracle專有的方法。要使用Oracle專有的批處理機制,可以以如下所示的方式調(diào)用setExecuteBatch():

    PreparedStatement pstmt3D null;
    try {
     ((OraclePreparedStatement)pstmt).setExecuteBatch(30);
     ...
     pstmt.executeUpdate();
    }
        調(diào)用setExecuteBatch()時指定的值是一個上限,當達到該值時,就會自動地引發(fā)SQL命令執(zhí)行,標準的executeUpdate()方法就會被作為批處理送到數(shù)據(jù)庫中。我們可以通過調(diào)用PreparedStatement類的sendBatch()方法隨時傳輸批處理任務(wù)。
     
    7、使用Oracle locator方法插入、更新大對象(LOB)
      Oracle的PreparedStatement類不完全支持BLOB和CLOB等大對象的處理,尤其是Thin驅(qū)動程序不支持利用 PreparedStatement對象的setObject()和setBinaryStream()方法設(shè)置BLOB的值,也不支持利用 setCharacterStream()方法設(shè)置CLOB的值。只有l(wèi)ocator本身中的方法才能夠從數(shù)據(jù)庫中獲取LOB類型的值。可以使用 PreparedStatement對象插入或更新LOB,但需要使用locator才能獲取LOB的值。由于存在這二個問題,因此,我建議使用 locator的方法來插入、更新或獲取LOB的值。

    8、使用SQL92語法調(diào)用存儲過程
      在調(diào)用存儲過程時,我們可以使用SQL92或Oracle PL/SQL,由于使用Oracle PL/SQL并沒有什么實際的好處,而且會給以后維護你的應(yīng)用程序的開發(fā)人員帶來麻煩,因此,我建議在調(diào)用存儲過程時使用SQL92。

    9、使用Object SQL將對象模式轉(zhuǎn)移到數(shù)據(jù)庫中
      既然可以將Oracle的數(shù)據(jù)庫作為一種面向?qū)ο蟮臄?shù)據(jù)庫來使用,就可以考慮將應(yīng)用程序中的面向?qū)ο竽J睫D(zhuǎn)到數(shù)據(jù)庫中。目前的方法是創(chuàng)建Java bean作為偽裝的數(shù)據(jù)庫對象,將它們的屬性映射到關(guān)系表中,然后在這些bean中添加方法。盡管這樣作在Java中沒有什么問題,但由于操作都是在數(shù)據(jù)庫之外進行的,因此其他訪問數(shù)據(jù)庫的應(yīng)用軟件無法利用對象模式。如果利用Oracle的面向?qū)ο蟮募夹g(shù),可以通過創(chuàng)建一個新的數(shù)據(jù)庫對象類型在數(shù)據(jù)庫中模仿其數(shù)據(jù)和操作,然后使用JPublisher等工具生成自己的Java bean類。如果使用這種方式,不但Java應(yīng)用程序可以使用應(yīng)用軟件的對象模式,其他需要共享你的應(yīng)用中的數(shù)據(jù)和操作的應(yīng)用軟件也可以使用應(yīng)用軟件中的對象模式。

    10、利用SQL完成數(shù)據(jù)庫內(nèi)的操作
      我要向大家介紹的最重要的經(jīng)驗是充分利用SQL的面向集合的方法來解決數(shù)據(jù)庫處理需求,而不是使用Java等過程化的編程語言。

      如果編程人員要在一個表中查找許多行,結(jié)果中的每個行都會查找其他表中的數(shù)據(jù),最后,編程人員創(chuàng)建了獨立的UPDATE命令來成批地更新第一個表中的數(shù)據(jù)。與此類似的任務(wù)可以通過在set子句中使用多列子查詢而在一個UPDATE命令中完成。當能夠在單一的SQL命令中完成任務(wù),何必要讓數(shù)據(jù)在網(wǎng)上流來流去的?我建議用戶認真學習如何最大限度地發(fā)揮SQL的功能。

      ?

    ORACLE 數(shù)據(jù)庫備份技術(shù)
      ORACLE數(shù)據(jù)庫是一種大型關(guān)系型的數(shù)據(jù)庫,可以存貯達到存貯TB的數(shù)據(jù),那么如何保證這些數(shù)據(jù)的安全尤其至關(guān)重要,我們從1991年開始使用 ORACLE數(shù)據(jù)庫,通過這些年的使用,我們制定了一整套的ORACLE數(shù)據(jù)庫的備份制度。現(xiàn)在把我們的備份制度介紹給大家,供大家參考。

    1.根據(jù)實際需要決定數(shù)據(jù)庫的運行方式
    ORACLE數(shù)據(jù)庫有兩種運行方式:一是歸檔方式(ARCHIVELOG),歸檔方式的目的是當數(shù)據(jù)庫發(fā)生故障時最大限度恢復所有已提交的事物;二是不歸檔方式(NOARCHIVELOG),恢復數(shù)據(jù)庫到最近的回收點。我們根據(jù)數(shù)據(jù)庫的高可用性和用戶可承受丟失的工作量的多少,把我們正式運行的數(shù)據(jù)庫采用為歸檔方式;那些正在開發(fā)和調(diào)試的數(shù)據(jù)庫采用不歸檔方式。

    2如何改變數(shù)據(jù)庫的運行方式
    2.1在創(chuàng)建數(shù)據(jù)庫時設(shè)置數(shù)據(jù)庫的運行的方式
      在創(chuàng)建數(shù)據(jù)庫時,作為創(chuàng)建數(shù)據(jù)庫的一部分,就決定了數(shù)據(jù)庫初始的存檔方式。一般情況下為NOARCHIVELOG方式。當數(shù)據(jù)庫創(chuàng)建好以后,根據(jù)我們的需要把需要運行在歸檔方式的數(shù)據(jù)庫改成ARCHIVELOG方式。
      
    2.2改變不歸檔方式為為歸檔方式
      關(guān)閉數(shù)據(jù)庫,備份已有的數(shù)據(jù)
      改變數(shù)據(jù)庫的運行方式是對數(shù)據(jù)庫的重要改動,所以要對數(shù)據(jù)庫做備份,對可能出現(xiàn)的問題作出保護。
      啟動Instance ,Mount數(shù)據(jù)庫但不打開數(shù)據(jù)庫,來改變歸檔方式

      sqldba lmode=y(svrmgrl)
      sqldba>connect internal
      sqldba>startup mount
      sqldba>alter database archivelog;

      使能自動存檔
      在初始化文件init*.ora(一般放ORACLE根目錄的下層目錄dbs下)加參數(shù):
      log_archive_start=true
      指定存檔的重做登錄文件名和存放的位置
      同樣是在初始化文件init*.ora中加入下面的參數(shù):
      log_archive_format=%S.arc
      log_archive_dest=/arch12/arch (arch12 是日志文件存放的目錄)
      關(guān)閉數(shù)據(jù)庫,重新啟動數(shù)據(jù)庫,歸檔方式轉(zhuǎn)換完成。

    3回收制度
    3.1根據(jù)數(shù)據(jù)庫的運行方式和可承受丟失的工作量來決定數(shù)據(jù)庫的回收制度對于不歸檔方式,我們用的是ORACLE數(shù)據(jù)庫的邏輯備份Export ,回收的制度是:一個月作一次全備份(x01.dmp),一周作一次累積備份(c*.dmp),一天一次增量備份(I*.dmp),具體的是星期一到星期五作增量備份,星期六做累積備份或全備份,每次做完備份后自動傳到其它的機器上存儲。這些備份都是自動執(zhí)行的,后面給出程序文本。

      對于歸檔方式,我們用的是ORCALE的物理備份:當數(shù)據(jù)庫創(chuàng)建好以后,做一次物理上的全備份,平時在不關(guān)閉數(shù)據(jù)庫的前提下,一個星期對經(jīng)常改變的數(shù)據(jù)文件做聯(lián)機的數(shù)據(jù)庫數(shù)據(jù)文件的物理備份;當數(shù)據(jù)庫的結(jié)構(gòu)發(fā)生改變,如:增加表空間,加數(shù)據(jù)文件等,如允許關(guān)機,正常關(guān)閉數(shù)據(jù)庫,重新做數(shù)據(jù)庫全備份,否則,備份控制文件,備份數(shù)據(jù)文件照常。聯(lián)機的日志文件我們是寫在陣列上的,不用鏡象和備份。

    3.2回收的方法
    3.2.1不歸檔方式
       我們拿曙光AIX操作系統(tǒng)為例,來講解以下如何做自動備份:
    ---- a.首先建UNIX用戶 demo/demo
    ---- b.拷貝oracle用戶下的 .profile 到 demo 用戶下,以保證 demo 用戶可以用 Export命令
    ---- c.用root用戶登錄,編輯 /var/adm/cron/cron.allow 加入用戶名demo,這樣demo用戶就有權(quán)自動執(zhí)行數(shù)據(jù)庫備份的shell程序;
    ---- d.創(chuàng)建數(shù)據(jù)庫備份程序,放到本用戶的下層目錄bin下,并且這些文件要有可執(zhí)行權(quán)文件zlbf1:(增量備份1,星期一執(zhí)行的程序)

    . /u11/demo/.profile 
    exp system/manager inctype=INCREMENTAL file=i01.dmp 
    ftp -n< < ! 
    open 10.10.10.40 
    user demo demo 
    binary 
    prompt 
    cd backup40 
    put i01.dmp 
    close 
    bye 
    ! 
    
    文件zlbf2:(增量備份2, 星期二執(zhí)行的程序) 
    
    . /u11/demo/.profile 
    exp system/manager inctype=INCREMENTAL file=i02.dmp 
    ftp -n< < ! 
    
    open 10.10.10.40 
    user demo demo 
    binary 
    prompt 
    cd backup40 
    put i02.dmp 
    close 
    bye 
    ! 
    
    文件zlbf3:(增量備份3, 星期三執(zhí)行的程序) 
    . /u11/demo/.profile 
    exp system/manager inctype=INCREMENTAL file=i03.dmp 
    ftp -n< < ! 
    open 10.10.10.40 
    user demo demo 
    binary 
    prompt 
    cd backup40 
    put i03.dmp 
    close 
    bye 
    ! 
    文件zlbf4:(增量備份4, 星期四執(zhí)行的程序) 
    . /u11/demo/.profile 
    exp system/manager inctype=INCREMENTAL file=i04.dmp 
    ftp -n< < ! 
    open 10.10.10.40 
    user demo demo 
    binary 
    prompt 
    cd backup40 
    put i04.dmp 
    close 
    bye 
    ! 
    文件zlbf5:(增量備份5, 星期五執(zhí)行的程序) 
    . /u11/demo/.profile 
    exp system/manager inctype=INCREMENTAL file=i05.dmp 
    ftp -n< < ! 
    open 10.10.10.40 
    user demo demo 
    binary 
    prompt 
    cd backup40 
    put i05.dmp 
    close 
    bye 
    ! 
    文件zlbf6:(增量備份6, 星期六執(zhí)行的程序) 
    . /u11/demo/.profile 
    js=`ls c*.dmp|wc -l` 
    if test  = 0 
    then 
    exp system/manager inctype=CUMULATIVE file=c01.dmp 
    ftp -n< < ! 
    open 10.10.10.40 
    user demo demo 
    binary 
    prompt 
    cd backup40 
    put c01.dmp 
    close 
    bye 
    ! 
    fi 
    if test  = 1 
    then 
    exp system/manger inctype=CUMULATIVE file=c02.dmp 
    ftp -n< < ! 
    open 10.10.10.40 
    user demo demo 
    binary 
    prompt 
    cd backup40 
    put c02.dmp 
    close 
    bye 
    ! 
    fi 
    if test  = 2 
    then 
    exp system/maneger inctype=CUMULATIVE file=c03.dmp 
    ftp -n< < ! 
    open 10.10.10.40 
    user demo demo 
    binary 
    prompt 
    cd backup40 
    put c03.dmp 
    close 
    bye 
    ! 
    fi 
    if test  = 3 
    then 
    exp system/manager inctype=COMPLETE file=x01.dmp 
    ftp -n< < ! 
    open 10.10.10.40 
    user demo demo 
    binary 
    prompt 
    cd backup40 
    put x01.dmp 
    close 
    bye 
    ! 
    rm c*.dmp 
    fi 
    
    ---- e.在demo 用戶下建一個文件,假如叫:cron.demo,文件內(nèi)容如下 
    59 22 * * 1 bin/zlbf1 
    59 22 * * 2 bin/zlbf2 
    59 22 * * 3 bin/zlbf3 
    59 22 * * 4 bin/zlbf4 
    59 22 * * 5 bin/zlbf5 
    59 22 * * 6 bin/zlbf6 
    

    ---- f.在demo用戶下執(zhí)行下面的命令:
    crontab cron.demo 執(zhí)行的結(jié)果放到
    /var/spool/cron/crontabs/demo文件里

    ---- g.重新啟動cron 進程,命令:kill -1 進程號
    ---- h.執(zhí)行結(jié)果放在本用戶的郵件里
    ---- i.查看結(jié)果是否執(zhí)行,請看:/var/adm/cron/log文件

    3.2.2歸檔方式
    ---- a. 找到要回收的數(shù)據(jù)文件、聯(lián)機重做登錄文件、控制文件和參數(shù)文件
    ---- b. 正常關(guān)閉數(shù)據(jù)庫,作一次全回收(用操作系統(tǒng)的TAR命令,可以寫成shell程序),然后打開數(shù)據(jù)庫供正常使用,shell程序如下:
    tar cvf /dev/rmt/ctape2 /u1/oracle/dbs/ctrl1ora7.ctl
    /u1/oracle/dbs/ctrl2ora7.ctl
    /u1/oracle/dbs/ctrl3ora7.ctl
    /u1/oracle/dbs/systora7.dbf
    /u1/oracle/dbs/rbsora7.dbf
    /u1/oracle/dbs/tempora7.dbf
    /u1/oracle/dbs/toolora7.dbf
    /u1/oracle/dbs/usrora7.dbf
    /ls1/ls1.dbf
    /u1/oracle/dbs/log1ora7.dbf
    /u1/oracle/dbs/log2ora7.dbf
    /u1/oracle/dbs/log3ora7.dbf
    ---- c. 經(jīng)常作聯(lián)機的表空間和數(shù)據(jù)文件的部分回收
    首先標記聯(lián)機表空間回收的開始
    alter tablespace 表空間名 begin backup;
    用操作系統(tǒng)命令備份數(shù)據(jù)文件
    最后標記聯(lián)機的表空間回收結(jié)束
    alter tablespace 表空間名 end backup
    ---- 多個表空間可以一起做標記,備份做標記的所有數(shù)據(jù)文件后,一起標記結(jié)束。
    ---- d. 當數(shù)據(jù)庫結(jié)構(gòu)發(fā)生改變后,要對它的控制文件做回收
    sqldba >alter database backup
    controlfile to ’文件名’ reuse;  ?

    數(shù)據(jù)庫設(shè)計中的14個技巧
    1. 原始單據(jù)與實體之間的關(guān)系
      可以是一對一、一對多、多對多的關(guān)系。在一般情況下,它們是一對一的關(guān)系:即一張原始單據(jù)對應(yīng)且只對應(yīng)一個實體。在特殊情況下,它們可能是一對多或多對一的關(guān)系,即一張原始單證對應(yīng)多個實體,或多張原始單證對應(yīng)一個實體。這里的實體可以理解為基本表。明確這種對應(yīng)關(guān)系后,對我們設(shè)計錄入界面大有好處。
      〖例1〗:一份員工履歷資料,在人力資源信息系統(tǒng)中,就對應(yīng)三個基本表:員工基本情況表、社會關(guān)系表、工作簡歷表。這就是“一張原始單證對應(yīng)多個實體”的典型例子。

    2. 主鍵與外鍵
      一般而言,一個實體不能既無主鍵又無外鍵。在E—R 圖中, 處于葉子部位的實體, 可以定義主鍵,也可以不定義主鍵(因為它無子孫), 但必須要有外鍵(因為它有父親)。
      主鍵與外鍵的設(shè)計,在全局數(shù)據(jù)庫的設(shè)計中,占有重要地位。當全局數(shù)據(jù)庫的設(shè)計完成以后,有個美國數(shù)據(jù)庫設(shè)計專家說:“鍵,到處都是鍵,除了鍵之外,什么也沒有”,這就是他的數(shù)據(jù)庫設(shè)計經(jīng)驗之談,也反映了他對信息系統(tǒng)核心(數(shù)據(jù)模型)的高度抽象思想。因為:主鍵是實體的高度抽象,主鍵與外鍵的配對,表示實體之間的連接。

    3. 基本表的性質(zhì)
      基本表與中間表、臨時表不同,因為它具有如下四個特性:
      (1) 原子性。基本表中的字段是不可再分解的。
      (2) 原始性。基本表中的記錄是原始數(shù)據(jù)(基礎(chǔ)數(shù)據(jù))的記錄。
      (3) 演繹性。由基本表與代碼表中的數(shù)據(jù),可以派生出所有的輸出數(shù)據(jù)。
      (4) 穩(wěn)定性。基本表的結(jié)構(gòu)是相對穩(wěn)定的,表中的記錄是要長期保存的。
       理解基本表的性質(zhì)后,在設(shè)計數(shù)據(jù)庫時,就能將基本表與中間表、臨時表區(qū)分開來。

    4. 范式標準
      基本表及其字段之間的關(guān)系, 應(yīng)盡量滿足第三范式。但是,滿足第三范式的數(shù)據(jù)庫設(shè)計,往往不是最好的設(shè)計。為了提高數(shù)據(jù)庫的運行效率,常常需要降低范式標準:適當增加冗余,達到以空間換時間的目的。
      〖例2〗:有一張存放商品的基本表,如表1所示。“金額”這個字段的存在,表明該表的設(shè)計不滿足第三范式,因為“金額”可以由“單價”乘以“數(shù)量”得到,說明“金額”是冗余字段。但是,增加“金額”這個冗余字段,可以提高查詢統(tǒng)計的速度,這就是以空間換時間的作法。
      在Rose 2002中,規(guī)定列有兩種類型:數(shù)據(jù)列和計算列。“金額”這樣的列被稱為“計算列”,而“單價”和“數(shù)量”這樣的列被稱為“數(shù)據(jù)列”。
      表1 商品表的表結(jié)構(gòu)
      商品名稱商品型號單價數(shù)量金額
      電視機 29吋 2,500 40 100,000

    5. 通俗地理解三個范式
      通俗地理解三個范式,對于數(shù)據(jù)庫設(shè)計大有好處。在數(shù)據(jù)庫設(shè)計中,為了更好地應(yīng)用三個范式,就必須通俗地理解三個范式(通俗地理解是夠用的理解,并不是最科學最準確的理解):
      第一范式:1NF是對屬性的原子性約束,要求屬性具有原子性,不可再分解;
      第二范式:2NF是對記錄的惟一性約束,要求記錄有惟一標識,即實體的惟一性;
      第三范式:3NF是對字段冗余性的約束,即任何字段不能由其他字段派生出來,它要求字段沒有冗余。
      沒有冗余的數(shù)據(jù)庫設(shè)計可以做到。但是,沒有冗余的數(shù)據(jù)庫未必是最好的數(shù)據(jù)庫,有時為了提高運行效率,就必須降低范式標準,適當保留冗余數(shù)據(jù)。具體做法是:在概念數(shù)據(jù)模型設(shè)計時遵守第三范式,降低范式標準的工作放到物理數(shù)據(jù)模型設(shè)計時考慮。降低范式就是增加字段,允許冗余。

    6. 要善于識別與正確處理多對多的關(guān)系
      若兩個實體之間存在多對多的關(guān)系,則應(yīng)消除這種關(guān)系。消除的辦法是,在兩者之間增加第三個實體。這樣,原來一個多對多的關(guān)系,現(xiàn)在變?yōu)閮蓚€一對多的關(guān)系。要將原來兩個實體的屬性合理地分配到三個實體中去。這里的第三個實體,實質(zhì)上是一個較復雜的關(guān)系,它對應(yīng)一張基本表。一般來講,數(shù)據(jù)庫設(shè)計工具不能識別多對多的關(guān)系,但能處理多對多的關(guān)系。
      〖例3〗:在“圖書館信息系統(tǒng)”中,“圖書”是一個實體,“讀者”也是一個實體。這兩個實體之間的關(guān)系,是一個典型的多對多關(guān)系:一本圖書在不同時間可以被多個讀者借閱,一個讀者又可以借多本圖書。為此,要在二者之間增加第三個實體,該實體取名為“借還書”,它的屬性為:借還時間、借還標志(0表示借書,1表示還書),另外,它還應(yīng)該有兩個外鍵(“圖書”的主鍵,“讀者”的主鍵),使它能與“圖書”和 “讀者”連接。

    7. 主鍵PK的取值方法
      PK是供程序員使用的表間連接工具,可以是一無物理意義的數(shù)字串, 由程序自動加1來實現(xiàn)。也可以是有物理意義的字段名或字段名的組合。不過前者比后者好。當PK是字段名的組合時,建議字段的個數(shù)不要太多,多了不但索引占用空間大,而且速度也慢。

    8. 正確認識數(shù)據(jù)冗余
      主鍵與外鍵在多表中的重復出現(xiàn), 不屬于數(shù)據(jù)冗余,這個概念必須清楚,事實上有許多人還不清楚。非鍵字段的重復出現(xiàn), 才是數(shù)據(jù)冗余!而且是一種低級冗余,即重復性的冗余。高級冗余不是字段的重復出現(xiàn),而是字段的派生出現(xiàn)。
      〖例4〗:商品中的“單價、數(shù)量、金額”三個字段,“金額”就是由“單價”乘以“數(shù)量”派生出來的,它就是冗余,而且是一種高級冗余。冗余的目的是為了提高處理速度。只有低級冗余才會增加數(shù)據(jù)的不一致性,因為同一數(shù)據(jù),可能從不同時間、地點、角色上多次錄入。因此,我們提倡高級冗余(派生性冗余),反對低級冗余(重復性冗余)。

    9. E--R圖沒有標準答案
      信息系統(tǒng)的E--R圖沒有標準答案,因為它的設(shè)計與畫法不是惟一的,只要它覆蓋了系統(tǒng)需求的業(yè)務(wù)范圍和功能內(nèi)容,就是可行的。反之要修改E--R圖。盡管它沒有惟一的標準答案,并不意味著可以隨意設(shè)計。好的E—R圖的標準是:結(jié)構(gòu)清晰、關(guān)聯(lián)簡潔、實體個數(shù)適中、屬性分配合理、沒有低級冗余。

    10. 視圖技術(shù)在數(shù)據(jù)庫設(shè)計中很有用
      與基本表、代碼表、中間表不同,視圖是一種虛表,它依賴數(shù)據(jù)源的實表而存在。視圖是供程序員使用數(shù)據(jù)庫的一個窗口,是基表數(shù)據(jù)綜合的一種形式, 是數(shù)據(jù)處理的一種方法,是用戶數(shù)據(jù)保密的一種手段。為了進行復雜處理、提高運算速度和節(jié)省存儲空間, 視圖的定義深度一般不得超過三層。若三層視圖仍不夠用, 則應(yīng)在視圖上定義臨時表, 在臨時表上再定義視圖。這樣反復交迭定義, 視圖的深度就不受限制了。
      對于某些與國家政治、經(jīng)濟、技術(shù)、軍事和安全利益有關(guān)的信息系統(tǒng),視圖的作用更加重要。這些系統(tǒng)的基本表完成物理設(shè)計之后,立即在基本表上建立第一層視圖,這層視圖的個數(shù)和結(jié)構(gòu),與基本表的個數(shù)和結(jié)構(gòu)是完全相同。并且規(guī)定,所有的程序員,一律只準在視圖上操作。只有數(shù)據(jù)庫管理員,帶著多個人員共同掌握的“安全鑰匙”,才能直接在基本表上操作。請讀者想想:這是為什么?

    11. 中間表、報表和臨時表
      中間表是存放統(tǒng)計數(shù)據(jù)的表,它是為數(shù)據(jù)倉庫、輸出報表或查詢結(jié)果而設(shè)計的,有時它沒有主鍵與外鍵(數(shù)據(jù)倉庫除外)。臨時表是程序員個人設(shè)計的,存放臨時記錄,為個人所用。基表和中間表由DBA維護,臨時表由程序員自己用程序自動維護。

    12. 完整性約束表現(xiàn)在三個方面
      域的完整性:用Check來實現(xiàn)約束,在數(shù)據(jù)庫設(shè)計工具中,對字段的取值范圍進行定義時,有一個Check按鈕,通過它定義字段的值城。
      參照完整性:用PK、FK、表級觸發(fā)器來實現(xiàn)。
      用戶定義完整性:它是一些業(yè)務(wù)規(guī)則,用存儲過程和觸發(fā)器來實現(xiàn)。

    13. 防止數(shù)據(jù)庫設(shè)計打補丁的方法是“三少原則”
      (1) 一個數(shù)據(jù)庫中表的個數(shù)越少越好。只有表的個數(shù)少了,才能說明系統(tǒng)的E--R圖少而精,去掉了重復的多余的實體,形成了對客觀世界的高度抽象,進行了系統(tǒng)的數(shù)據(jù)集成,防止了打補丁式的設(shè)計;
      (2) 一個表中組合主鍵的字段個數(shù)越少越好。因為主鍵的作用,一是建主鍵索引,二是做為子表的外鍵,所以組合主鍵的字段個數(shù)少了,不僅節(jié)省了運行時間,而且節(jié)省了索引存儲空間;
      (3) 一個表中的字段個數(shù)越少越好。只有字段的個數(shù)少了,才能說明在系統(tǒng)中不存在數(shù)據(jù)重復,且很少有數(shù)據(jù)冗余,更重要的是督促讀者學會“列變行”,這樣就防止了將子表中的字段拉入到主表中去,在主表中留下許多空余的字段。所謂“列變行”,就是將主表中的一部分內(nèi)容拉出去,另外單獨建一個子表。這個方法很簡單,有的人就是不習慣、不采納、不執(zhí)行。
      數(shù)據(jù)庫設(shè)計的實用原則是:在數(shù)據(jù)冗余和處理速度之間找到合適的平衡點。“三少”是一個整體概念,綜合觀點,不能孤立某一個原則。該原則是相對的,不是絕對的。“三多”原則肯定是錯誤的。試想:若覆蓋系統(tǒng)同樣的功能,一百個實體(共一千個屬性) 的E--R圖,肯定比二百個實體(共二千個屬性) 的E--R圖,要好得多。
      提倡“三少”原則,是叫讀者學會利用數(shù)據(jù)庫設(shè)計技術(shù)進行系統(tǒng)的數(shù)據(jù)集成。數(shù)據(jù)集成的步驟是將文件系統(tǒng)集成為應(yīng)用數(shù)據(jù)庫,將應(yīng)用數(shù)據(jù)庫集成為主題數(shù)據(jù)庫,將主題數(shù)據(jù)庫集成為全局綜合數(shù)據(jù)庫。集成的程度越高,數(shù)據(jù)共享性就越強,信息孤島現(xiàn)象就越少,整個企業(yè)信息系統(tǒng)的全局E—R圖中實體的個數(shù)、主鍵的個數(shù)、屬性的個數(shù)就會越少。
      提倡“三少”原則的目的,是防止讀者利用打補丁技術(shù),不斷地對數(shù)據(jù)庫進行增刪改,使企業(yè)數(shù)據(jù)庫變成了隨意設(shè)計數(shù)據(jù)庫表的“垃圾堆”,或數(shù)據(jù)庫表的“大雜院”,最后造成數(shù)據(jù)庫中的基本表、代碼表、中間表、臨時表雜亂無章,不計其數(shù),導致企事業(yè)單位的信息系統(tǒng)無法維護而癱瘓。
      “三多”原則任何人都可以做到,該原則是“打補丁方法”設(shè)計數(shù)據(jù)庫的歪理學說。“三少”原則是少而精的原則,它要求有較高的數(shù)據(jù)庫設(shè)計技巧與藝術(shù),不是任何人都能做到的,因為該原則是杜絕用“打補丁方法”設(shè)計數(shù)據(jù)庫的理論依據(jù)。

    14. 提高數(shù)據(jù)庫運行效率的辦法
      在給定的系統(tǒng)硬件和系統(tǒng)軟件條件下,提高數(shù)據(jù)庫系統(tǒng)的運行效率的辦法是:
      (1) 在數(shù)據(jù)庫物理設(shè)計時,降低范式,增加冗余, 少用觸發(fā)器, 多用存儲過程。
      (2) 當計算非常復雜、而且記錄條數(shù)非常巨大時(例如一千萬條),復雜計算要先在數(shù)據(jù)庫外面,以文件系統(tǒng)方式用C++語言計算處理完成之后,最后才入庫追加到表中去。這是電信計費系統(tǒng)設(shè)計的經(jīng)驗。
      (3) 發(fā)現(xiàn)某個表的記錄太多,例如超過一千萬條,則要對該表進行水平分割。水平分割的做法是,以該表主鍵PK的某個值為界線,將該表的記錄水平分割為兩個表。若發(fā)現(xiàn)某個表的字段太多,例如超過八十個,則垂直分割該表,將原來的一個表分解為兩個表。
      (4) 對數(shù)據(jù)庫管理系統(tǒng)DBMS進行系統(tǒng)優(yōu)化,即優(yōu)化各種系統(tǒng)參數(shù),如緩沖區(qū)個數(shù)。
      (5) 在使用面向數(shù)據(jù)的SQL語言進行程序設(shè)計時,盡量采取優(yōu)化算法。
       總之,要提高數(shù)據(jù)庫的運行效率,必須從數(shù)據(jù)庫系統(tǒng)級優(yōu)化、數(shù)據(jù)庫設(shè)計級優(yōu)化、程序?qū)崿F(xiàn)級優(yōu)化,這三個層次上同時下功夫。
      上述十四個技巧,是許多人在大量的數(shù)據(jù)庫分析與設(shè)計實踐中,逐步總結(jié)出來的。對于這些經(jīng)驗的運用,讀者不能生幫硬套,死記硬背,而要消化理解,實事求是,靈活掌握。并逐步做到:在應(yīng)用中發(fā)展,在發(fā)展中應(yīng)用。
    特別聲明以上內(nèi)容是轉(zhuǎn)至http://dev2dev.bea.com.cn/bbsdoc/20060112181.html,如果您認為該文檔的內(nèi)容侵犯了您的權(quán)益,請與整理者(excelarthur.com.cn)聯(lián)系,與Dev2Dev網(wǎng)站無關(guān)。

    posted @ 2006-04-04 14:36 rodney 閱讀(1367) | 評論 (0)編輯 收藏
     
    在安裝完了JBuilder9時,打開JB9會彈出一個對話框講你要注冊。這時你沒有注冊號時,有一個叫JB9_Ent_KeyGen.exe的文件,這時你只要將這個文件copy to 你安裝的目錄下。double click this file,這時你只要點擊"Generate",再點擊"Save"就OK了。例如:E:\JBuilder9\jdk1.4\bin下放入copy的文件。這個文件一定要放入jdk1.4\bin下面。
    posted @ 2006-04-03 17:27 rodney 閱讀(1508) | 評論 (0)編輯 收藏
     
    如果你做過很多java程序,你可能對java集合類很熟悉,例如Vector和ArrayList。你可以創(chuàng)建一個集合并向其中增加元素:
    1.     List lst = new ArrayList();
    2.     lst.add(new Integer(37));

    在這個特殊的范例中,一個整型值37用于構(gòu)造一個Integer封裝類對象,然后那個對象被加入到列表。

    這個簡單的范例展示集合的一個基礎(chǔ)-他們用于操縱一列對象,其中的每個對象是一個類或者接口類型。因此,一個ArrayList可以包含Object,String,Float以及Runnable類型的對象。集合類不能用于原始數(shù)據(jù)類型的列表,例如整型數(shù)組。

    如果你在你的程序中使用原始類型的數(shù)組,你如何操縱它們呢?這個技巧就給你展示幾個你可以使用的技術(shù)。

    第一個技術(shù)是排序。java.util.Arrays類包含一套排序和查找數(shù)組的類方法,例如:
    1.     import java.util.Arrays;
    2.     public class ArrayDemo1 {
    3.         public static void main(String args[]) {
    4.             int vec[] = {37, 47, 23, -5, 19, 56};
    5.             Arrays.sort(vec);
    6.             for (int i = 0; i < vec.length; i++) {
    7.                 System.out.println(vec[i]);
    8.             }
    9.         }
    10.     }

    這個演示程序初始化一個整數(shù)數(shù)組然后調(diào)用Arrays.sort升序排序那個數(shù)組。

    類似的,你可以在排完序的數(shù)組上進行二分法查找:
    1.     import java.util.Arrays;
    2.     public class ArrayDemo2 {
    3.         public static void main(String args[]) {
    4.             int vec[] = {-5, 19, 23, 37, 47, 56};
    5.             int slot = Arrays.binarySearch(vec, 35);
    6.             slot = -(slot + 1);
    7.             System.out.println("insertion point = " + slot);
    8.         }
    9.     }

    這個程序有個微妙的概念,如果二分法查找失敗它將返回:

        -(insertion point) - 1

    這個演示程序以參數(shù)35調(diào)用查找方法,而那個參數(shù)在數(shù)組中不存在,方法返回值-4,如果這個值加一再取其負數(shù)就得到3,這就是35應(yīng)該被插入到數(shù)組中的位置,換言之,值-5, 19和23在數(shù)組中占據(jù)的位置是0,1和2。因此值35應(yīng)該在索引3的位置,而37, 47以及56順延。搜索方法并不進行實際的插入操作而只是指出應(yīng)該在何處插入。

    除了排序和查找,我們還可以對原始類型數(shù)組做什么?另一個有用的技術(shù)是將一個原始數(shù)組轉(zhuǎn)換為等價的對象類型數(shù)組。每個對應(yīng)元素使用它們的封裝器類,例如在封裝數(shù)組中,37成為Integer(37)。
    1.     import java.util.Arrays;
    2.     import java.lang.reflect.Array;
    3.     
    4.     public class ArrayDemo3 {
    5.     
    6.         // if input is a single-dimension primitive array,
    7.         // return a new array consisting of wrapped elements,
    8.         // else just return input argument
    9.     
    10.         public static Object toArray(Object vec) {
    11.     
    12.             // if null, return
    13.     
    14.             if (vec == null) {
    15.                 return vec;
    16.             }
    17.     
    18.             // if not an array or elements not primitive, return
    19.     
    20.             Class cls = vec.getClass();
    21.             if (!cls.isArray()) {
    22.                 return vec;
    23.             }
    24.             if (!cls.getComponentType().isPrimitive()) {
    25.                 return vec;
    26.             }
    27.     
    28.             // get array length and create Object output array
    29.     
    30.             int length = Array.getLength(vec);
    31.             Object newvec[] = new Object[length];
    32.     
    33.             // wrap and copy elements
    34.     
    35.             for (int i = 0; i < length; i++) {
    36.                 newvec[i] = Array.get(vec, i);
    37.             }
    38.     
    39.             return newvec;
    40.         }
    41.     
    42.         public static void main(String args[]) {
    43.     
    44.             // create a primitive array
    45.     
    46.             int vec[] = new int[]{1, 2, 3};
    47.     
    48.             // wrap it
    49.     
    50.             Object wrappedvec[] = (Object[])toArray(vec);
    51.     
    52.             // display result
    53.     
    54.             for (int i = 0; i < wrappedvec.length; i++) {
    55.                 System.out.println(wrappedvec[i]);
    56.             }
    57.         }
    58.     }

    方法"toArray"的參數(shù)是一個Object對象(數(shù)組可以被賦值給一個Object引用)。如果參數(shù)是null或者代表的不是原始類型數(shù)組那么這個方法簡單的返回參數(shù)值。java.lang.Class工具類用于判斷參數(shù)是否是一個數(shù)組并獲取數(shù)組的底層元素的類型。

    一旦做完這些檢查,使用java.lang.reflect.Array工具類的反射工具方法就可以獲取原始數(shù)組的長度并獲得數(shù)組的單個元素。Array.get獲得的每個元素被返回到封裝器類中,例如Integer或者Double。

    最終的范例基于前面的那個并向你展示如何在數(shù)組上使用集合特性。這假設(shè)你已經(jīng)有一個對象數(shù)組。
    1.     import java.util.Arrays;
    2.     import java.util.List;
    3.     public class ArrayDemo4 {
    4.         public static void main(String args[]) {
    5.             Object vec[] = {new Integer(37), new Integer(47)};
    6.             List lst = Arrays.asList(vec);
    7.             lst.set(1, new Integer(57));
    8.             for (int i = 0; i < vec.length; i++) {
    9.                 System.out.println(vec[i]);
    10.             }
    11.         }
    12.     }

    在這個程序中,vec是一個對象數(shù)組,包含Integer(37)和Integer(47),然后Arrays.asList被調(diào)用。它返回一個集合(List接口類型),使用數(shù)組作為集合的后臺存儲。換言之,ArrayList這樣的集合類型在它內(nèi)部有某種存儲類型去存儲集合元素。在這個例子中,使用的存儲類型是作為參數(shù)傳遞到Arrays.asList的數(shù)組。這意味著集合方法所做的改變會被反射到底層的數(shù)組。

    修改集合中的元素1導致底層的數(shù)組也改變,程序的輸出是:

        37
        57

    因此如果你有一個對象數(shù)組,你可以在它上面使用集合特性,數(shù)組自身作為底層存儲。

    我們也可以將集合轉(zhuǎn)換為一個對象數(shù)組,例如:

        Object vec[] = lst.toArray();

    package com.cucu.test;

    /**
    * @author http://www.linewell.com <a href=mailto:cg@linewell.com>cg@linewell.com</a>
    * @version 1.0
    */
    public class Sort {

    public void swap(int a[], int i, int j) {
    int tmp = a;
    a = a[j];
    a[j] = tmp;
    }

    public int partition(int a[], int low, int high) {
    int pivot, p_pos, i;
    p_pos = low;
    pivot = a[p_pos];
    for (i = low + 1; i <= high; i++) {
    if (a > pivot) {
    p_pos++;
    swap(a, p_pos, i);
    }
    }
    swap(a, low, p_pos);
    return p_pos;
    }

    public void quicksort(int a[], int low, int high) {
    int pivot;
    if (low < high) {
    pivot = partition(a, low, high);
    quicksort(a, low, pivot - 1);
    quicksort(a, pivot + 1, high);
    }

    }

    public static void main(String args[]) {
    int vec[] = new int[] { 37, 47, 23, -5, 19, 56 };
    int temp;
    //選擇排序法(Selection Sort)
    long begin = System.currentTimeMillis();
    for (int k = 0; k < 1000000; k++) {
    for (int i = 0; i < vec.length; i++) {
    for (int j = i; j < vec.length; j++) {
    if (vec[j] > vec) {
    temp = vec;
    vec = vec[j];
    vec[j] = temp;
    }
    }

    }
    }
    long end = System.currentTimeMillis();
    System.out.println("選擇法用時為:" + (end - begin));
    //打印排序好的結(jié)果
    for (int i = 0; i < vec.length; i++) {
    System.out.println(vec);
    }
    // 冒泡排序法(Bubble Sort)
    begin = System.currentTimeMillis();
    for (int k = 0; k < 1000000; k++) {
    for (int i = 0; i < vec.length; i++) {
    for (int j = i; j < vec.length - 1; j++) {
    if (vec[j + 1] > vec[j]) {
    temp = vec[j + 1];
    vec[j + 1] = vec[j];
    vec[j] = temp;
    }
    }

    }
    }
    end = System.currentTimeMillis();
    System.out.println("冒泡法用時為:" + (end - begin));
    //打印排序好的結(jié)果
    for (int i = 0; i < vec.length; i++) {
    System.out.println(vec);
    }

    //插入排序法(Insertion Sort)
    begin = System.currentTimeMillis();
    for (int k = 0; k < 1000000; k++) {
    for (int i = 1; i < vec.length; i++) {
    int j = i;
    while (vec[j - 1] < vec) {
    vec[j] = vec[j - 1];
    j--;
    if (j <= 0) {
    break;
    }
    }
    vec[j] = vec;
    }
    }
    end = System.currentTimeMillis();
    System.out.println("插入法用時為:" + (end - begin));
    //打印排序好的結(jié)果
    for (int i = 0; i < vec.length; i++) {
    System.out.println(vec);
    }

    //快速排序法(Quick Sort)

    Sort s = new Sort();
    begin = System.currentTimeMillis();
    for (int k = 0; k < 1000000; k++) {
    s.quicksort(vec, 0, 5);
    }
    end = System.currentTimeMillis();
    System.out.println("快速法用時為:" + (end - begin));
    //打印排序好的結(jié)果
    for (int i = 0; i < vec.length; i++) {
    System.out.println(vec);
    }
    }

    }
    以下是運行結(jié)果:
    選擇法用時為:234
    56
    47
    37
    23
    19
    -5
    冒泡法用時為:172
    56
    47
    37
    23
    19
    -5
    插入法用時為:78
    56
    47
    37
    23
    19
    -5
    快速法用時為:297
    56
    47
    37
    23
    19
    -5*
    posted @ 2006-03-06 10:16 rodney 閱讀(376) | 評論 (0)編輯 收藏
     
    dwg,img,iso,sub怎么打開?這個問題在google去查詢一下有許多都可找到答案。我個人有過的的工具有:dwg用daemon,其它的用虛擬光驅(qū)就OK了。
    posted @ 2006-03-02 09:55 rodney 閱讀(765) | 評論 (0)編輯 收藏
     
    因一個QQ的網(wǎng)友發(fā)了一個鏈接給我,我一點擊,完了中他的套了。我的IE彈出了許多的廣告,在任務(wù)欄中有連接的小圖標不見了。我在設(shè)置中打開網(wǎng)絡(luò)和拔號連接,可這里也沒有呀。只是圖標不見了,連接還是可以用。不知道為什么,是哪里被改了。
    這可能是你的Network Connections服務(wù)被禁用了原因造成的,查看方法如下:在“運行”窗口中輸入“services.msc”,然后在打開的“服務(wù)”窗口右側(cè)服務(wù)列表中找到名稱為“Network Connections”的服務(wù),看看其狀態(tài)是否為“已啟動”。如果不是,那么就需要將其設(shè)置為“已啟動”。
    posted @ 2006-03-01 10:03 rodney 閱讀(462) | 評論 (0)編輯 收藏
     

    這個異常是在測試EJB的時候,程序執(zhí)行到ctx.lookup("testEJB")時拋出的。由NamingException捕捉到。打印出棧軌跡是
    javax.naming.NameNotFoundException: Unable to resolve 'TestEJB'. Resolved ''; remaining name 'TestEJB'
     at weblogic.jndi.internal.BasicNamingNode.newNameNotFoundException(BasicNamingNode.java:1123)
     at weblogic.jndi.internal.BasicNamingNode.lookupHere(BasicNamingNode.java:250)
     at weblogic.jndi.internal.ServerNamingNode.lookupHere(ServerNamingNode.java:171)
     at weblogic.jndi.internal.BasicNamingNode.lookup(BasicNamingNode.java:204)
     at weblogic.jndi.internal.WLEventContextImpl.lookup(WLEventContextImpl.java:267)
     at weblogic.jndi.internal.WLContextImpl.lookup(WLContextImpl.java:362)
     at javax.naming.InitialContext.lookup(InitialContext.java:351)
     at testejb.servlet.SrvEJB.init(SrvEJB.java:26)
     at javax.servlet.GenericServlet.init(GenericServlet.java:256)
     at weblogic.servlet.internal.StubSecurityHelper$ServletInitAction.run(StubSecurityHelper.java:265)
     at weblogic.security.acl.internal.AuthenticatedSubject.doAs(AuthenticatedSubject.java:321)
     at weblogic.security.service.SecurityManager.runAs(SecurityManager.java:121)
     at weblogic.servlet.internal.StubSecurityHelper.createServlet(StubSecurityHelper.java:61)
     at weblogic.servlet.internal.StubLifecycleHelper.createOneInstance(StubLifecycleHelper.java:58)
     at weblogic.servlet.internal.StubLifecycleHelper.<init>(StubLifecycleHelper.java:48)
     at weblogic.servlet.internal.ServletStubImpl.prepareServlet(ServletStubImpl.java:502)
     at weblogic.servlet.internal.ServletStubImpl.execute(ServletStubImpl.java:224)
     at weblogic.servlet.internal.ServletStubImpl.execute(ServletStubImpl.java:165)
     at weblogic.servlet.internal.WebAppServletContext$ServletInvocationAction.run(WebAppServletContext.java:3022)
     at weblogic.security.acl.internal.AuthenticatedSubject.doAs(AuthenticatedSubject.java:321)
     at weblogic.security.service.SecurityManager.runAs(SecurityManager.java:121)
     at weblogic.servlet.internal.WebAppServletContext.securedExecute(WebAppServletContext.java:1925)
     at weblogic.servlet.internal.WebAppServletContext.execute(WebAppServletContext.java:1848)
     at weblogic.servlet.internal.ServletRequestImpl.run(ServletRequestImpl.java:1288)
     at weblogic.work.ExecuteThread.execute(ExecuteThread.java:207)
     at weblogic.work.ExecuteThread.run(ExecuteThread.java:179)
    我的ejb-jar.xml文件描述如下:
    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE ejb-jar PUBLIC "-//Sun Microsystems, Inc.//DTD Enterprise JavaBeans 2.0//EN" "

    <ejb-jar>
      <display-name>EJB</display-name>
      <enterprise-beans>
        <session>
          <ejb-name>TestEJB</ejb-name>
          <home>testejb.ejb.TestEJBHome</home>
          <remote>testejb.ejb.TestEJBRemote</remote>
          <ejb-class>testejb.ejb.TestEJBBean</ejb-class>
          <session-type>Stateless</session-type>
          <transaction-type>Container</transaction-type>
        </session>
      </enterprise-beans>
      <assembly-descriptor>
        <container-transaction>
          <method>
            <ejb-name>TestEJB</ejb-name>
            <method-name>*</method-name>
          </method>
          <trans-attribute>Required</trans-attribute>
        </container-transaction>
      </assembly-descriptor>
    </ejb-jar>

    weblogic-ejb-jar.xml文件描述如下:
    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE weblogic-ejb-jar PUBLIC "-//BEA Systems, Inc.//DTD WebLogic 8.1.0 EJB//EN" "

    <weblogic-ejb-jar>
      <weblogic-enterprise-bean>
        <ejb-name>TestEJB</ejb-name>
        <jndi-name>TestEJB</jndi-name>
      </weblogic-enterprise-bean>
    </weblogic-ejb-jar>
    這些配置我都寫了為什么還有名字沒有找到的異常呢?
    請大家?guī)兔纯础Vx謝! QQ:86322591。MSN:rodney_luo@163.com

     
    系統(tǒng)環(huán)境:
    OS: Windows Server 2000 SP4
    開發(fā)工具:JBuilder 2006。
    WEB服務(wù)器:Weblogic9.0
    數(shù)據(jù)庫:DB2 V7.2
    使用Type2的JDBC連接方式。因為DB2 V7.2只支持Type2與Type3的連接。
    我新建了一個TestDB類,在這個類中我可以連接到DB2中,并且取出數(shù)據(jù)。可是我把這個連接的方法寫到Servlet中就不能連接到該數(shù)據(jù)庫中了。拋出ClassNotFoundException的異常。  請大家?guī)兔矗以谙到y(tǒng)環(huán)境有設(shè)置Classpath的DB2驅(qū)動程序包。并在WEB-INF\lib目錄下也有這個驅(qū)程驅(qū)動程序包。它就是在Sevelt中要拋出ClassNotFoundException的異常。。。。。
    QQ:86322591
    MSN: rodney_luo@163.com
    Email: rodney_luo@163.com

    謝謝大家。
    posted @ 2006-02-17 13:17 rodney 閱讀(476) | 評論 (0)編輯 收藏
     
    我想各位網(wǎng)上的朋友常為了找不到自己合適的工具而煩吧。http://www.9iv.com/down/index.htm?eid=236712這里有你想要的一切工具軟件,開發(fā)工具,商務(wù)軟件。一切的軟件盡在http://www.9iv.com/down/index.htm?eid=236712中。
    posted @ 2006-02-15 09:46 rodney 閱讀(444) | 評論 (0)編輯 收藏
     
    1.查詢返回結(jié)果數(shù)量的設(shè)置
      缺省的情況下,一個全文本索引查詢的結(jié)果被限制為250個文檔,如果你想改變查詢返回
      QueryMaxResults=XXXX;
      XXXX代表一個小于5000的數(shù),如果XXXX超過5000,查詢將會變得很不穩(wěn)定,我建議最好將
      2.NOTES.INI中PREFERENCES變量的設(shè)置
      在NOTES.INI中的PREFERENCES變量的值一直是個迷,LOTUS公司一直沒有提供詳細的說明
    。直到現(xiàn)在,經(jīng)過國內(nèi)外LOTUS愛好者的研究,才弄清楚它的大體含義。其實,PREFERENCES
    變量的值是一個有正負的32位WORD變量的十進制表示法,其中每一位代表一個不同的優(yōu)先設(shè)置
      位位置 = 用戶優(yōu)先設(shè)置選擇
      0 = 不詳
      1 =掃描未讀文檔
      2 =不詳
      3 =大字體
      4 =不詳
      5 =將Internet URLs地址 (http//:)變?yōu)闊狳c
      6 =不詳
      7 = 只有打字機字體
      8 =單色顯示
      9 = Scandinavian 校驗
      10 =不詳
      11 = 保存已發(fā)送郵件
      12 =發(fā)送郵件簽名
      13 =發(fā)送郵件加密
      14 = Metric(1)/Imperial(0)度量
      15 =最近校驗的次數(shù)
      16 = 法國包裝
      17 =不詳
      18 = 每隔X分鐘檢查一次新郵件
      19 = 使能本地后臺索引
      20 = 加密保存的郵件
      21 =不詳
      22 =不詳
      23 =右鍵雙擊關(guān)閉窗口
      24 =位置提示
      25 =不詳
      26 = 在預覽框中打開文檔后將文檔標記為已讀
      27 = 使能本地預定代理
      28 =保存發(fā)送郵件(總是提示,1=YES,0=NO)
      29 = 使新郵件提示可見
      30 =使新郵件提示可以聽見
      31 =有紋理的工作臺
      3.DOMINO最大限度獲得系統(tǒng)可用內(nèi)存的設(shè)置
      在NOTES.INI文件中加入以下變量:
      Platform_Statistics_Enabled=1
      強烈建議在NOTES.INI文件中加入上面一行,這樣會讓DOMINO可以最大限度的獲得系統(tǒng)的
    內(nèi)存,提高DOMINO服務(wù)器的性能。Domino 5.0.2 (或更高版本)的這個屬性支持NT和Solaris
      4.取消NOTES的缺省郵件程序地位
      大家可能都遇到過,如果NOTES被當作缺省的郵件程序時,當你點擊MAILTO聯(lián)接的時候,
    就會啟動NOTES,耗時費勁,那么怎樣改變NOTES的缺省郵件程序地位呢?在NOTES.INI中加
      NotDefaultMailTo=1
      將取消NOTES的缺省郵件程序地位。
      5.用層疊地址本(cascaded address book)鑒別WEB用戶
      在Domino 4.6.1以前的版本中,都可以使用層疊地址本(cascaded address book)鑒別
    WEB用戶,但是到了Domino 4.6.2以后,不再支持用層疊地址本鑒別WEB用戶,取而代之的是
    用主NAB鑒別WEB用戶。為了鑒別WEB用戶,我們不得不使用主地址本,不過在NOTES.INI中加
    入以下行,你將會重新可以使用層疊地址本鑒別WEB用戶。
      NoMABForWebNames=1
      6.在工作站上隱藏設(shè)計菜單
      如果你不想讓工作站上的用戶創(chuàng)建個人視圖,可以用以下的方法隱藏設(shè)計菜單:
      NoDesignMenu=1或0
      1------隱藏設(shè)計菜單
      0------不隱藏設(shè)計菜單
      7.改變郵件到達的提示聲音
      大家可能已經(jīng)厭煩了LOTUS卻省的郵件到達提示聲音,不用急,改變一下notes.ini,你
    可以使用任何的聲音了。方法如下,在notes.ini中加入以下行:
      NewMailTune=[相對于NOTES DATA目錄的.wav文件的完整路徑].
      如:NewMailTune=c:winntmediamessage.wav
      現(xiàn)在你可以使用任何喜歡的聲音了。
      8.使用附加的地址本
      在NOTES.INI文件中加入以下行:
      Names=NAMES.NSF,NAMES1.NSF
      NOTES將會在NAMES.NSF和NAMES1.NSF兩個地址本中尋找用戶。

    9.設(shè)置新郵件檢查時間間隔
      在NOTES.INI文件中加入以下行:
      MinNewMailPoll= 時間(分鐘)
      工作站將會根據(jù)以上的設(shè)置,每隔一定時間檢查服務(wù)器上的新郵件。卻省的設(shè)置是15分鐘
      10.指定NOTES所用內(nèi)存大小
      通過在NOTES.INI中使用以下行:
      Memory_Quota = xx
      可以指定NOTES客戶端使用的PC的內(nèi)存大小,其中XX代表所用內(nèi)存的大小,注意XX值設(shè)得
    不要太小,否則會出現(xiàn)問題,NOTES R5比NOTES4.X需要的內(nèi)存多。
      11.記錄已經(jīng)索引的數(shù)據(jù)庫
      可以通過改變NOTES.INI設(shè)置,讓日志記錄已經(jīng)索引的數(shù)據(jù)庫。這個設(shè)置在數(shù)據(jù)庫更新所
    引的時候突然崩潰時非常有用。設(shè)置選項如下:
      要想記錄索引數(shù)據(jù)庫的視圖和文件夾:
      Log_Update=2
      要想只記錄索引過的數(shù)據(jù)庫:
      Log_Update=1
      完全關(guān)閉更新日志
      Log_Update=0
      12.調(diào)試代理
      在NOTES.INI文件中加入以下行,你就可以調(diào)試代理了:
      DEBUG_AMGR = n ,n代表以下的數(shù)值
      r = 代理運行
      l = 代理加載
      m = 代理內(nèi)存警告
      p = 代理性能狀態(tài)
      e = 事件
      s = 計劃安排
      c = 代理控制參數(shù)顯示
      v = 詳細
      * =使能以上所有選項
      13.指定運行的NOTES程序
      當你在同一臺機器上安裝NOTES客戶端和DOMINO服務(wù)器的時候,在NOTES.INI文件中有一
    項會隨之變化:
      KitType=
      1 ? 客戶端
      2 ? 服務(wù)器和客戶端
      14.加速視圖索引的速度
      在NOTES.INI文件中加入以下行,就能在一個視圖首次打開時加速索引的速度:
      GOFASTER=1
      加速視圖索引
      GOFASTER=0
      放慢視圖索引
      15.平行運行WEB觸發(fā)代理
      DominoAsynchronizeAgents = 1
      在NOTES.INI文件中加入以上行之后,可以平行的運行WEB觸發(fā)的代理。
      例如,如果有一個WEBQUERYOPEN代理,同時運行這個代理的幾率很大,但是NOTES不支持
    同時運行同一個代理,因此,如果三個用戶同時申請了運行這個代理,那么只有一個用戶的申
    請被批準,其余的只有等待。用了以上的設(shè)置之后,三個用戶可以同時運行這個代理。
      16.將服務(wù)器窗口的內(nèi)容寫入一個文件
      在NOTES.INI文件中寫入以下行,就可以將服務(wù)器端窗口的內(nèi)容寫入一個文件:   Debug_Outfile = < filename >
      在NOTES4.X中,文件名必須是DEBUG.TXT,每次服務(wù)器重新啟動之后,就會產(chǎn)生一個文件
    DEBUG1.TXT,DEBUG2.TXT等等,依次類推,DEBUG.TXT代表最新的服務(wù)器端的內(nèi)容
    posted @ 2006-01-16 16:05 rodney 閱讀(1079) | 評論 (0)編輯 收藏
     
    初次接觸IBM 的WEbsphere產(chǎn)品系列。大家要注意的幾個地方是在配置與編程程序。一在編程時EJB的在調(diào)用時的lookup("java:comp/env/JNDIEJB")這個名字一定要與EJB的配置描述符一樣,有區(qū)分大小寫。同時最好與BEAN的名字也一樣。二。在用連接池編寫程序時的JNDI也一樣要加上lookup("java:comp/env/JNDIName")這里的JNDI名是在配置連接池指定的JNDI,也有區(qū)分大小寫。在配置WEB,EJB應(yīng)用程序時這兩個程序可以分開配置。但EJB的配置時會多幾步,要把Enteprice Bean這個復選框選上。
    posted @ 2005-12-28 09:26 rodney 閱讀(763) | 評論 (0)編輯 收藏
    僅列出標題
    共5頁: 上一頁 1 2 3 4 5 下一頁 
     
    主站蜘蛛池模板: 久久精品亚洲日本波多野结衣| 国产亚洲精品自在久久| 91亚洲va在线天线va天堂va国产| 久久久受www免费人成| 国产成人亚洲综合无码| 免费无码又爽又黄又刺激网站| 国产免费一区二区三区VR| 亚洲精品无播放器在线播放| 成人毛片手机版免费看| 亚洲成av人片在www鸭子| 日韩a级毛片免费视频| 在线亚洲v日韩v| 亚洲毛片av日韩av无码| 国产亚洲日韩在线a不卡| 免费在线观看理论片| caoporm超免费公开视频| 久久亚洲高清综合| 一级毛片免费观看不卡的| 亚洲视屏在线观看| 毛片免费视频观看| 国产精品亚洲а∨无码播放不卡| 午夜私人影院免费体验区| 羞羞漫画登录页面免费| 亚洲色中文字幕无码AV| 国产精品成人免费福利| 国产成人不卡亚洲精品91| 亚洲精品你懂的在线观看| 最近高清中文字幕无吗免费看| 在线播放亚洲精品| 亚洲午夜久久影院| 亚洲精品国产高清不卡在线| 亚欧在线精品免费观看一区| 特黄特色大片免费| 亚洲日本在线播放| 亚洲欧洲无码AV电影在线观看| 永久免费毛片在线播放| 久久国产高潮流白浆免费观看| 亚洲欧美在线x视频| 亚洲同性男gay网站在线观看| 亚洲五月午夜免费在线视频| 美女视频黄的全免费视频|