JAVA

          人生若只如初見,何事秋風悲畫扇。

            BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
            50 隨筆 :: 25 文章 :: 157 評論 :: 0 Trackbacks

          ORACLE沒有自動增長的數據類型,需要建立一個自動增長的序列號,插入記錄時要把序列號的下一個
          值賦于此字段。

          ??? CREATE SEQUENCE 序列號的名稱 (最好是表名+序列號標記) INCREMENT BY 1? START? WITH? 1
          MAXVALUE? 99999? CYCLE? NOCACHE;
          ??? 其中最大的值按字段的長度來定, 如果定義的自動增長的序列號 NUMBER(6) , 最大值為999999
          ??? INSERT 語句插入這個字段值為: 序列號的名稱.NEXTVAL?
          ???
          ?????如,可以用如下的操作來對其進行操作:
          ?????

          String?sqlSelectCID? = ? " Select?CourseList_SEQ.nextval?as?Course_ID?from?dual " ;
          PreparedStatement?stmtSelectCID;
          stmtSelectCID?
          = ?conn.prepareStatement(sqlSelectCID)
          synchronized (stmtSelectCID)
          ????????????????????
          {
          ????????????????????????selectCourseIDRS?
          = ?stmtSelectCID.executeQuery();
          ????????????????????}

          ????????????????????
          ????????????????????
          if ( ! selectCourseIDRS.next())
          ????????????????????
          {
          ????????????????????????
          // Update?DB?failed
          ????????????????????????stmtSelectCID.close();
          ????????????????????????conn.close();
          ????????????????????????
          return ;
          ????????????????????}

          ????????????????????setCourseID(selectCourseIDRS.getInt(
          " Course_ID " ));



          ================================================================================

          用:SELECT SEQUENCE_NAME FROM USER_SEQUENCES;可以查看序列!

          ================================================================================


          在PL/SQL Developer中(OR PL/SQL)的描述串:
          (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=localhost)(PORT=1521))(CONNECT_DATA=(SERVICE_NAME=orcl)))

          ================================================================================
          在Oracle中顯示日期,諸如:
          select to_char(last_day(current_date),'yyyy-mm')||'-'||'01' "本月初日期", to_char(last_day(current_date),'yyyy-mm-dd') "本月末日期" from dual;

          顯示結果:

          本月初日期 本月末日期
          ---------- ----------
          2006-01-01 2006-01-31

          ================================================================================

          單行字符串函數用于操作字符串數據,他們大多數有一個或多個參數,其中絕大多數返回字符串

            ascii()
            c1是一字符串,返回c1第一個字母的ascii碼,他的逆函數是chr()
          select ascii(''a'') big_a,ascii(''z'') big_z from empbig_a big_z65 122

            chr(<i>)[nchar_cs]
            i是一個數字,函數返回十進制表示的字符
          select chr(65),chr(122),chr(223) from empchr65 chr122 chr223a z b

            concat(,)
            c1,c2均為字符串,函數將c2連接到c1的后面,如果c1為null,將返回c2.如果c2為null,則返回c1,如果c1、c2都為null,則返回null。他和操作符||返回的結果相同
          select concat(''slobo '',''svoboda'') username from dualusernameslobo syoboda

            initcap()
            c1為一字符串。函數將每個單詞的第一個字母大寫其它字母小寫返回。單詞由空格,控制字符,標點符號限制。
          select initcap(''veni,vedi,vici'') ceasar from dualceasarveni,vedi,vici

            instr(,[,<i>[,]])
            c1,c2均為字符串,i,j為整數。函數返回c2在c1中第j次出現的位置,搜索從c1的第i個字符開始。當沒有發現需要的字符時返回0,如果i為負數,那么搜索將從右到左進行,但是位置的計算還是從左到右,i和j的缺省值為1.
          select instr(''mississippi'',''i'',3,3) from dualinstr(''mississippi'',''i'',3,3)11select instr(''mississippi'',''i'',-2,3) from dualinstr(''mississippi'',''i'',3,3)2

            instrb(,[,i[,j])
            與instr()函數一樣,只是他返回的是字節,對于單字節instrb()等于instr()

            length()
            c1為字符串,返回c1的長度,如果c1為null,那么將返回null值。
          select length(''ipso facto'') ergo from dualergo10

            lengthb()
            與length()一樣,返回字節。

            lower()
            返回c的小寫字符,經常出現在where子串中
          select lower(colorname) from itemdetail where lower(colorname) like ''%white%''colornamewinterwhite

            lpad(,<i>[,])
            c1,c2均為字符串,i為整數。在c1的左側用c2字符串補足致長度i,可多次重復,如果i小于c1的長度,那么只返回i那么長的c1字符,其他的將被截去。c2的缺省值為單空格,參見rpad。
          select lpad(answer,7,'''') padded,answer unpadded from question;padded unpadded yes yesno nomaybe maybe

            ltrim(,)
            把c1中最左邊的字符去掉,使其第一個字符不在c2中,如果沒有c2,那么c1就不會改變。
          select ltrim(''mississippi'',''mis'') from dualltrppi

            rpad(,<i>[,])
            在c1的右側用c2字符串補足致長度i,可多次重復,如果i小于c1的長度,那么只返回i那么長的c1字符,其他的將被截去。c2的缺省值為單空格,其他與lpad相似

            rtrim(,)
            把c1中最右邊的字符去掉,使其第后一個字符不在c2中,如果沒有c2,那么c1就不會改變。

            replace(,[,])
            c1,c2,c3都是字符串,函數用c3代替出現在c1中的c2后返回。
          select replace(''uptown'',''up'',''down'') from dualreplacedowntown

            stbstr(,<i>[,])
            c1為一字符串,i,j為整數,從c1的第i位開始返回長度為j的子字符串,如果j為空,則直到串的尾部。
          select substr(''message'',1,4) from dualsubsmess

            substrb(,<i>[,])
            與substr大致相同,只是i,j是以字節計算。

            soundex()
            返回與c1發音相似的詞
          select soundex(''dawes'') dawes soundex(''daws'') daws, soundex(''dawson'') from dualdawes daws dawsond200 d200 d250

            translate(,,)
            將c1中與c2相同的字符以c3代替
          select translate(''fumble'',''uf'',''ar'') test from dualtextramble

            trim([[]] from c3)
            將c3串中的第一個,最后一個,或者都刪除。
          select trim('' space padded '') trim from dual trimspace padded

            upper()
            返回c1的大寫,常出現where子串中select name from dual where upper(name) like ''ki%''nameking

          posted on 2006-01-12 00:28 Jkallen 閱讀(654) 評論(0)  編輯  收藏 所屬分類: DB學習

          只有注冊用戶登錄后才能發表評論。


          網站導航:
           
          主站蜘蛛池模板: 滁州市| 光泽县| 蓝田县| 张家川| 承德县| 灵石县| 桂林市| 辽宁省| 靖边县| 大兴区| 昌都县| 定结县| 青铜峡市| 龙井市| 广丰县| 大余县| 广德县| 肥城市| 卢氏县| 望江县| 沙田区| 葵青区| 陇川县| 黄龙县| 于都县| 绥芬河市| 新平| 子洲县| 化州市| 五原县| 古浪县| 宁明县| 沧州市| 龙口市| 和政县| 东乡| 巴彦县| 顺昌县| 保康县| 牟定县| 大兴区|