JAVA架構(gòu)師學(xué)習(xí)方向
posted @ 2018-10-26 14:12 JavaSuns 閱讀(182) | 評(píng)論 (0) | 編輯 收藏
SunsplHello,everyone,i am sun.
天道酬勤,笨鳥先飛.
隨筆 - 47, 文章 - 0, 評(píng)論 - 24, 引用 - 0
|
JAVA架構(gòu)師學(xué)習(xí)方向請(qǐng)點(diǎn)我查閱:JAVA架構(gòu)師
posted @ 2018-10-26 14:12 JavaSuns 閱讀(182) | 評(píng)論 (0) | 編輯 收藏 POI操作package cc.dynasoft.struts.action; posted @ 2009-06-13 19:52 JavaSuns 閱讀(612) | 評(píng)論 (0) | 編輯 收藏 linux創(chuàng)建文件夾命令
mkdir /home/u1 創(chuàng)建文件夾/home/u1
chown oracle /home/u1 表示改變目錄所有者為oracle賬戶; chgrp dba /home/u1 改變/home/u1目錄為dba所有; chmod 755 /home/u1 表示oracle賬戶對(duì)/home/u1目錄有755權(quán)限; rmdir /home/u1 表示刪除/home/u1目錄 hostname可以查看linux的計(jì)算機(jī)名; whoami可以查看當(dāng)前用戶; pwd顯示當(dāng)前路徑; df查看系統(tǒng)的硬件信息 ls -lrt l表示顯示詳細(xì)列表,-t表示按時(shí)間排序,-r反向排序 cat orcl_ora_3436.trc|grep bucket 以下查看相關(guān)文件內(nèi)容: more /etc/oratab cat /etc/passwd cat /etc/group posted @ 2008-07-28 09:01 JavaSuns 閱讀(38656) | 評(píng)論 (4) | 編輯 收藏 Linux中復(fù)制文件或目錄的命令(為了響應(yīng)新工作,要學(xué)習(xí)一下LINUX)copy命令 該命令的功能是將給出的文件或目錄拷貝到另一文件或目錄中,同MSDOS下的copy命令一樣,功能十分強(qiáng)大。 語(yǔ)法: cp [選項(xiàng)] 源文件或目錄 目標(biāo)文件或目錄 說明:該命令把指定的源文件復(fù)制到目標(biāo)文件或把多個(gè)源文件復(fù)制到目標(biāo)目錄中。 該命令的各選項(xiàng)含義如下: - a 該選項(xiàng)通常在拷貝目錄時(shí)使用。它保留鏈接、文件屬性,并遞歸地拷貝目錄,其作用等于dpR選項(xiàng)的組合。 - d 拷貝時(shí)保留鏈接。 - f 刪除已經(jīng)存在的目標(biāo)文件而不提示。 - i 和f選項(xiàng)相反,在覆蓋目標(biāo)文件之前將給出提示要求用戶確認(rèn)。回答y時(shí)目標(biāo)文件將被覆蓋,是交互式拷貝。 - p 此時(shí)cp除復(fù)制源文件的內(nèi)容外,還將把其修改時(shí)間和訪問權(quán)限也復(fù)制到新文件中。 - r 若給出的源文件是一目錄文件,此時(shí)cp將遞歸復(fù)制該目錄下所有的子目錄和文件。此時(shí)目標(biāo)文件必須為一個(gè)目錄名。 - l 不作拷貝,只是鏈接文件。 需要說明的是,為防止用戶在不經(jīng)意的情況下用cp命令破壞另一個(gè)文件,如用戶指定的目標(biāo)文件名已存在,用cp命令拷貝文件后,這個(gè)文件就會(huì)被新源文件覆蓋,因此,建議用戶在使用cp命令拷貝文件時(shí),最好使用i選項(xiàng)。 posted @ 2008-07-28 08:59 JavaSuns 閱讀(2325) | 評(píng)論 (0) | 編輯 收藏 解析oracle的rownum(學(xué)習(xí))
對(duì)于rownum來說它是oracle系統(tǒng)順序分配為從查詢返回的行的編號(hào),返回的第一行分配的是1,第二行是2,依此類推,這個(gè)偽字段可以用于限制查詢返回的總行數(shù),而且rownum不能以任何表的名稱作為前綴。
舉例說明: 例如表:student(學(xué)生)表,表結(jié)構(gòu)為: ID char(6) --學(xué)號(hào) name VARCHAR2(10) --姓名 create table student (ID char(6), name VARCHAR2(100)); insert into sale values('200001',‘張一’); insert into sale values('200002',‘王二’); insert into sale values('200003',‘李三’); insert into sale values('200004',‘趙四’); commit; (1) rownum 對(duì)于等于某值的查詢條件 如 果希望找到學(xué)生表中第一條學(xué)生的信息,可以使用rownum=1作為條件。但是想找到學(xué)生表中第二條學(xué)生的信息,使用rownum=2結(jié)果查不到數(shù)據(jù)。因 為rownum都是從1開始,但是1以上的自然數(shù)在rownum做等于判斷是時(shí)認(rèn)為都是false條件,所以無法查到rownum = n(n>1的自然數(shù))。 SQL> select rownum,id,name from student where rownum=1;(可以用在限制返回記錄條數(shù)的地方,保證不出錯(cuò),如:隱式游標(biāo)) SQL> select rownum,id,name from student where rownum=1; ROWNUM ID NAME ---------- ------ --------------------------------------------------- 1 200001 張一 SQL> select rownum,id,name from student where rownum =2; ROWNUM ID NAME ---------- ------ --------------------------------------------------- (2)rownum對(duì)于大于某值的查詢條件 如果想找到從第二行記錄以后的記錄,當(dāng)使用rownum>2是查不出記錄的,原因是由于rownum是一個(gè)總是從1開始的偽列,Oracle 認(rèn)為rownum> n(n>1的自然數(shù))這種條件依舊不成立,所以查不到記錄 SQL> select rownum,id,name from student where rownum >2; ROWNUM ID NAME ---------- ------ --------------------------------------------------- 那如何才能找到第二行以后的記錄呀。可以使用以下的子查詢方法來解決。注意子查詢中的rownum必須要有別名,否則還是不會(huì)查出記錄來,這是因?yàn)閞ownum不是某個(gè)表的列,如果不起別名的話,無法知道rownum是子查詢的列還是主查詢的列。 SQL>select * from(select rownum no ,id,name from student) where no>2; NO ID NAME ---------- ------ --------------------------------------------------- 3 200003 李三 4 200004 趙四 SQL> select * from(select rownum,id,name from student)where rownum>2; ROWNUM ID NAME ---------- ------ --------------------------------------------------- (3)rownum對(duì)于小于某值的查詢條件 如果想找到第三條記錄以前的記錄,當(dāng)使用rownum<3是能得到兩條記錄的。顯然rownum對(duì)于rownum<n((n>1的自然數(shù))的條件認(rèn)為是成立的,所以可以找到記錄。 SQL> select rownum,id,name from student where rownum <3; ROWNUM ID NAME ---------- ------ --------------------------------------------------- 1 200001 張一 2 200002 王二 綜 上幾種情況,可能有時(shí)候需要查詢r(jià)ownum在某區(qū)間的數(shù)據(jù),那怎么辦呀從上可以看出rownum對(duì)小于某值的查詢條件是人為true的,rownum對(duì) 于大于某值的查詢條件直接認(rèn)為是false的,但是可以間接的讓它轉(zhuǎn)為認(rèn)為是true的。那就必須使用子查詢。例如要查詢r(jià)ownum在第二行到第三行之 間的數(shù)據(jù),包括第二行和第三行數(shù)據(jù),那么我們只能寫以下語(yǔ)句,先讓它返回小于等于三的記錄行,然后在主查詢中判斷新的rownum的別名列大于等于二的記 錄行。但是這樣的操作會(huì)在大數(shù)據(jù)集中影響速度。 SQL> select * from (select rownum no,id,name from student where rownum<=3 ) where no >=2; NO ID NAME ---------- ------ --------------------------------------------------- 2 200002 王二 3 200003 李三 (4)rownum和排序 Oracle中的rownum的是在取數(shù)據(jù)的時(shí)候產(chǎn)生的序號(hào),所以想對(duì)指定排序的數(shù)據(jù)去指定的rowmun行數(shù)據(jù)就必須注意了。 SQL> select rownum ,id,name from student order by name; ROWNUM ID NAME ---------- ------ --------------------------------------------------- 3 200003 李三 2 200002 王二 1 200001 張一 4 200004 趙四 可以看出,rownum并不是按照name列來生成的序號(hào)。系統(tǒng)是按照記錄插入時(shí)的順序給記錄排的號(hào),rowid也是順序分配的。為了解決這個(gè)問題,必須使用子查詢 SQL> select rownum ,id,name from (select * from student order by name); ROWNUM ID NAME ---------- ------ --------------------------------------------------- 1 200003 李三 2 200002 王二 3 200001 張一 4 200004 趙四 這樣就成了按name排序,并且用rownum標(biāo)出正確序號(hào)(有小到大) posted @ 2008-06-26 10:23 JavaSuns 閱讀(434) | 評(píng)論 (0) | 編輯 收藏 Java里的list,set,map操作方法(練習(xí))
//ArrayList
{ ArrayList arraylist=new ArrayList(); arraylist.add(0,"end");//指定索引加入值 //需注意的是,如果現(xiàn)有2個(gè)值,我加入索引為5的那么就會(huì)出現(xiàn)異常 for(int i=0;i<2;i++){ arraylist.add(i,String.valueOf(i)); } System.out.println("ArrayList:"); for(int i=0;i<arraylist.size();i++){ System.out.print(arraylist.get(i)+";"); } arraylist.add("0");//直接加入值到ArrayList的最后 arraylist.add("0"); System.out.print("\nArrayList\'s lastIndexOf(\"0\") is "+arraylist.lastIndexOf("0")); } //Arrays { String []array=new String[]{"a","b","c"}; List list=Arrays.asList(array); System.out.println("\nArrays:"); for(int i=0;i<list.size();i++){ System.out.print(list.get(i)+";"); } System.out.print("\nArrays\'s length is "+array.length);//打印數(shù)組的長(zhǎng)度 } //Collections { String []array=new String[]{"a","b","c"}; List list=Arrays.asList(array); Collections.fill(list,"Fill");//用Fill填充全部元素 System.out.println("\nCollections:"); for(int i=0;i<list.size();i++){ System.out.print(list.get(i)+";"); } array=new String[]{"1","2","3"}; List list2=Arrays.asList(array); Collections.copy(list,list2);//拷貝list2的數(shù)據(jù)進(jìn)list System.out.println("\n"+list); Collections.swap(list,2,1);//調(diào)換索引為1和2的元素的位置 System.out.println(list); } //EventObject { String s="hello"; String s2=s; EventObject eventobject=new EventObject(s);//一個(gè)準(zhǔn)容器類型,確切的歸類它不是容器 System.out.println("EventObject:"); System.out.println(eventobject.getSource()); System.out.println(eventobject.equals(s2)); } //HashMap { HashMap hashmap=new HashMap();//一個(gè)速度最快的容器 hashmap.put("0","c"); hashmap.put("1","a"); hashmap.put("2","b"); hashmap.put("3","a"); System.out.println("HashMap:"); System.out.println(hashmap);//該容器有其內(nèi)部的排序方式 Set set=hashmap.keySet();//獲取全部鍵 Iterator iterator=set.iterator(); while(iterator.hasNext()){ System.out.print(hashmap.get(iterator.next())+";"); } } //HashSet { HashSet hashset=new HashSet();//一個(gè)絕對(duì)不能重復(fù)的類型 hashset.add("c"); hashset.add("b"); hashset.add("a"); hashset.add("a"); hashset.add("b"); System.out.println("\nHashSet:"); System.out.println(hashset); Iterator iterator=hashset.iterator();//取出元素 while(iterator.hasNext()){ System.out.print(iterator.next()+";"); } } //Hashtable { Hashtable hashtable=new Hashtable();//一個(gè)完全可以由其他容器替換的老容器類型 hashtable.put("0","c"); hashtable.put("1","a"); hashtable.put("3","c"); hashtable.put("2","b"); System.out.println("\nHashtable:"); Enumeration enumeration=hashtable.elements();//獲取元素,Enumeration已經(jīng)不是主流,Iterator是它的下一代替代品 while(enumeration.hasMoreElements()){ System.out.print(enumeration.nextElement()+";"); } } //IdentityHashMap { IdentityHashMap identityhashmap=new IdentityHashMap(); identityhashmap.put("0","c"); identityhashmap.put("1","a"); identityhashmap.put("3","b"); identityhashmap.put("2","a"); System.out.println("\nIdentityHashMap:"); System.out.println(identityhashmap); System.out.println(identityhashmap.containsKey("3"));//是否包含這個(gè)鍵 System.out.println(identityhashmap.containsValue("a"));//是否包含值 Set set=identityhashmap.entrySet();//傳為Set類型 System.out.println(set); set=identityhashmap.keySet();//全部鍵 System.out.println(set); } //LinkedHashMap { LinkedHashMap linkedhashmap=new LinkedHashMap(); linkedhashmap.put("0","b"); linkedhashmap.put("2","a"); linkedhashmap.put("1","c"); linkedhashmap.put("3","b"); System.out.println("LinkedHashMap:"); System.out.println(linkedhashmap); System.out.println(linkedhashmap.containsKey("2"));//是否包含這個(gè)鍵 System.out.println(linkedhashmap.containsValue("c"));//是否包含值 Set set=linkedhashmap.keySet(); Iterator iterator=set.iterator(); while(iterator.hasNext()){ System.out.print(linkedhashmap.get(iterator.next())+";"); } } //LinkedHashSet { LinkedHashSet linkedhashset=new LinkedHashSet();//它包含了幾種Set的屬性但卻沒有自己的特色 linkedhashset.add("c"); linkedhashset.add("a"); linkedhashset.add("a"); linkedhashset.add("b"); System.out.println("\nLinkedHashSet:"); System.out.println(linkedhashset); System.out.println(linkedhashset.contains("a"));//是否包含對(duì)象 Iterator iterator=linkedhashset.iterator(); while(iterator.hasNext()){ System.out.print(iterator.next()+";"); } } //LinkedList { LinkedList linkedlist=new LinkedList();//自由使用是它的特色 linkedlist.add("a"); linkedlist.add(1,"c"); linkedlist.addLast("b"); linkedlist.addFirst("d"); System.out.println("\nLinkedList:"); System.out.println(linkedlist); //linkedlist.clear();//該方法清空容器 //linkedlist.remove(0);//刪除索引為0的元素 //linkedlist.remove("d");//刪除值為d的元素 //linkedlist.removeFirst();//刪除第一個(gè)元素 //linkedlist.removeLast();//刪除最后一個(gè)元素 for(int i=0;i<linkedlist.size();i++){ System.out.print(linkedlist.get(i)+";"); } } //Stack { Stack stack=new Stack();//堆棧 stack.add("b"); stack.add(0,"c"); stack.push("d"); stack.add("e"); stack.push("a"); Enumeration enumeration=stack.elements(); System.out.println("\nStack:"); while(enumeration.hasMoreElements()){ System.out.print(enumeration.nextElement()+";"); } //后進(jìn)先出 System.out.println("\n"+stack.peek()); System.out.println(stack.pop()); System.out.println(stack.contains("d")+";"+stack.contains("a"));//是否包含該元素,有趣的事情發(fā)生了 System.out.println(stack.search("c"));//非常有用的屬性,檢索,但是由后向前的排列 } //TreeMap { TreeMap treemap=new TreeMap(); treemap.put("0","d"); treemap.put("2","a"); treemap.put("1","b"); treemap.put("3","c"); System.out.println("\nTreeMap:");//可以對(duì)鍵排序 System.out.println(treemap); System.out.println(treemap.firstKey());//返回第一個(gè)鍵 Set set=treemap.keySet(); Iterator iterator=set.iterator(); while(iterator.hasNext()){ System.out.print(treemap.get(iterator.next())+";"); } } //TreeSet { TreeSet treeset=new TreeSet();//自動(dòng)排序內(nèi)容 treeset.add("b"); treeset.add("a"); treeset.add("c"); treeset.add("d"); System.out.println("\nTreeSet:"); System.out.println(treeset); System.out.println(treeset.first());//返回第一個(gè)元素 Iterator iterator=treeset.iterator(); while(iterator.hasNext()){ System.out.print(iterator.next()+";"); } } //Vector { Vector vector=new Vector(); vector.add(0,"b"); vector.add("a"); vector.addElement("d"); vector.add("c"); System.out.println("\nVector:"); System.out.println(vector); vector.set(2,"h");//替換掉指定索引的元素 System.out.println(vector); Object []str=vector.toArray(); for(int i=0;i<str.length;i++){ System.out.print(str[i]+";"); } vector.setSize(2);//重新設(shè)置大小為2 System.out.println("\n"+vector); } //WeakHashMap { WeakHashMap weakhashmap=new WeakHashMap(); weakhashmap.put("1","b"); weakhashmap.put("2","c"); weakhashmap.put("0","d"); weakhashmap.put("3","a"); System.out.println("\nWeakHashMap:"); System.out.println(weakhashmap); System.out.println(weakhashmap.containsKey("3"));//是否包含鍵 System.out.println(weakhashmap.containsValue("d"));//是否包含值 Set set=weakhashmap.entrySet(); Iterator iterator=set.iterator(); while(iterator.hasNext()){ System.out.print(iterator.next()+";"); } //weakhashmap.remove("2");//刪除該鍵對(duì)應(yīng)的值 //weakhashmap.get("1");//獲取指定鍵的值 } } posted @ 2008-06-25 17:33 JavaSuns 閱讀(3885) | 評(píng)論 (0) | 編輯 收藏 map,set,list,等JAVA中集合解析(了解)
在JAVA的util包中有兩個(gè)所有集合的父接口Collection和Map,它們的父子關(guān)系:
java.util +Queue 接口 +Set 接口 +Map 接口 以下對(duì)眾多接口和類的簡(jiǎn)單說明:首先不能不先說一下數(shù)組(Array) Java所有“存儲(chǔ)及隨機(jī)訪問一連串對(duì)象”的做法,array是最有效率的一種。 1、 2、Java中有一個(gè)Arrays類,專門用來操作array。
若撰寫程序時(shí)不知道究竟需要多少對(duì)象,需要在空間不足時(shí)自動(dòng)擴(kuò)增容量,則需要使用容器類庫(kù),array不適用。 1、Collection 和 Map 的區(qū)別 容器內(nèi)每個(gè)為之所存儲(chǔ)的元素個(gè)數(shù)不同。 2、Java2容器類類庫(kù)的用途是“保存對(duì)象”,它分為兩類,各自旗下的子類關(guān)系 Collection Map----一組成對(duì)的“鍵值對(duì)”對(duì)象,即其元素是成對(duì)的對(duì)象,最典型的應(yīng)用就是數(shù)據(jù)字典,并且還有其它廣泛的應(yīng)用。另外,Map可以返回其所有鍵組成的Set和其所有值組成的Collection,或其鍵值對(duì)組成的Set,并且還可以像數(shù)組一樣擴(kuò)展多維Map,只要讓Map中鍵值對(duì)的每個(gè)“值”是一個(gè)Map即可。 3、其他特征 * List,Set,Map將持有對(duì)象一律視為Object型別。
Collections是針對(duì)集合類的一個(gè)幫助類。提供了一系列靜態(tài)方法實(shí)現(xiàn)對(duì)各種集合的搜索、排序、線程完全化等操作。 四、如何選擇? 1、容器類和Array的區(qū)別、擇取 2、 結(jié)論:最常用的是ArrayList,HashSet,HashMap,Array。而且,我們也會(huì)發(fā)現(xiàn)一個(gè)規(guī)律,用TreeXXX都是排序的。
1、Collection沒有g(shù)et()方法來取得某個(gè)元素。只能通過iterator()遍歷元素。 5、Map用 put(k,v) / get(k),還可以使用containsKey()/containsValue()來檢查其中是否含有某個(gè)key/value。 6、Map中元素,可以將key序列、value序列單獨(dú)抽取出來。 為什么一個(gè)生成Set,一個(gè)生成Collection?那是因?yàn)椋琸ey總是獨(dú)一無二的,value允許重復(fù)。 posted @ 2008-06-25 17:32 JavaSuns 閱讀(11793) | 評(píng)論 (1) | 編輯 收藏 |
|