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

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

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

    qqjianyue代碼工

    砌java代碼
    posts - 62, comments - 9, trackbacks - 0, articles - 10
      BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

    2009年2月18日

    1. Change to aliyun repository

    2. Chinese input method
    sudo apt-get install ibus-pinyin
    #remmeber to logout and re-logon to change system 'Region&Language' setting

    3. Shadowsocks and genpac
    sudo apt install -y shadowsocks-libev
    #sudo vi /etc/shadowsocks-libev/shadowsock.json
    {
        
    "server":"x.x.x.x",
        
    "server_port":xx,
        
    "local_port":1080,
        
    "password":"xxxxx",
        
    "timeout":60,
        
    "method":"aes-256-cfb"
    }

    nohup ss-local -c /etc/shadowsocks-libev/shadowsock.json >/dev/null 2>&1 &

    sudo apt install phython-pip
    sudo -H
    pip install genpac


    如果pip error "TypeError: unsupported operand type(s) for -=: 'Retry' and 'int'"
    sudo python -m pip install --upgrade --force pip

    mkdir pac
    cd pac
    touch user-rules.txt
    genpac --pac-proxy "SOCKS5 127.0.0.1:1080" --gfwlist-proxy="SOCKS5 127.0.0.1:1080" --output="autoproxy.pac" --gfwlist-url="https://raw.githubusercontent.com/gfwlist/gfwlist/master/gfwlist.txt" --user-rule-from="user-rules.txt"

    配置系統自動代理為:
    /home/xxx/pac/autoproxy.pac

    4. JDK8
    https://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html
    download and setup environment variable manually


    5.gcloud
    http://ubuntuhandbook.org/index.php/2014/10/google-cloud-sdk-made-into-canonical-partners-repository/

    posted @ 2018-11-03 08:39 Qzi 閱讀(199) | 評論 (0)編輯 收藏

    官方說明:http://source.android.com/source/initializing.html
    環境:
    Ubuntu 12.04 64bit
    JDK6(installation: http://www.gaggl.com/2012/04/installing-java6-jdk-on-ubuntu-12-04/)

    $ make -v
    GNU Make 3.81
    Copyright (C) 2006  Free Software Foundation, Inc.
    This is free software; see the source for copying conditions.
    There is NO warranty; not even for MERCHANTABILITY or FITNESS FOR A
    PARTICULAR PURPOSE.
    This program built for x86_64-pc-linux-gnu
    $ python -V
    Python 2.7.3
    android 當前 mainfest version: 4.2


    按照官方說明從下載到運行emulator,沒有nexus,所以沒做實際機器燒錄。步驟請根據官方說明做,以下只列出過程遇到的問題:
    1.repo sync
    經常出現斷線,網上有很多參考辦法,我是每次忽略這些錯誤,直到運行完畢退出,我再重新運行:
    repo sync -f
    知道所有代碼下載完畢(4.2的有16G)
    2.每次跑emulator都要cd到代碼目錄先進行環境初始化
    source build/envsetup.sh
    lunch full-eng
    3.emulator出錯
    $ emulator
    emulator: WARNING: system partition size adjusted to match image file (229 MB > 200 MB)
    Segmentation fault (core dumped)
    改成用emulator-arm -partition-size 1024
    full long command reference:
    http://stackoverflow.com/questions/9022750/running-emulator-after-building-android-from-source

    posted @ 2013-04-20 10:57 Qzi 閱讀(303) | 評論 (0)編輯 收藏

    Spring 聲明式事務讓我們從復雜的事務處理中得到解脫。使得我們再也無需要去處理獲得連接、關閉連接、事務提交和回滾等這些操作。再也無需要我們在與事務相關的方法中處理大量的 try catch  finally 代碼。 我們在使用 Spring 聲明式事務時,有一個非常重要的概念就是事務屬性。事務屬性通常由事務的傳播行為,事務的隔離級別,事務的超時值和事務只讀標志組成。我們在進行事務劃分時,需要進行事務定義,也就是配置事務的屬性。

     

    Spring  TransactionDefinition 接口中定義這些屬性 , 以供 PlatfromTransactionManager 使用 , PlatfromTransactionManager  spring 事務管理的核心接口。

     

    l         getTimeout() 方法,它返回事務必須在多少秒內完成。

    l         isReadOnly() , 事務是否只讀,事務管理器能夠根據這個返回值進行優化,確保事務是只讀的。

    l         getIsolationLevel() 方法返回事務的隔離級別,事務管理器根據它來控制另外一個事務可以看到本事務內的哪些數據。

     

     TransactionDefinition 接口中定義了五個不同的事務隔離級別:

     

    l         ISOLATION_DEFAULT 這是一個 PlatfromTransactionManager 默認的隔離級別,使用數據庫默認的事務隔離級別 . 另外四個與 JDBC 的隔離級別相對應

    l         ISOLATION_READ_UNCOMMITTED 這是事務最低的隔離級別,它充許別外一個事務可以看到這個事務未提交的數據。這種隔離級別會產生臟讀,不可重復讀和幻像讀。 例如 : Mary的原工資為 1000, 財務人員將 Mary 的工資改為了 8000 ,但未提交事務 與此同時, Mary正在讀取自己的工資 Mary 發現自己的工資變為了 8000 ,歡天喜地! 而財務發現操作有誤,而回滾了事務 ,Mary 的工資又變為了 1000. 像這樣 ,Mary 記取的工資數 8000 是一個臟數據。

    l         ISOLATION_READ_COMMITTED 保證一個事務修改的數據提交后才能被另外一個事務讀取。另外一個事務不能讀取該事務未提交的數據。這種事務隔離級別可以避免臟讀出現,但是可能會出現不可重復讀和幻像讀。

    l         ISOLATION_REPEATABLE_READ 這種事務隔離級別可以防止臟讀,不可重復讀。但是可能出現幻像讀。它除了保證一個事務不能讀取另一個事務未提交的數據外,還保證了避免下面的情況產生 ( 不可重復讀 )  在事務 1 中, Mary 讀取了自己的工資為 1000, 操作并沒有完成 在事務 2 中,這時財務人員修改了 Mary 的工資為 2000, 并提交了事務 . 在事務 1 中,Mary 再次讀取自己的工資時,工資變為了 2000 在一個事務中前后兩次讀取的結果并不致,導致了不可重復讀。 使用 ISOLATION_REPEATABLE_READ 可以避免這種情況發生。

    l         ISOLATION_SERIALIZABLE 這是花費最高代價但是最可靠的事務隔離級別。事務被處理為順序執行。除了防止臟讀,不可重復讀外,還避免了幻像讀。 目前工資為 1000 的員工有 10人。 事務 1, 讀取所有工資為 1000 的員工。 共讀取 10 條記錄 這時另一個事務向 employee表插入了一條員工記錄,工資也為 1000 事務 1 再次讀取所有工資為 1000 的員工 共讀取到了 11 條記錄,這就產生了幻像讀。 ISOLATION_SERIALIZABLE 能避免這樣的情況發生。但是這樣也耗費了最大的資源。

     

     

    getPropagationBehavior () 返回事務的傳播行為,由是否有一個活動的事務來決定一個事務調用。  TransactionDefinition 接口中定義了七個事務傳播行為:

     

    l         PROPAGATION_REQUIRED 如果存在一個事務,則支持當前事務。如果沒有事務則開啟一個新的事務。 使用 spring 聲明式事務, spring 使用 AOP 來支持聲明式事務,會根據事務屬性,自動在方法調用之前決定是否開啟一個事務,并在方法執行之后決定事務提交或回滾事務。 單獨調用 methodB 方法 相當于 Spring 保證在 methodB 方法中所有的調用都獲得到一個相同的連接。在調用 methodB 時,沒有一個存在的事務,所以獲得一個新的連接,開啟了一個新的事務。 單獨調用 MethodA 時,在 MethodA 內又會調用 MethodB. 執行效果相當于 調用 MethodA 時,環境中沒有事務,所以開啟一個新的事務 . 當在 MethodA 中調用MethodB 時,環境中已經有了一個事務,所以 methodB 就加入當前事務。

    l         PROPAGATION_SUPPORTS 如果存在一個事務,支持當前事務。如果沒有事務,則非事務的執行。但是對于事務同步的事務管理器, PROPAGATION_SUPPORTS 與不使用事務有少許不同。 單純的調用 methodB 時, methodB 方法是非事務的執行的。 當調用 methdA ,methodB 則加入了 methodA 的事務中 , 事務地執行。

    l         PROPAGATION_MANDATORY 如果已經存在一個事務,支持當前事務。如果沒有一個活動的事務,則拋出異常。 當單獨調用 methodB 時,因為當前沒有一個活動的事務,則會拋出異常 throw new IllegalTransactionStateException("Transaction propagation ''mandatory'' but no existing transaction found"); 當調用 methodA 時, methodB 則加入到 methodA 的事務中,事務地執行。

    l         PROPAGATION_REQUIRES_NEW 總是開啟一個新的事務。如果一個事務已經存在,則將這個存在的事務掛起。 當單獨調用 methodB 時,相當于把 methodb 聲明為 REQUIRED 。開啟一個新的事務,事務地執行。 當調用 methodA  情況有些大不一樣 . 相當于下面的效果。 在這里,我把 ts1 稱為外層事務, ts2 稱為內層事務。從上面的代碼可以看出, ts2 ts1 是兩個獨立的事務,互不相干。 Ts2 是否成功并不依賴于 ts1 。如果 methodA 方法在調用 methodB 方法后的 doSomeThingB 方法失敗了,而 methodB 方法所做的結果依然被提交。而除了 methodB 之外的其它代碼導致的結果卻被回滾了。 使用PROPAGATION_REQUIRES_NEW, 需要使用 JtaTransactionManager 作為事務管理器。

    l         PROPAGATION_NOT_SUPPORTED 總是非事務地執行,并掛起任何存在的事務。 當單獨調用 methodB 時,不啟用任何事務機制,非事務地執行。 當調用 methodA 時,相當于下面的效果 使用 PROPAGATION_NOT_SUPPORTED, 也需要使用 JtaTransactionManager 作為事務管理器。

    l         PROPAGATION_NEVER 總是非事務地執行,如果存在一個活動事務,則拋出異常 單獨調用methodB ,則非事務的執行。 調用 methodA 則會拋出異常

    l         PROPAGATION_NESTED 如果一個活動的事務存在,則運行在一個嵌套的事務中 . 如果沒有活動事務 , 則按 TransactionDefinition.PROPAGATION_REQUIRED 屬性執行 這是一個嵌套事務 , 使用 JDBC 3.0 驅動時 , 僅僅支持 DataSourceTransactionManager 作為事務管理器。需要 JDBC 驅動的 java.sql.Savepoint 類。有一些 JTA 的事務管理器實現可能也提供了同樣的功能。 使用 PROPAGATION_NESTED ,還需要把 PlatformTransactionManager nestedTransactionAllowed 屬性設為 true;  nestedTransactionAllowed 屬性值默認為false; 如果單獨調用 methodB 方法,則按 REQUIRED 屬性執行。 如果調用 methodA 方法,相當于下面的效果  methodB 方法調用之前,調用 setSavepoint 方法,保存當前的狀態到 savepoint 。如果 methodB 方法調用失敗,則恢復到之前保存的狀態。但是需要注意的是,這時的事務并沒有進行提交,如果后續的代碼 (doSomeThingB() 方法 ) 調用失敗,則回滾包括 methodB 方法的所有操作。 嵌套事務一個非常重要的概念就是內層事務依賴于外層事務。外層事務失敗時,會回滾內層事務所做的動作。而內層事務操作失敗并不會引起外層事務的回滾。

     

     

    PROPAGATION_NESTED  PROPAGATION_REQUIRES_NEW 的區別:

     

    它們非常類似 , 都像一個嵌套事務,如果不存在一個活動的事務,都會開啟一個新的事務。使用PROPAGATION_REQUIRES_NEW 時,內層事務與外層事務就像兩個獨立的事務一樣,一旦內層事務進行了提交后,外層事務不能對其進行回滾。兩個事務互不影響。兩個事務這是一個真正的嵌套事務。同時它需要 JTA 事務管理器的支持。 使用 PROPAGATION_NESTED 時,外層事務的回滾可以引起內層事務的回滾。而內層事務的異常并不會導致外層事務的回滾,它是一個真正的嵌套事務。 DataSourceTransactionManager 使用 savepoint 支持PROPAGATION_NESTED 時,需要 JDBC 3.0 以上驅動及 1.4 以上的 JDK 版本支持。其它的JTA TrasactionManager 實現可能有不同的支持方式。 PROPAGATION_REQUIRED 應該是我們首先的事務傳播行為。它能夠滿足我們大多數的事務需求。

    posted @ 2011-11-29 10:25 Qzi 閱讀(240) | 評論 (0)編輯 收藏

    參考這篇文章:http://blog.csdn.net/bluishglc/article/details/6632280 
    一。Maven的執行方式
    maven對構建(build)的過程進行了抽象和定義,這個過程被稱為構建的生命周期(lifecycle)。生命周期(lifecycle)由多個階段(phase)組成,每個階段(phase)會掛接一到多個goal。goal是maven里定義任務的最小單元,goal分為兩類,一類是綁定phase的,就是執行到某個phase,那么這個goal就會觸發,另外一類不綁定,就是單獨任務,這就相當于ant里的target。
    1。以phase來構建
    例如:
    mvn clean
    mvn compile
    mvn test
    mvn package
    表明maven會執行到某個生命周期(lifecycle)的某個階段(phase)
    這個phase以及它前面所有phase綁定的目標(goal)都會執行, 每個phase都會邦定maven默認的goal或者沒有goal, 或者自定義的goal。
    也可以通過傳入參數跳過(skip)某些phase,例如:
    mvn install -Dmaven.test.skip=true

    1。以goal來構建
    這類就是沒有綁定phase的goal,但是這類goal卻通常會有個執行前提,就是project必須執行到某個phase,
    那么執行這個goal,其實也會觸發maven執行到前提要求的phase。
    例如jetty:run是個非綁定phase的goal,它的前提是test-compile,這個前提是由plugin的代碼邏輯制定的

    /**
     * @goal run
     * @requiresDependencyResolution runtime
     * @execute phase="test-compile"
     * @description Runs jetty6 directly from a maven project
     */
    public class Jetty6RunMojo extends AbstractJettyRunMojo
    {
        ...
    }
    二。Maven lifecycle, phase概覽
    Maven預設了三個Lifecycle ,各包含了下列Phases.
    1. Clean Lifecycle
      • pre-clean
      • clean
      • post-clean
    2. Default Lifecycle
      • validate
      • initialize
      • generate-sources
      • process-sources
      • generate-resources
      • process-resources
      • compile
      • process-classes
      • generate-test-sources
      • process-test-sources
      • process-test-resources
      • test-compile
      • process-test-classes
      • test
      • prepare-package
      • package
      • pre-integration-test
      • integration-test
      • post-integration-test
      • verify
      • install
      • deploy
    3. Site Lifecycle
      • pre-site
      • site
      • post-site
      • site-deploy

    posted @ 2011-09-22 10:01 Qzi 閱讀(9283) | 評論 (0)編輯 收藏

    1.Window
    • java -classpath .;jar1;jar2 MainClass
      注意: -classpath參數必須放于前面。
    • java -jar jar1
      jar包的MANIFEST.MF文件:
      Manifest-Version: 1.0
      Main-Class: com.Main1
      Class-Path: jar1.jar;jar2.jar

      注意: 使用-jar參數,那么主jar包必須含有MANIFEST.MF信息,并且指定Main-Class & Class-Path。命令行的-classpath參數將被忽略
    2.Linux
    區別:
    目錄分隔符由\變成/
    jar包分隔符由;變成:

    Window測試環境是Sun java version "1.6.0_14"
    其他版本沒有驗證

    posted @ 2011-09-16 17:10 Qzi 閱讀(326) | 評論 (0)編輯 收藏

    posted @ 2011-09-16 16:59 Qzi 閱讀(263) | 評論 (0)編輯 收藏

    1.綁定本地接口,自動生成代理對象
    復制下面鏈接代碼
    // Endpoint Address
    String endpointAddress = "http://localhost:8111/helloWorld";
    // Add a port to the Service
    service.addPort(PORT_NAME, SOAPBinding.SOAP11HTTP_BINDING, endpointAddress);
    HelloService hw = service.getPort(HelloService.class);

    posted @ 2011-09-16 16:58 Qzi 閱讀(616) | 評論 (0)編輯 收藏

    java -Dhttp.proxyHost=127.0.0.1 -Dhttp.proxyPort=8888 -Dhttps.proxyHost=127.0.0.1 -Dhttps.proxyPort=8888

    posted @ 2011-09-16 16:58 Qzi 閱讀(516) | 評論 (0)編輯 收藏

    Java Keytool Commands for Creating and Importing

    These commands allow you to generate a new Java Keytool keystore file, create a CSR, and import certificates. Any root or intermediate certificates will need to be imported before importing the primary certificate for your domain.

    • Generate a Java keystore and key pair

      keytool -genkey -alias mydomain -keyalg RSA -keystore keystore.jks -keysize 2048

    • Generate a certificate signing request (CSR) for an existing Java keystore

      keytool -certreq -alias mydomain -keystore keystore.jks -file mydomain.csr

    • Import a root or intermediate CA certificate to an existing Java keystore

      keytool -import -trustcacerts -alias root -file Thawte.crt -keystore keystore.jks

    • Import a signed primary certificate to an existing Java keystore

      keytool -import -trustcacerts -alias mydomain -file mydomain.crt -keystore keystore.jks

    • Generate a keystore and self-signed certificate (see How to Create a Self Signed Certificate using Java Keytool for more info)

      keytool -genkey -keyalg RSA -alias selfsigned -keystore keystore.jks -storepass password -validity 360 -keysize 2048

    Java Keytool Commands for Checking

    If you need to check the information within a certificate, or Java keystore, use these commands.

    • Check a stand-alone certificate

      keytool -printcert -v -file mydomain.crt

    • Check which certificates are in a Java keystore

      keytool -list -v -keystore keystore.jks

    • Check a particular keystore entry using an alias

      keytool -list -v -keystore keystore.jks -alias mydomain

    Other Java Keytool Commands

    • Delete a certificate from a Java Keytool keystore

      keytool -delete -alias mydomain -keystore keystore.jks

    • Change a Java keystore password

      keytool -storepasswd -new new_storepass -keystore keystore.jks

    • Export a certificate from a keystore

      keytool -export -alias mydomain -file mydomain.crt -keystore keystore.jks

    • List Trusted CA Certs

      keytool -list -v -keystore $JAVA_HOME/jre/lib/security/cacerts

    • Import New CA into Trusted Certs

      keytool -import -trustcacerts -file /path/to/ca/ca.pem -alias CA_ALIAS -keystore $JAVA_HOME/jre/lib/security/cacerts

    posted @ 2011-09-16 16:24 Qzi 閱讀(389) | 評論 (0)編輯 收藏

    第一種方式:適合于全部HTML標簽
    <acronym title="World Wide Web">
    WWW
    </acronym>

    第二種方式:IMG之類的標簽例如:
    <img src="#" alt="鼠標移動到上方會顯示并且未加載圖片時也會顯示">

    第三種方式:input之類的標簽例如:
    <input type="button" value="確定" title="鼠標移動到上方會顯示并且未加載圖片時也會顯示">

    posted @ 2010-05-28 16:31 Qzi 閱讀(226) | 評論 (0)編輯 收藏

    第一:簡單的使用axis2包自己實現調用

    package common;

    import javax.xml.namespace.QName;
    import org.apache.axis2.AxisFault;
    import org.apache.axis2.addressing.EndpointReference;
    import org.apache.axis2.client.Options;
    import org.apache.axis2.rpc.client.RPCServiceClient;

    public class WebServiceUtils
    {
     // ----------------------------------------------------- Properties
     public static int TIMEOUT = 100000;

     // ----------------------------------------------------- Constructors

     // ----------------------------------------------------- Methods
     /**
      *
      * 調用axis2的webservice的方法
      *
      * @return
      */
     @SuppressWarnings("unchecked")
     static public Object[] invokeWebService( String url, String nameSpace, String method, Object[] args, Class[] returnTypes )
       throws AxisFault
     {
      RPCServiceClient serviceClient = new RPCServiceClient();
      Options options = serviceClient.getOptions();
      EndpointReference targetEPR = new EndpointReference( url );
      options.setTo( targetEPR );
      options.setTimeOutInMilliSeconds( TIMEOUT );
      QName opName = new QName( nameSpace, method );
      Object[] results = serviceClient.invokeBlocking( opName, args, returnTypes );
      return results;
     }
    }


    第二:

    public static OMElement getEchoOMElement() {
            OMFactory fac = OMAbstractFactory.getOMFactory();
            OMNamespace omNs = fac.createOMNamespace(
                    "http://example1.org/example1", "example1");
            OMElement method = fac.createOMElement("echo", omNs);
            OMElement value = fac.createOMElement("Text", omNs);
            value.addChild(fac.createOMText(value, "Axis2 Echo String "));
            method.addChild(value);

            return method;
        }

     public static void main(String[] args) {
            try {
               OMElement payload = ClientUtil.getEchoOMElement();
                Options options = new Options();
              
                options.setTo(targetEPR);
                options.setAction("urn:echo");

                //Blocking invocation
                ServiceClient sender = new ServiceClient();
                sender.setOptions(options);
                OMElement result = sender.sendReceive(payload);

                System.out.println(result);
              
                System.out.println(options.getTo());

            } catch (AxisFault axisFault) {
                axisFault.printStackTrace();
            }
        }

     
    第三:

    利用插件生成客戶端
    private static String URL="http://localhost:8080/axis2/services/WeatherService"; 
        public static void main(String[] args) throws RemoteException {
            try {
                WeatherServiceStub stub;
                if (args != null && args.length != 0) {
                    stub = new WeatherServiceStub(args[0]);
                  
                } else {
                    stub = new WeatherServiceStub(URL);
                }
                WeatherServiceStub.SetWeather setWether = new WeatherServiceStub.SetWeather();
                WeatherServiceStub.Weather wether = new WeatherServiceStub.Weather();
              
                wether.setForecast("east");
                wether.setRain(true);
                wether.setTemperature(12.3f);
                wether.setForecast("big");
              
                setWether.setWeather(wether);
                stub.setWeather(setWether);
              
                WeatherServiceStub.GetWeatherResponse gw = new WeatherServiceStub.GetWeatherResponse();
                System.out.println(gw.get_return());       
              
            } catch (AxisFault e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
        }


    本文部分來自CSDN博客,轉載請標明出處:http://blog.csdn.net/yhhah/archive/2009/05/07/4158487.aspx

    posted @ 2010-01-20 23:16 Qzi 閱讀(10504) | 評論 (0)編輯 收藏

    IE的 script 元素支持onreadystatechange事件,不支持onload事件。
    FF的script 元素不支持onreadystatechange事件,只支持onload事件。
    如果要在一個<script src="xx.js"> 加載完成執行一個操作,FF使用onload事件就行了,IE下則要結合onreadystatechange事件和this.readyState
    var loadScript = function(fileName,callback) {
     var scriptTag = document.createElement("script");
      scriptTag.src = fileName;
      document.body.appendChild(scriptTag);
      if (callback) {
       scriptTag.onload = callback;//ff
       scriptTag.onreadystatechange = function()//ie
       {
        if (scriptTag.readyState == "loaded") {
        callback();
       }
      }
     }
    }

    posted @ 2009-12-11 18:57 Qzi 閱讀(474) | 評論 (0)編輯 收藏

    關鍵是查詢v$locked_object

    select sess.sid,
        sess.serial#,
        lo.oracle_username,
        lo.os_user_name,
        ao.object_name,
        lo.locked_mode
        from v$locked_object lo,
        dba_objects ao,
        v$session sess
    where ao.object_id = lo.object_id and lo.session_id = sess.sid;


    或者

    select * from v$session t1, v$locked_object t2 where t1.sid = t2.SESSION_ID;

    殺掉進程:
    alter system kill session 'sid,serial#';

    posted @ 2009-09-21 14:09 Qzi 閱讀(242) | 評論 (0)編輯 收藏

    --創建臨時表空間
    create temporary tablespace dbuser_temp
    tempfile 'D:\oracle\product\10.1.0\oradata\btx\dbuser_temp01.dbf'
    size 32m
    autoextend on
    next 32m maxsize 2048m
    extent management local;

    --創建數據表空間

    create tablespace dbuser_data
    logging
    datafile 'D:\oracle\product\10.1.0\oradata\btx\dbuser_data01.dbf'
    size 32m
    autoextend on
    next 32m maxsize 2048m
    extent management local;
    --或者自己控制增長規則
    --pctincreate表示下一次增長是前一次增長的110%
    create tablespace dbuser_data logging datafile 'D:/oracle/product/10.1.0/oradata/btx/DBUSER_DATA01.DBF' size 32m autoextend on next 5m maxsize unlimited default storage (initial 32m next 5m pctincrease 10);

    --修改表空間
    alter tablespace dbuser_data add datafile 'D:/oracle/product/10.1.0/oradata/btx/DBUSER_DATA02.DBF'  size 32m autoextend on next 5m maxsize unlimited;

    --創建用戶與指定默認數據表空間與默認臨時表空間
    create user dbuser identified by dbuser
    default tablespace dbuser_data
    temporary tablespace dbuser_temp;
    --修改用戶表空間
    alter user dbuser default tablespace dbuser_data temporary tablespace dbuser_temp;

    --為用戶賦權

    grant connect,resource to dbuser;

    修改表空間


    查詢oracle表空間使用狀況
    SELECT b.tablespace_name "表空間名",total 表空間大小,free 表空間剩余大小,
    (total-free) 表空間使用大小,
    ROUND((total-free)/total,4)*100 "使用率 %"
    FROM  (SELECT tablespace_name,SUM(bytes) free FROM DBA_FREE_SPACE
    GROUP BY tablespace_name ) a,
    (SELECT tablespace_name,SUM(bytes) total FROM DBA_DATA_FILES
    GROUP BY tablespace_name) b
    WHERE a.tablespace_name=b.tablespace_name ;

    posted @ 2009-08-16 11:24 Qzi 閱讀(1026) | 評論 (0)編輯 收藏

    恢復表數據:
    alter table 表名 enable row movement;
    flashback table 表名 TO TIMESTAMP to_timestamp('2009-08-07 18:34:00','yyyy-mm-dd hh24:mi:ss');

    恢復存儲過程:
    select text from dba_source as of timestamp to_timestamp('2009-03-06 09:45:00', 'YYYY-MM-DD HH24:MI:SS') where owner='IPRA' and name= 'P_IPACCHECK_NC' order by line;
    需要sys用戶
    否則不夠權限
    或者登錄數據庫所在主機,使用數據庫管理者的系統用戶登錄

    posted @ 2009-08-07 22:07 Qzi 閱讀(203) | 評論 (0)編輯 收藏

    視圖:(受權限過濾了)
    all_tables 所有表
    all_indexs 所有索引
    all_tab_columns  所有列,可以查看列的類型

    (dba權限包括所有)
    dba_tables
    dba_tab_columns
    dba_free_space 各對象的剩余空間
    dba_data_files  各數據空間的文件信息
    dba_tablespaces  表空間信息

    posted @ 2009-07-21 13:35 Qzi 閱讀(250) | 評論 (0)編輯 收藏

     

    常用字符函數

    函數

    描述

    LOWER(char)

    將字符串表達式char中的所有大寫字母轉換為小寫字母

    UPPER(char)

    將字符串表達式char中的所有小寫字母轉換為大寫字母

    INITCAP(char)

    首字母轉換成大寫

    SUBSTR(char,start,length)

    返回字符串表達式char中從第start開始的length個字符

    LENGTH(char)

    返回字符串表達式char的長度

    LTRIM(char)

    去掉字符串表達式char后面的空格

    ASCII(char)

    charASCII

    CHAR(number)

    numberASCII

    REPLACE(char,str1,str2)

    將字符串中所有str1換成str2

    INSTR(char1,char2,start,times)

    char1字符串中搜索char2字符串,start為執行搜索操作的起始位置,times為搜索次數

     

    常用日期函數

    函數

    描述

    SYSDATE

    返回系統當前日期和時間

    NEXT_DAY(day,char)

    返回day指定的日期之后并滿足char指定條件的第一個日期,char所指條件只能為星期幾

    LAST_DAY(day)

    返回day日期所指定月份中最后一天所對應的日期

    ADD_MONTH(day,n)

    返回day日期在n個月后(n為正數)或前(n為負數)的日期

    MONTH_BETWEEN(day1,day2)

    返回day1日期和day2日期之間相差得月份

    ROUND(day[,fmt])

    按照fmt指定格式對日期數據day做舍入處理,默認舍入到日

    TRUNC(day,[,fmt])

    按照fmt指定格式對日期數據day做舍入處理,默認截斷到日

     

    數據類型轉換函數

    函數

    描述

    TO_CHAR

    將一個數字或日期轉換成字符串

    TO_NUMBER

    將字符型數據轉換成數字型數據

    TO_DATE

    將字符型數據轉換為日期型數據

    CONVERT

    將一個字符串從一個字符集轉換為另一種字符集

    CHARTORowid

    將一個字符串轉換為Rowid數據類型

    RowIDTOCHAR

    將一個Rowid數據類型轉換為字符串

    NEXTTORAW

    將一個十六進制字符串轉換為RAW數據類型

    RAWTOHEX

    將一個RAW類型的二進制數據類型轉換為一個十六進制表達的字符串

    TO_MULTI_BYTE

    將一個單字節字符串轉換為多字節字符串

    TO_SINGLE_BYTE

    將一個多字節字符串轉換為單字節字符串

     

     

     

    集合函數

    函數

    描述

    AVG

    計算一列值的平均值

    COUNT

    統計一列中值的個數

    MAX

    求一列值中的最大值

    MIN

    求一列值中的最小值

    SUM

    計算一列值的總和

    STDDEV

    計算一列值的標準差

    VARIANCE

    計算一列值的方差

    posted @ 2009-07-16 21:26 Qzi 閱讀(520) | 評論 (0)編輯 收藏

    1、
      encodeURIComponent(”[string]“)
      decodeURIComponent(”[encodedString]“)

    2、
      encodeURI(”[string]“)
      decodeURI(”[encodedString]“)

    3、
      escape(”[string]“)
      unescape(”[encodedString]“)


    1、對每個字節進行編碼;
    2、空格轉為”+”號;
    3、安全字符不編碼。安全字符:大小寫英文字母(a-z以及A-Z) 阿拉伯數字(0-9) \’ ( ) * - . _ !
    4、其他字節以十六進制顯示并加”%”前綴,例如用%25代表%號。

    posted @ 2009-07-15 21:29 Qzi 閱讀(163) | 評論 (0)編輯 收藏

    設置客戶端字符集:
    # 常用中文字符集
    set NLS_LANG=SIMPLIFIED CHINESE_CHINA.ZHS16GBK
    # 常用unicode字符集
    set NLS_LANG=american_america.AL32UTF8

    exp 用戶名/密碼@主機 file=導出文件的文件名 tables=(逗號分割表名)  log=aibsm.log feedback=200

    posted @ 2009-07-06 13:21 Qzi 閱讀(203) | 評論 (0)編輯 收藏

    1.Json的對象形式
    {
    property0 : true,                    //property0是一個布爾型的值
    property1 : 0,                        //property1是一個數值型的值
    property2 : "123",                 //property2是一個字符串型的值
    property3 : function(){...}     //property3是一個函數
    }
    使用key-value對構造json對象,注意屬性的key和value使用“:”分開,屬性之間使用“,”分開,注意最后的屬性沒有“,”,什么符號都不要有。將此結構直接賦值給js的對象,則可以使用這個對象調用這些屬性。
    例如:var obj1 = {
    property0 : true,                    //property0是一個布爾型的值
    property1 : 0,                        //property1是一個數值型的值
    property2 : "123",                 //property2是一個字符串型的值
    property3 : function(){...},     //property3是一個函數
    property4 : { p1 : p1Value, p2 : p2Value }    //property4本身又是一個對象
    }
    那么可以調用
    alert(obj1.property0);
    obj1.property3();
    ……
    在Java Web開發中,服務端負責輸出這串字符到jsp頁面的js,就可以使用了。

    關鍵的是,字符串中可能具有js需要避免的特殊字符,建議查看一下spring的JavascriptUtils的javaScriptEscape方法就知道如何做啦
    如果是Ajax調用的話,就是用prototype庫的方法,將字符串轉換為json對象
    new Ajax.Request("http://url/", { 
      method: "get", 
      onSuccess: function(transport) { 
        var json = transport.responseText.evalJSON(); 
        // TODO: document.write(json.xxx); 
      } 
    prototype庫的官網:    http://prototypejs.org/
     }); 
    2.    Json的數組形式
    其實js中的數組更像是一個Map對象,因為它的key不只是整數,還可以是字符串。
    var array;
    array["key0"] = key0Value;
    array["key1"] = key1Value;

    posted @ 2009-06-01 13:33 Qzi 閱讀(356) | 評論 (0)編輯 收藏

         摘要: 基本javascript事件的列表介紹  閱讀全文

    posted @ 2009-05-22 15:51 Qzi 閱讀(374) | 評論 (0)編輯 收藏

         摘要: 首先介紹一個網站,我很多書本都是在上面下載的,很好。http://www.freebookspot.in/
    我現在學習的書本是:Pro Javascript Design Pattern

    首先簡單地為優雅的Javascript代碼開個頭

    運用設計模式的三大原因:
    可維護性
    溝通交流性
    性能追求
    不使用設計模式的兩大原因:
    復雜性
    性能追求
      閱讀全文

    posted @ 2009-05-16 10:36 Qzi 閱讀(1819) | 評論 (2)編輯 收藏

    函數:
    import導入文件的路徑、類型、和title,title用來標識你是否已導入這個文件用。
    setStyle用于使導入的css有效,根據不同的瀏覽器,可能css生效的條件不同,反復無效與有效間切換,可以使得最后有效。
     1function $import(path, type, title) {
     2    var s, i;
     3    if (type == "js"{
     4        var ss = document.getElementsByTagName("script");
     5        for (i = 0; i < ss.length; i++{
     6            if (ss[i].src && ss[i].src.indexOf(path) != -1{
     7                return;
     8            }

     9        }

    10        s = document.createElement("script");
    11        s.type = "text/javascript";
    12        s.src = path;
    13    }
     else {
    14        if (type == "css"{
    15            var ls = document.getElementsByTagName("link");
    16            for (i = 0; i < ls.length; i++{
    17                if (ls[i].href && ls[i].href.indexOf(path) != -1{
    18                    return;
    19                }

    20            }

    21            s = document.createElement("link");
    22            s.rel = "alternate stylesheet";
    23            s.type = "text/css";
    24            s.href = path;
    25            s.title = title;
    26            s.disabled = false;
    27        }
     else {
    28            return;
    29        }

    30    }

    31    var head = document.getElementsByTagName("head")[0];
    32    head.appendChild(s);
    33}

    34
    35function setStyle(title) {
    36    var i, links, eflag = false;
    37    links = document.getElementsByTagName("link");
    38    for (i = 0; links[i]; i++{
    39        if (links[i].getAttribute("rel").indexOf("style"!= -1 && links[i].getAttribute("title")) {
    40            links[i].disabled = true;
    41            if (links[i].getAttribute("title").indexOf(title) != -1{
    42                links[i].disabled = false;
    43                eflag = true;
    44            }

    45        }

    46    }

    47    if (!eflag) {
    48        $import("skin/" + title + "/default.css""css", title);
    49        setStyle(title);
    50    }

    51}

    posted @ 2009-02-18 12:43 Qzi 閱讀(969) | 評論 (0)編輯 收藏

    主站蜘蛛池模板: 老司机亚洲精品影院无码| 女人与禽交视频免费看| 亚洲AV无码乱码在线观看牲色| 91在线亚洲精品专区| 成人自慰女黄网站免费大全| 亚洲乱色熟女一区二区三区蜜臀| 成全视频免费观看在线看| 亚洲国产日韩成人综合天堂| 亚洲色成人四虎在线观看| 69成人免费视频| 亚洲精品影院久久久久久| 暖暖在线视频免费视频| 久久国内免费视频| 亚洲酒色1314狠狠做| 日韩中文字幕免费视频| 亚洲成色在线影院| 亚洲1区2区3区精华液| 黄瓜视频高清在线看免费下载| jlzzjlzz亚洲jzjzjz| 99久久免费国产香蕉麻豆 | 亚洲午夜av影院| 人妻仑刮八A级毛片免费看| 国产一级特黄高清免费大片| 亚洲av中文无码乱人伦在线播放 | 亚洲第一页日韩专区| 深夜a级毛片免费视频| 亚洲A∨精品一区二区三区| 添bbb免费观看高清视频| 久久久久亚洲精品无码网址| 久久av免费天堂小草播放| 国产亚洲人成无码网在线观看| 一本色道久久88亚洲精品综合| 国产1024精品视频专区免费| 亚洲精品自产拍在线观看| a级毛片免费全部播放无码| 久久精品7亚洲午夜a| 亚洲一区二区三区免费在线观看 | 亚洲AV无码一区二三区| 中文字幕永久免费视频| 亚洲高清在线视频| 青青久在线视频免费观看|