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

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

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

    yanmin

      BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
      16 隨筆 :: 1 文章 :: 9 評論 :: 0 Trackbacks

    2006年3月20日 #

         摘要:   閱讀全文
    posted @ 2012-07-12 16:48 yanmin 閱讀(861) | 評論 (0)編輯 收藏

    最近做一個項目,里面很多特殊字符,引發了一些問題,解決后很開心,特別來分享。
    特殊字符:
    Jörg Ranau
    Sigut? Jakštonyt?
    Côte d'Ivoire

    數據庫手工導入數據

    1 先檢查數據庫的字符集和客戶端字符集是否一致。 采用的是UTF8
    查看語句:
    select * from nls_database_parameters

    2 若是采用DOS 下的SQLPLUS 導入數據,需要set NLS_LANG=AMERICAN_AMERICA.UTF8
    windows:    set NLS_LANG=AMERICAN_AMERICA.UTF8
    unix:    NLS_LANG=AMERICAN_AMERICA.UTF8

    3:   檢查導入的數據的文件格式,格式采用: UTF8 without BOM, 
    可以用NOTEPAD++, CONVER TO UTF8 without BOM
    也可以用txt , 轉換成UTF8.

    第3點非常重要,之前忽略了,發現插入導入數據庫后,數據顯示不對。

    驗證你導入的數據是否正確可以用ORACLE DUMP 命令。
    select dump(country_desc),country_desc  from tb_test  where testcode='1';
    Typ=1 Len=14: 67,195,180,116,101,32,100,39,73,118,111,105,114,101        Côte d'Ivoire


    數據庫腳本中遇到特殊字符:
    1:  單引號‘ , oracle 腳本需要寫成 兩個單引號
    UPDATE pi_portal_nday SET ND_CTY='Côte d'‘Ivoire' WHERE ND_ID IN (152,162);

    2: 特殊字符&, oracle 表示需要的參數, 若是數據中有這個有2個方法:
    第1 種: set define off;

    第2種:
    set escape on;
    然后將所有的&, 替換成/&。

    3: 空行
    用<br> 代替。


    JAVA 代碼導入數據:

    要導入的數據都放在TXT 類型的文件里,通過batch job 導入數據庫。 
    檢查導入的數據的文件格式,格式采用: UTF8 without BOM, 
    可以用NOTEPAD++, CONVER TO UTF8 without BOM

    java 代碼:
    1 讀文件的時候采用 UTF8格式。

    InputStreamReader read = new InputStreamReader (new FileInputStream(file),"UTF-8");
    BufferedReader inBuf=new BufferedReader(read); 

    2 檢查所用開發工具的文件ENCODING 字符。
    這個就是會為什么導致沒發現 讀文件錯誤,在開發工具中打出的LOG 欺騙了我們的眼睛。

    我的開發工具BEA JAVA 文件默認ENCODING cp1252, 改成UTF8 就好了。這個特別容易忽略,當在控制臺看LOG的時候,發現讀過來的文件里的內容打出來都正確,就忽略了JAVA的源文件。認為是從unicode轉換 utf8 有問題,特別將字符又做了處理,發現插入數據庫還是不正確。 修改了ENCODING 字符字符后發現讀入文件就不對了。這樣輕松就解決了。 所以只要修改了讀文件的時候采用 UTF8格式就可以啦。


    JAVA 代碼中直接賦值的或是頁面錄入的。
    1: 頁面的就很簡單了,JSP 或是HTML ,里面加入字符是UTF8的就OK
    2: 代碼里面的,需要轉換:
    byte[] byteArr1 = columnValueBe.getBytes("UTF-8");
    columnValue = new String(byteArr1, "UTF-8");













    posted @ 2011-05-20 18:29 yanmin 閱讀(1991) | 評論 (1)編輯 收藏

         用了這么多年計算機, 發現很多計算機的快捷命令都不知道, 汗啊,  從網上搜尋下一些,COPY 在這是沒用的,打下來用的時候就看:

    這些命令都是從開始——運行處進行的(windows鍵+R)

           'cmd'     這個命令是調用類似dos的命令窗口的命令,在這里你可以像操作DOS一樣操作Windows.

           'inetmgr'   這個命令相信做過網站的都知道,對了這就是調用IIS的快捷命令。

           'mstsc'     這個是用來啟動遠程桌面連接的快捷命令,相信搞過網絡的人對此不會陌生。

           'regedit'   這個命令大家都很熟悉,是用來調用注冊表的。

           'appwiz.cpl'     進入添加和刪除程序的快捷命令

           'control userpasswords2'         進入用戶賬戶設置界面的命令

           'cleanmgr'                       磁盤垃圾清理快捷命令

          'command.com'               調用的則是系統內置的 NTVDM,一個 DOS虛擬機。它完全是一個類似 Virtual PC 的 虛擬環

    境,和系統本身聯系不大。當我們在命令提示符下運行 DOS 程序時,實際上也 是自動轉移到 NTVDM虛擬機下,和 CMD

    本身沒什么關系。

          'calc'           啟動計算器

          'chkdsk.exe'                 磁盤檢查

          'compmgmt.msc'           計算機管理

          'devmgmt.msc'               設備管理器

          diskmgmt.msc              磁盤管理實用程序

          'dfrg.msc '                      磁盤碎片整理程序

          'drwtsn32'             系統醫生

          'dvdplay'                Windows Media Player

          'explorer'               資源管理器

          'dxdiag'                   DirectX Diagnostic Tool

          'gpedit.msc'           組策略編輯器

          'gpupdate /target:computer /force'              強制刷新組策略

          'eventvwr.exe'                       事件查看器

          'logoff'                    注銷命令

          'lusrmgr.msc'            本地用戶和組   

          'msinfo32'                   系統信息

          'msconfig'                   系統配置實用程序

          'net start (servicename)'        啟動該服務

          'net stop (servicename)'停止該服務

          'notepad'           記事本

         'nusrmgr.cpl'       同control userpasswords,打開用戶帳戶控制面板

         'Nslookup'           IP地址偵測器

         'oobe/msoobe /a'             檢查XP是否激活

         'perfmon'                計算機性能監視器

         'regedit'                   系統注冊表

         'regedt32'                 注冊表編輯器

         'regsvr32 /u *.dll'      停止dll文件運行

         'route print'             查看路由表

         'rononce -p'             15秒快速關機

         'rsop.msc'               組策略結果集

         'rundll32.exe rundll32.exe %Systemroot%\System32\shimgvw.dll,ImageView_Fullscreen'    啟動一個空白的Windows 圖

    片和傳真查看器

         ' secpol.msc'             本地安全策略

         'services.msc'            本地服務設置

         'sfc /scannow'          啟動系統文件檢查器

         'sndrec32'               錄音機

         'taskmgr'                 任務管理器

         'tsshutdn'               60秒倒記時關機命令

         'winchat'                  winxp自帶局域網聊天

         'winmsd'                  系統信息

         'winver'                  顯示About Windows 窗口

         'wupdmgr'                 update

         'firewall.cpl'             防火墻

         'magnify'                  放大鏡

         'sysdm.cpl'               系統屬性

         'sysdm.cpl'               windows系統安全工具

         'write'                     寫字板

         'tourstart'                Windows XP 漫游

         'utilman'                   輔助工具管理器

        'spider'                     蜘蛛牌游戲

        'sysedit'                   系統配置編輯器

        系統文件檢查工具(立即掃描) sfc /scannow

       系統文件檢查工具(下次啟動時掃描) sfc /scanonce

       系統文件檢查工具(每次啟動時掃描) sfc /scanboot

       系統文件檢查工具(返回默認設置) sfc /revert

       系統文件檢查工具(清除文件緩存) sfc /purgecache

       系統文件檢查工具(設置緩存大小=x) sfc /cachesize=x

       'cliconfg'                SQL Client客戶端網絡實用工具

       'mmsys.cpl'             聲音和音頻設備屬性       

      'shutdown'               關閉windows

      'fsmgmt.msc'           共享文件夾

       'wscui.cpl'              Windows安全中心

       'control schedtasks'       任務計劃

       'sticpl.cpl'               掃描儀與相機

        'ntmsmgr.msc'         可移動存儲

        'intl.cpl'             區域的語言選擇

        'eudcedit'          TrueType造字程序

        'control printers'    打印機和傳真

       'powercfg.cpl'          電源選項屬性

       'telephon.cpl'      電話與調制解調器選項

        'osk'           屏幕鍵盤

        'odbccp32.cpl'           ODBC數據源管理器

        'packager'              對象包裝程序

        'ncpa.cpl' /'control netconnections'            網絡連接

        'netsetup.cpl'        網絡連接向導

        'main.cpl' /'control mouse'         鼠標屬性

        'winmine'                 掃雷游戲

        'secpol.msc'            本地安全設置

        'control keyboard'         鍵盤屬性

       IP配置實用程序(顯示連接配置) ipconfig /all
      IP配置實用程序(顯示DNS緩存內容) ipconfig /displaydns
      IP配置實用程序(刪除DNS緩存內容) ipconfig /flushdns
      IP配置實用程序(釋放全部(或指定)適配器的由DHCP分配的動態IP地址) ipconfig /release
      IP配置實用程序(為全部適配器重新分配IP地址) ipconfig /renew
      IP配置實用程序(刷新DHCP并重新注冊DNS) ipconfig /registerdns
      IP配置實用程序(顯示DHCP Class ID) ipconfig /showclassid
      IP配置實用程序(修改DHCP Class ID) ipconfig /setclassid

      'inetcpl.cpl'                internet屬性

       'ciadv.msc'                  索引服務

      'winver'                      檢查windows版本號

      'mplayer2'                  簡易widnows media player

       'mspaint'                     畫圖板

       'mem.exe'                顯示內存使用狀況

       'compmgmt.msc'               計算機管理

       'wmimgmt.msc'                   打開windows管理體系結構(WMI)

       'ntbackup'                          系統備份與還原

      'narrator'                         屏幕“講述人”

      'netstat  -an'                   (TC)命令檢查接口

      'syncapp'                     創建一個公文包

       'sigverif'                       文件簽名驗證程序

        'certmgr.msc'               證書管理實用程序

       'iexpress'                     木馬捆綁工具,系統自帶

        'access.cpl'                   輔助功能選項

        'fsquirt'                  Bluetooth文件傳送向導

        'dcomcnfg'                     組件服務

         'timedate.cpl'                 日期時間屬性

         'ddeshare'                         DDE共享

         'control desktop'             顯示屬性

         'desk.cpl'                        顯示屬性

         'control.cpl'                  顯示屬性的外觀選項卡

         'sigverif'                     文件簽名驗證 

        快速查找 findfast.cpl

       文件夾選項 control folders

       字體文件夾 control fonts

       字體文件夾 fonts

        'freecell'         空檔接龍游戲 

        'joy.cpl'              游戲控制 

    posted @ 2008-01-03 10:00 yanmin 閱讀(248) | 評論 (1)編輯 收藏

         toad 中的中文顯示“靠”

    本來就超級忙,被迫重裝了系統,重新建了庫,一切都OK的時候,發現用TOAD連接ORACLE 數據庫,里面的中文字都顯示“靠”, 第一個反映,遭了,數據庫文字設置不對,要是數據庫重裝,那又要浪費2天??!

    幸好,用其他機器的TOAD,中文字顯示正確; 明白了是自己新裝的操作系統的原因。 網上查到解決辦法, 解決了,心又落回來了??!

        在環境變量中設置系統環境變量:

       NLS_lANG = SIMPLIFIED CHINESE_CHINA.ZHS16GBK

    posted @ 2007-10-29 11:45 yanmin 閱讀(739) | 評論 (1)編輯 收藏

    最近狂多的面試,發現自己的基礎知識和理論都弱了很多,為了不誤人子弟,開始惡補:

    一.Enterprise Beans
      在EJB(Enterprise Java Beans)中定義了兩種不同類別的Enterprise Bean :
      *會話 Bean (Session Bean)
      *實體Bean (Entity Bean)
      
      1. 會話 Bean (Session Bean)
      會話 Bean 是調用它的客戶端代碼要完成的工作。當客戶端與服務器建立聯系,那么一個會話 Bean 就建立起來了。根據會話 Bean 的狀態不同有分為:
      A. 狀態會話 Bean (Stateful Session Bean)
      B. 無狀態會話 Bean (Stateless Session Bean)
      1.1 狀態會話 Bean (Stateful Session Bean)
      當客戶機和服務器建立連接之后,狀態會話 Bean (Stateful Session Bean) 將一直在客戶機和服務器之間保持著用戶的某個狀態。例如:用戶使用銀行的ATM時,經過驗證之后,用戶可以連續執行多次操作,在這個過程當中,用戶的合法狀態將一直被保留,直到她將信用卡取出,結束這次操作。這時,狀態會話 Bean (Stateful Session Bean) 也就被銷毀。
      1.2無狀態會話 Bean (Stateless Session Bean)
      當客戶機和服務器建立連接之后,無狀態會話 Bean (Stateless Session Bean)處理單一的用戶請求或商務過程。無狀態會話 Bean (Stateless Session Bean)不需要從以前的請求中提取任何狀態。例如,用戶的用戶密碼確認。用戶輸入密碼后,發送請求。組件返回真或假來確認用戶,一旦過程完成,無狀態會話 Bean (Stateless Session Bean) 也宣告結束。
      2. 實體Bean (Entity Bean)
      實體Bean (Entity Bean)只是數據模型,它不包括商務邏輯。實體Bean (Entity Bean)可以將關系/對象數據庫的數據映射到內存中供其它組件使用。實體Bean (Entity Bean)是一直存在的,而且具有很高的容錯性能。實體Bean (Entity Bean)能供允許多用戶同時訪問。
      
      二. 會話 Bean (Session Bean)
      Ejb的執行過程是被放在一個EJB容器中進行的,所以客戶端不會直接調用我們寫好的Enterprise Bean ,而是調用EJB容器生成的一個EJBObject (EJB對象)來實現。那么,我們在編寫服務器端的Enterprise Bean 時,就要考慮這點。既然客戶端不能直接訪問,就由EJBObject來代勞,所以在編寫服務器端時,就要編寫服務器端的一個接口(Remote)用來與客戶機聯系,實力化EJBObject。要生成EJBObject 就要調有Home 接口,來建立這個實力。
      
      以下是會話 Bean 的代碼分析:
      A.Enterprise Bean 類:sailorsy.class
      1.setSessionContext(SessionContext ctx)方法
      它是EJB容器和Enterprise Bean互相作用的關口。
      
      import java.rmi.*;
      import javax.ejb.*;
      public class sailorsy implements SessionBean{
      private SessionContext ctx=null;
      public voic setSessionContext(SessionContext ctx)//setSessionContext
      }//class sailorsy
      
      2.ejbCreate(…)方法
      它可以初始化Enterprise Bean ,可以定義不同的ejbCreate(…)方法,每個方法所帶的參數不同。但是,必許要存在至少一種。
      
       import java.rmi.*;
       import javax.ejb.*;
      public class sailorsy implements SessionBean{
      private SessionContext ctx=null;
      public voic setSessionContext(SessionContext ctx)//setSessionContext
          public void ejbCreate() //ejbCreate
      }//class sailorsy
      
      3.ejbPassivate()方法
      如果初始化的Enterprise Bean 過多,EJB容器將其中的一些掛起(passivate),釋放他們所占用的空間。
      
       import java.rmi.*;
       import javax.ejb.*;
      public class sailorsy implements SessionBean{
      private SessionContext ctx=null;
      
      public voic setSessionContext(SessionContext ctx)//setSessionContext
      
          public void ejbCreate() //ejbCreate
          public void ejbPassivate() //ejbPassivate
      
      }//class sailorsy
      
      4.ejbActivate()方法
      和ejbPassivate正好相反,它將被掛起的Bean從新調回。
      
      import java.rmi.*;
       import javax.ejb.*;
      public class sailorsy implements SessionBean{
      private SessionContext ctx=null;
      
      public voic setSessionContext(SessionContext ctx)//setSessionContext
      
          public void ejbCreate() //ejbCreate
          public void ejbPassivate() //ejbPassivate
          
          public void ejbActivate() //ejbActivate
      
      }//class sailorsy
      
      5.ejbRemove()方法
      它可以清除EJB容器中的Bean。
      
       import java.rmi.*;
       import javax.ejb.*;
      public class sailorsy implements SessionBean{
      private SessionContext ctx=null;
      
      public voic setSessionContext(SessionContext ctx)//setSessionContext
      
          public void ejbCreate() //ejbCreate
      
          public void ejbPassivate() //ejbPassivate
          
          public void ejbActivate() //ejbActivate
      
          public void ejbRemove() //ejbRemove
         
           public String showname(){
           return "Hello,my name is sailorsy";
          }//自己的商務方法
      }//class sailorsy
      
      以上這些是EJB必需的回調方法,我們可以在里面加入自己的方法,加入自己的商務邏輯。
      B.Home 接口: sailorsyHome
      
        import java.rmi.*;
      import javax.ejb.*;
      
      public interface sailorsyHome extends EJBHome {
       public sailorsyRemote create() throws RemoteException, CreateException;
      }
      
      C. Remote接口:sailorsyRemote
      import java.rmi.*;
      import javax.ejb.*;
      
      public interface sailorsyRemote extends EJBObject {
       public java.lang.String showname() throws RemoteException;
      }
      
      三.調用會話 Bean:sailorsyTestClient1
       [code]    import javax.naming.*;
      import javax.ejb.*;
      import javax.rmi.PortableRemoteObject;
      import java.rmi.*;
      
      public class sailorsyTestClient1 {
       private sailorsyHome sailorsyHomeObject = null;
      
       //Construct the EJB test client
       public sailorsyTestClient1() {
        try {
         //以下是客戶端使用JNDI定位Home對象。
         Context ctx = new InitialContext();
      
         //look up jndi name
         Object ref = ctx.lookup("sailorsy");
      
         //cast to Home interface
         sailorsyHomeObject = (sailorsyHome) PortableRemoteObject.narrow(ref, sailorsyHome.class);
      
        }
        catch(Exception e)
       }
      
       //----------------------------------------------------------------------------
       // Utility Methods
       //----------------------------------------------------------------------------
      
       public sailorsyHome getHome() {
        return sailorsyHomeObject;
       }
       //Main method
      
       public static void main(String[] args) throws Exception{
        sailorsyTestClient1 client = new sailorsyTestClient1();
        sailorsyRemote sr=client.getHome() .create()
        String s=sr.showname()
        System.out.print(s);
        // Use the getHome() method of the client object to call Home interface
        // methods that will return a Remote interface reference. Then
        // use that Remote interface reference to access the EJB.
       }
      }[/code]
      
      以上的EJB在win2000+jbuilder5/jbuilder6+BAS4.5經過測試。
      
      以下是整個EJB的執行過程:
      1. 客戶端通過JNDI檢索Home對象的引用;
      2. JNDI返回Home對象的引用;
      3. 請求創建一個新的EJB對象;
      4. 創建EJB對象;
      5. 返回EJB對象;
      6. 調用商務方法;
      7. 調用Enterprise Bean.
    posted @ 2007-10-19 15:57 yanmin| 編輯 收藏

    實現java1.4中的split()函數功能的代碼- -

    ??????????????????????????????????????

    split()函數是分隔字符串的函數,在JDK1.4以后才有的.

    在以前的版本里要用這個函數時,需要自己去寫.

    lotus r6中的JDK是1.3的,寫JAVA代理時也需要自己寫這個函數


    import java.util.*;
    public class test
    {
    ? public static void main(String args[])
    ??? {
    ????? Vector v = new Vector();
    ????? test t = new test();
    ????? v = t.splitString("b","aaabccccbddddbeeeeee");
    ????? System.out.println(v.size());
    ????? for (int i = 0;i<v.size();i++)
    ????? {
    ????? ?System.out.println(v.get(i));
    ????? ?}
    ??? ?}
    ??? ?
    ??? ?
    ?? public Vector splitString(String sign, String sourceString)
    ?? {
    ??????? Vector splitArrays = new Vector();
    ??????? int i = 0;
    ??????? int j = 0;
    ??????? if (sourceString.length()==0) {return splitArrays;}
    ??????? while (i <= sourceString.length()) {
    ?????????????? j = sourceString.indexOf(sign, i);
    ?????????????? if (j < 0) {j = sourceString.length();}
    ?????????????? splitArrays.addElement(sourceString.substring(i, j));
    ?????????????? i = j + 1;
    ??????? }
    ??????? return splitArrays;
    ? }
    ?
    }
    posted @ 2006-09-23 17:15 yanmin| 編輯 收藏

    <bean:define id="oe" name="<%=org.apache.struts.taglib.html.Constants.BEAN_KEY%>"/>
    ???? <td class='ssCell' width="6.8%" align="center">
    ???? ?<%
    ???String mrnString = "";
    ???com.phs.ihis.pm.PatientBarInfoModel pbInfoModel = (com.phs.ihis.pm.PatientBarInfoModel)oe;?
    ???if (pbInfoModel.getMrnString() != null && !"".equals(pbInfoModel.getMrnString())){
    ????mrnString = pbInfoModel.getMrnString()+"*";?
    ???}else{
    ????if (pbInfoModel.getPatientNo() != null && !"".equals(pbInfoModel.getPatientNo())){
    ?????mrnString = pbInfoModel.getPatientNo();
    ????}
    ???}?
    ??? ?%>
    ??? ?<a href="javascript: clickPick(
    ??? ???'<%=pbInfoModel.getKey()%>')">
    ??? ???<%=mrnString%>
    ??? ?</a>
    ??? </td>
    posted @ 2006-09-15 10:08 yanmin| 編輯 收藏

    ?myCheckBoxArray.value !=undefined
    posted @ 2006-09-06 19:56 yanmin 閱讀(402) | 評論 (0)編輯 收藏


    這段是放在bodyonload ();剛才做的action :
    document.OTNotesForm.action = contextPath + "/ot/SearchCareproviderOTNotesAction.do?setter="+setter+"&"+type+"="+ParamEncode(value)+"&CareProviderType="+ParamEncode(careproviderType);

    在JSP上的JAVA巧調用javascript 方法
    用的: out.println("javascript 方法(參數1,參數2);");
    ??



    <%
    ??if(request.getAttribute("PopupCareProviderSearch") != null){
    ???String setter = request.getParameter("setter");
    ???String careProviderCode = request.getParameter("CareProviderCode");
    ???String careProviderName = request.getParameter("CareProviderName");
    ???String careProviderType = request.getParameter("CareProviderType");
    ???careProviderCode = careProviderCode == null? "": careProviderCode;
    ???careProviderName = careProviderName == null? "": careProviderName;
    ???out.println("popupCareProvider('"+setter+"','"+careProviderCode+"','"+careProviderName+"','"+careProviderType+"',true);");
    ??}
    ??if(request.getAttribute("RefreshPatientBar") != null){
    ???out.println("top.refreshPatientBar();");
    ??}??
    ??if(request.getAttribute("PopupOrderItemSearch") != null){
    ???String setter = request.getParameter("setter");
    ???String itemCode = request.getParameter("searchCode");
    ???String itemName = request.getParameter("searchDesc");
    ???itemCode = itemCode == null? "": itemCode;
    ???itemName = itemName == null? "": itemName;
    ???out.println("popupOrderItemSearch('"+setter+"','"+itemCode+"','"+itemName+"',true);");
    ??}
    ??String y = request.getParameter("y");
    ??if(y != null){
    ???out.println("document.body.scrollTop="+y+";");
    ??}??
    ?%>
    posted @ 2006-09-06 19:45 yanmin 閱讀(1900) | 評論 (1)編輯 收藏

    get :? userId
    byte[] userId = (byte[])session.getUserMstrPK().getPrimaryKey();
    posted @ 2006-09-01 17:15 yanmin 閱讀(182) | 評論 (0)編輯 收藏

    // 焦點
    window.CommonPatPersonSearchFrame.document.CommonPatPersonSearchForm.txtSearchCode.focus();
    posted @ 2006-09-01 17:14 yanmin 閱讀(467) | 評論 (1)編輯 收藏

    function AddItem(setter,dropdownValue){
    ??// obtain the dropdownlist control
    ??var ct1 = null;
    ??if (setter == "OperateDoctor1"){
    ???ctl = document.OTRequestForm.ddOperateDoctor1Subspecialty;
    ??}
    ??if (setter == "OperateDoctor2"){
    ???ctl = document.OTRequestForm.ddOperateDoctor2Subspecialty;
    ??}
    ??if (setter == "RequestDoctor"){
    ???ctl = document.OTRequestForm.ddRequestDoctorSubspecialty;
    ??}
    ??if (ctl != null){
    ???clearDropdown(ctl);
    ??}
    ??// get the text and value
    ??var subSpecInfo =? dropdownValue.split("&&");
    ??for (i=0; i<subSpecInfo.length; i++){
    ???// create a new option
    ???var newOpt = document.createElement("option");
    ???var subSpec = subSpecInfo[i].split("|");
    ???newOpt.text = subSpec[1];
    ???newOpt.value = subSpec[0];
    ???ctl.add(newOpt);
    ??}
    ???
    }
    posted @ 2006-09-01 17:11 yanmin 閱讀(534) | 評論 (0)編輯 收藏

    得到CVS里所有文件清單

    用WINCVS 不能得到所有CVS里的文件清單,以EXCEL形式。

    現介紹用這個方法:

    1: check out? 最新CVS所有文件。
    2: 用批處理刪除其中的CVS目錄和一些無用的class 文件和其他一些文件。
    3: 用ultraEdit 軟件, 多文件查找,只填寫目錄和選中搜索子目錄,和保存到新文件。


    此批處理文件用來參數CVS目錄和一些有標志的文件或目錄

    @echo On
    @Rem 刪除CVS版本控制目錄

    @REM 刪除所有有規律的目錄
    @for /r . %%a in (.) do @if exist "%%a\CVS" rd /s /q "%%a\CVS"

    @REM 刪除所有有規律的文件
    @for /r . %%a in (.) do @if exist "%%a\EJS*.*" del /f /s /q "%%a\EJS*.*"

    @for /r . %%a in (.) do @if exist "%%a\_*.*" del /f /s /q "%%a\_*.*"

    @Rem for /r . %%a in (.) do @if exist "%%a\CVS" @echo "%%a\CVS"

    @echo Mission Completed.
    @pause

    posted @ 2006-09-01 17:09 yanmin 閱讀(353) | 評論 (0)編輯 收藏

    進入首頁立刻會彈出一個窗口,或者按一個連接或按鈕彈出,通常在這個窗口里會顯示一些注意事項、版權信息 、警告、歡迎光顧之類的話或者作者想要特別提示的信息。只要往該頁面的HTML里加入幾段Javascript代碼即可實現.

    ????? window.open ('page.html', 'newwindow', 'height=100, width=400, top=0,
    ????? left=0, toolbar=no, menubar=no, scrollbars=no, resizable=no,location=n o,
    ????? status=no') //這句要寫成一行


    參數解釋:
      
      <SCRIPT LANGUAGE="javascript"> js腳本開始;
      window.open 彈出新窗口的命令;
      'page.html' 彈出窗口的文件名;
      'newwindow' 彈出窗口的名字(不是文件名),非必須,可用空''代替;
      height=100 窗口高度;
      width=400 窗口寬度;
      top=0 窗口距離屏幕上方的象素值;
      left=0 窗口距離屏幕左側的象素值;
      toolbar=no 是否顯示工具欄,yes為顯示;
      menubar,scrollbars 表示菜單欄和滾動欄。
      resizable=no 是否允許改變窗口大小,yes為允許;
      location=no 是否顯示地址欄,yes為允許;
      status=no 是否顯示狀態欄內的信息(通常是文件已經打開),yes為允許;
      </SCRIPT> js腳本結束


    【1、最基本的彈出窗口代碼】
    ?????   
    ?????   <SCRIPT LANGUAGE="javascript">
    ?????   <!--
    ?????   window.open ('page.html')
    ?????   -->
    ?????   </SCRIPT>
    ?????   
    ?????   因為著是一段javascripts代碼,所以它們應該放在<SCRIPT
    ????? LANGUAGE="javascript">標簽和</script>之間。<!-- 和
    ????? -->是對一些版本低的瀏覽器起作用,在這些老瀏覽器中不會將標簽中的代碼作為文本顯示出來。要養成這個好習慣啊。window.open
    ????? ('page.html')
    ????? 用于控制彈出新的窗口page.html,如果page.html不與主窗口在同一路徑下,前面應寫明路徑,絕對路徑(http://)和相對路徑(../)均可。用單引號和雙引號都可以,只是不要混用。這一段代碼可以加入HTML的任意位置,<head>和</head>之間可以,<body>間</body>也可以,越前越早執行,尤其是頁面代碼長,又想使頁面早點彈出就盡量往前放。
    ?????  
    ?????   【2、經過設置后的彈出窗口】
    ?????   
    ?????   下面再說一說彈出窗口的設置。只要再往上面的代碼中加一點東西就可以了。
    我們來定制這個彈出的窗口的外觀,尺寸大小,彈出的位置以適應該頁面的具體情況。
    ?????   
    ?????   <SCRIPT LANGUAGE="javascript">
    ?????   <!--
    ?????   window.open ('page.html', 'newwindow', 'height=100, width=400, top=0,
    ????? left=0, toolbar=no, menubar=no, scrollbars=no, resizable=no,location=n o,
    ????? status=no') //這句要寫成一行
    ?????   -->
    ?????   </SCRIPT>
    ?????   ?????   
    ?????   【3、用函數控制彈出窗口】
    ?????   
    ?????   下面是一個完整的代碼。
    ?????   <html>
    ?????   <head>
    ?????   <script LANGUAGE="JavaScript">
    ?????   <!--
    ?????   function openwin() {
    ?????   window.open ("page.html", "newwindow", "height=100, width=400, toolbar
    ????? =no, menubar=no, scrollbars=no, resizable=no, location=no, status=no")
    ????? //寫成一行
    ?????   }
    ?????   //-->
    ?????   </script>
    ?????   </head>
    ?????   <body onload="openwin()">
    ?????   任意的頁面內容...
    ?????   </body>
    ?????   </html>
    ?????   這里定義了一個函數openwin(),函數內容就是打開一個窗口。在調用它之前沒有任何用途。怎么調用呢?

    ?????   方法一:<body onload="openwin()"> 瀏覽器讀頁面時彈出窗口;
    ?????   方法二:<body onunload="openwin()"> 瀏覽器離開頁面時彈出窗口;
    ?????   方法三:用一個連接調用:
    ?????   <a href="#" onclick="openwin()">打開一個窗口</a>
    ?????   注意:使用的“#”是虛連接。
    ?????   方法四:用一個按鈕調用:
    ?????   <input type="button" onclick="openwin()" value="打開窗口">
    ?????  
    ?????  
    ?????   【4、同時彈出2個窗口】
    ?????   
    ?????    對源代碼稍微改動一下:
    ?????   
    ?????   <script LANGUAGE="JavaScript">
    ?????   <!--
    ?????   function openwin() {
    ?????   window.open ("page.html", "newwindow", "height=100, width=100, top=0,
    ????? left=0,toolbar=no, menubar=no, scrollbars=no, resizable=no, location=n o,
    ????? status=no")//寫成一行
    ?????   window.open ("page2.html", "newwindow2", "height=100, width=100, top=1
    ????? 00, left=100,toolbar=no, menubar=no, scrollbars=no, resizable=no, loca
    ????? tion=no, status=no")//寫成一行
    ?????   }
    ?????   //-->
    ?????   </script>
    ?????   為避免彈出的2個窗口覆蓋,用top和left控制一下彈出的位置不要相互覆蓋即可 。最后用上面說過的四種方法調用即可。
    ?????   注意:2個窗口的name(newwindows和newwindow2)不要相同,或者干脆全部為空。
    ??????
    ?????   【5、主窗口打開文件1.htm,同時彈出小窗口page.html】

    ?????   如下代碼加入主窗口<head>區:
    ?????   <script language="javascript">
    ?????   <!--
    ?????   function openwin() {
    ?????   window.open("page.html","","width=200,height=200")
    ?????   }
    ?????   //-->
    ?????   </script>
    ?????   加入<body>區:
    ?????   <a href="1.htm" onclick="openwin()">open</a>即可。
    ??????
    ?????   【6、彈出的窗口之定時關閉控制】
    ?????   
    ?????   下面我們再對彈出的窗口進行一些控制,效果就更好了。如果我們再將一小段
    ????? 代碼加入彈出的頁面(注意是加入page.html的HTML中,可不是主頁面中,否則 ...),讓它10秒后自動關閉是不是更酷了?
    ????? 首先,將如下代碼加入page.html文件的<head>區:
    ?????   <script language="JavaScript">
    ?????   function closeit()
    ?????   {
    ?????   setTimeout("self.close()",10000) //毫秒
    ?????   }
    ?????   </script>
    ?????   然后,再用<body onload="closeit()">
    ????? 這一句話代替page.html中原有的<BODY>這一句就可以了。(這一句話千萬不要忘記寫??!這一句的作用是調用關閉窗
    ????? 口的代碼,10秒鐘后就自行關閉該窗口。)
    ?????   【7、在彈出窗口中加上一個關閉按鈕】

    ?????   <FORM>
    ?????   <INPUT TYPE='BUTTON' VALUE='關閉' onClick='window.close()'>
    ?????   </FORM>
    ?????   呵呵,現在更加完美了!

    ?????   【8、內包含的彈出窗口-一個頁面兩個窗口】
    ?????   上面的例子都包含兩個窗口,一個是主窗口,另一個是彈出的小窗口。通過下面的例子,你可以在一個頁面內完成上面的效果。

    ?????   <html>
    ?????   <head>
    ?????   <SCRIPT LANGUAGE="JavaScript">
    ?????   function openwin()
    ?????   {
    ?????   OpenWindow=window.open("", "newwin", "height=250, width=250,toolbar=no
    ????? ,scrollbars="+scroll+",menubar=no");
    ?????   //寫成一行
    ?????   OpenWindow.document.write("<TITLE>例子</TITLE>")
    ?????   OpenWindow.document.write("<BODY BGCOLOR=#ffffff>")
    ?????   OpenWindow.document.write("<h1>Hello!</h1>")
    ?????   OpenWindow.document.write("New window opened!")
    ?????   OpenWindow.document.write("</BODY>")
    ?????   OpenWindow.document.write("</HTML>")
    ?????   OpenWindow.document.close()
    ?????   }
    ?????   </SCRIPT>
    ?????   </head>
    ?????   <body>
    ?????   <a href="#" onclick="openwin()">打開一個窗口</a>
    ?????   <input type="button" onclick="openwin()" value="打開窗口">
    ?????   </body>
    ?????   </html>
    ?????   看看OpenWindow.document.write()里面的代碼不就是標準的HTML嗎?只要按照
    ????? 格式寫更多的行即可。千萬注意多一個標簽或少一個標簽就會出現錯誤。記得用 OpenWindow.document.close()結束啊。
    ?????   【9、終極應用--彈出的窗口之Cookie控制】
    ?????   回想一下,上面的彈出窗口雖然酷,但是有一點小毛病(沉浸在喜悅之中,一定
    ????? 沒有發現吧?)比如你將上面的腳本放在一個需要頻繁經過的頁面里(例如首頁),那么每次刷新這個頁面,窗口都會彈出一次,是不是非常煩人?:-(
    ?????   有解決的辦法嗎?Yes! ;-) Follow me.我們使用cookie來控制一下就可以了。
    ?????   首先,將如下代碼加入主頁面HTML的<HEAD>區:
    ?????   <script>
    ?????   function openwin(){
    ?????   window.open("page.html","","width=200,height=200")
    ?????   }
    ?????   function get_cookie(Name) {
    ?????   var search = Name + "="
    ?????   var returnvalue = "";
    ?????   if (document.cookie.length > 0) {
    ?????   offset = document.cookie.indexOf(search)
    ?????   if (offset != -1) {
    ?????   offset += search.length
    ?????   end = document.cookie.indexOf(";", offset);
    ?????   if (end == -1)
    ?????   end = document.cookie.length;
    ?????   returnvalue=unescape(document.cookie.substring(offset, end))
    ?????   }
    ?????   }
    ?????   return returnvalue;
    ?????   }  
    ?????   function loadpopup(){
    ?????   if (get_cookie('popped')==''){
    ?????   openwin()
    ?????   document.cookie="popped=yes"
    ?????   }
    ?????   }
    ?????   </script>
    ?????   然后,用<body
    ????? onload="loadpopup()">(注意不是openwin而是loadpop?。。┨鎿Q主頁面中原有的<BODY>這一句即可。你可以試著刷新一下這個頁面或重新進
    ????? 入該頁面,窗口再也不會彈出了。真正的Pop-Only-Once!
    ?????   寫到這里彈出窗口的制作和應用技巧基本上算是完成了

    posted @ 2006-05-25 11:11 yanmin 閱讀(267) | 評論 (1)編輯 收藏


    最近做項目發現很多SQL沒有優化: 現在總結幾種優化方式.
    ?首先先了解一個SQL語句的執行過程分3步: 語法分析(parase)與編譯,執行,取數據.
    1: 在語法分析與編譯時:oracle 使用哈希函數為SQL語句在庫緩存中分配一個SQL區,
    首先檢查語句是否存在,若在,則查詢數據庫字典、檢查必須的權限。
    若無,需要語法分析與編譯。所以SQL語句存在與內存中,將減少分析,編譯時間。
    SQL語句的分析與編譯占整個語句運行過程的60%的時間,SQL優化的目標就是減少分析與編譯的時間,共享代碼。

    查詢SQL語句分析與編譯的時間:
    select * from v$sysstat
    where name in ('parse time cpu','parse time elapsed','parse count (hard)')

    一個SQL語句的響應時間(elapsed time )應該是服務時間+等待時間.
    服務時間= CPU執行時間.
    等待時間 可以從v$system_event
    select total_waits, total_timeouts, time_waited, average_wait ,event
    from v$system_event
    where event='latch free'
    所以解析一個SQL語句的平均等待時間是"等待時間/parse count" 這個值接近0
    通過數據字典v$sqlare,可以查詢到頻繁被分析與編譯的SQL語句.應該減少SQL語句的分析與編譯的次數.

    2: 將常用的實體駐留內存.
    為了減少分析與編譯時間,可以將常用的的實體如: 存儲過程,包等,盡可能駐留在內存區域.
    ?1)預留內存空間. sql> show parameter shared_pool_reserved_size
    ?????? 2)將頻繁使用的實體駐留在內存中. 在使用DBMS_SHARED_POOL程序包前,必須首先運行系統提供的程序包: dbmspool.sql 和prvtpool.plb
    ?在加載這兩個程序包后,自動生成所需的包.
    ????? 加載: sql> @/u01/app/oracle/product/8.17/rdbms/admin/dbmspool.sql
    ?????????? sql> @/u01/app/oracle/product/8.17/rdbms/admin/prvtpool.sql
    ????? 包DBMS_SHARED_POOL包含以下存儲過程.
    ????? dbms_shared_pool.keep 用于將實體保存內存. dbms_shared_pool.keep(object in varchar2,[type in char default p]);
    ???????????????????????????? object 表示參數名, type 表示被駐留內存的實體類型;P 表示存儲過程,C表示光標,R表示觸發器,默認P
    ???????
    ????? dbms_shared_pool.unkeep 用于取消被設置進入內存的實體. dbms_shared_pool.unkeep(object in varchar2,[type in char default p]);
    ???????????????????????????? object 表示參數名, type 表示被駐留內存的實體類型;P 表示存儲過程,C表示光標,R表示觸發器,默認P
    ?????
    ????? dbms_shared_pool.size(minsize in number)

    ????? select name ,type ,source_size+code_size+parsed_size+error_size "total bytes"
    ????? from dba_object_size
    ????? where owner='SCOTT'

    3: 創建索引.
    ?? select index_name,table_owner, table_name, tablespace_name from all_indexes
    ??
    ?? select user_indexes.TABLE_NAME, user_indexes.INDEX_NAME,uniqueness, column_name
    ?? from user_ind_columns ,user_indexes
    ?? where user_ind_columns.INDEX_NAME=user_indexes.INDEX_NAME
    ?? and user_ind_columns.TABLE_NAME=user_indexes.TABLE_NAME
    ?? order by user_indexes.TABLE_TYPE,user_indexes.TABLE_NAME,user_indexes.INDEX_NAME,user_ind_columns.COLUMN_POSITION

    4: 創建聚簇(cluster): 是一組存儲在一起的有共同列或經常一起使用的表,被聚簇的兩個表只有一個數據段.聚簇表在存儲時,在物理層將子表合并到父表中,這樣就少了表的連接時間.

    5: 創建哈希索引.
    ?
    6: SQL優化器: 基于成本的優化器CBO(cose_based)和基于規則RBO(rule_based)
    ?? sql> show parameter OPTIMIZER_MODE
    ?? 可以修改參數文件: initSID.ora,增加: optimizer_Mode={CHOOSE| RULE| FIRST_ROWS|ALL_ROWS}
    ? all_rows , first_rows(n)基于成本; rule 基于規則,choose基于規則、成本。
    ? /*+ ordered*/
    ? /*+ rule */
    ? /*+ first_rows(50) */

    ? /*+ordered star*/
    ? 寫發:?
    ? alter system flush shared_pool;
    select /*+ rule */ aa from visit

    posted @ 2006-03-20 15:28 yanmin 閱讀(1066) | 評論 (1)編輯 收藏

    主站蜘蛛池模板: 亚洲国产中文在线视频| 国产午夜影视大全免费观看 | 日韩插啊免费视频在线观看 | 色影音免费色资源| 亚洲国产成人手机在线电影bd| 成人免费777777被爆出| 亚洲精品视频在线看| 色妞www精品视频免费看| 无码国模国产在线观看免费 | 亚洲中文无码永久免| AA免费观看的1000部电影| 亚洲成a人片在线观看播放| 亚洲一区二区在线免费观看| 亚洲国产香蕉人人爽成AV片久久 | 亚洲精品无码久久久久YW| 好爽…又高潮了免费毛片 | 男女一边摸一边做爽的免费视频| 免费在线黄色网址| 一级成人a免费视频| 亚洲精品视频久久久| 一级做受视频免费是看美女| 免费高清资源黄网站在线观看| 亚洲日日做天天做日日谢| 九九九精品成人免费视频| 亚洲欧美日韩综合俺去了| 日韩免费视频在线观看| 免费的黄色的网站| 日本亚洲成高清一区二区三区 | 免费不卡中文字幕在线| 欧洲亚洲综合一区二区三区| 四虎www免费人成| 韩国免费A级毛片久久| 亚洲三区在线观看无套内射| ssswww日本免费网站片| 久久精品国产亚洲香蕉| 中文字幕无码播放免费| 亚洲欧美日韩久久精品| 亚洲麻豆精品国偷自产在线91| 日韩精品无码免费专区午夜不卡| 亚洲专区在线视频| 亚洲国产成人VA在线观看|