2017年4月22日 星期六

成為Java高手的25個學習目標

出處: 開源互助社區
http://www.coctec.com/docs/java/show-post-59764.html


本文將告訴你學習Java需要達到的25個目標,希望能夠對你的學習及找工作有所幫助.對比一下自己,你已經掌握了這25條中的多少條了呢?

1.你需要精通面向對象分析與設計(OOA/OOD)、涉及模式(GOF,J2EEDP)以及綜合模式.你應該了解UML,尤其是 class,object,interaction以及statediagrams.

2.你需要學習Java語言的基礎知識以及它的核心類庫 (collections,serialization,streams,networking,?multithreading,reflection,event,handling,NIO,localization,
   以及其他).

3.你應該了解JVM,classloaders,classreflect,以及垃圾回收的基本工作機制等.你應該有能力反編譯一個類文件並且明白一些基本的彙編指令.

4.如果你將要寫客戶端程序,你需要學習Web的小應用程序(applet),必需掌握GUI設計的思想和方法,以及桌面程序的 SWING,AWT,?SWT.
  你還應該對UI部件的JavaBEAN組件模式有所了解.JavaBEANS也被應用在JSP中以把業務邏輯從表現層中分離出來.

5.你需要學習Java資料庫技術,並且會使用至少一種persistence/ORM構架,例如Hibernate,JDO,?CocoBase,TopLink,InsideLiberator(中國產JDO紅工廠軟體)或者iBatis.

6.你還應該了解對象關係的阻抗失配的含義,以及它是如何影響業務對象的與關係型資料庫的交互,和它的運行結果,還需要掌握不同的資料庫產品運用,
  比如racle,mysql,mssqlserver.

7.你需要學習Servlets,JSP,以及JSTL(StandardTagLibraries)和可以選擇的第三方TagLibraries.

8.你需要熟悉主流的網頁框架,例如JSF,Struts,Tapestry,Cocoon,WebWork,以及他們下面的涉及模式,如MVC/MODEL2.

9.你需要學習如何使用及管理Web伺服器,例如tomcat,resin,Jrun,並且知道如何在其基礎上擴展和維護Web程序.

10.你需要學習分散式對象以及遠程API,例如RMI和RMI/IIOP.

11.你需要掌握各種流行中間件技術標準和與Java結合實現,比如Tuxedo、CROBA,當然也包括JavaEE本身.

12.你需要學習最少一種的XMLAPI,例如JAXP(JavaAPIforXMLProcessing),JDOM(JavaforXMLDocumentObjectModel),DOM4J,或JAXR(JavaAPIforXMLRegistries).

13.你應該學習如何利用Java的API和工具來構建WebService.例如JAX- RPC(JavaAPIforXML/RPC),SAAJ? (SOAPwithAttachmentsAPIforJava),
   JAXB(JavaArchitectureforXMLBinding),JAXM(JavaAPIforXMLMessaging),?JAXR(JavaAPIforXMLRegistries),或者JWSDP(JavaWebServicesDeveloperPack).

14.你需要學習一門輕量級應用程序框架,例如Spring,PicoContainer,Avalon,以及它們的IoC/DI風格(setter,constructor,interfaceinjection).

15.你需要熟悉不同的J2EE技術,例如JNDI(JavaNamingandDirectoryInterface),JMS? (JavaMessageService),
   JTA/JTS(JavaTransactionAPI /JavaTransactionService),JMX?(JavaManagementeXtensions),以及JavaMail.

16.你需要學習企業級JavaBeans(EJB)以及它們的不同組件模式:Stateless/StatefulSessionBeans,EntityBeans
  (包含 Bean-?ManagedPersistence[BMP]或者Container-ManagedPersistence[CMP]和它的EJB- QL),或者?Message-DrivenBeans(MDB).

17.你需要學習如何管理與配置一個J2EE應用程序伺服器,如WebLogic,JBoss等,並且利用它的附加服務,例如簇類,連接池以及分散式處理支援.
   你還需要了解如何在它上面封裝和配置應用程序並且能夠監控、調整它的性能.

18.你需要熟悉面向方面的程序設計以及面向屬性的程序設計(這兩個都被很容易混淆的縮寫為AOP),以及他們的主流Java規格和執行.
   例如AspectJ和AspectWerkz.

19.你需要熟悉對不同有用的API和framework等來為你服務.例如Log4J(logging/tracing),Quartz(scheduling),
   JGroups(networkgroupcommunication),JCache(distributedcaching),?Lucene(full- textsearch),JakartaCommons等等.

20.你應該熟練掌握一種JavaIDE例如sunOne,netBeans,IntelliJIDEA或者Eclipse.(有些人更喜歡VI或EMACS來編寫文件.隨便你用什麼了:)

21.Java(精確的說是有些配置)是冗長的,它需要很多的人工代碼(例如EJB),所以你需要熟悉代碼生成工具,例如XDoclet.

22.你需要熟悉一種單元測試體系(JNunit),並且學習不同的生成、部署工具(Ant,Maven).

23.你需要熟悉一些在Java開發中經常用到的軟體工程過程.例如RUP(RationalUnifiedProcess)andAgilemethodologies.

24.你還需要緊跟Java發展的步伐,比如現在可以深入的學習Webwork2.0

25.你必需要對實際項目的開發流程有所了解,至少要有兩個有實際應用價值的項目,而不是練習項目!
   現在企業看重的是你有沒有實際的開發經驗,真正開發經驗的體現就是你做的項目,也就是有實際應用的項目!

Eclipse 開發 Windows GUI


安裝 WindowBuilder
到 Eclipse 官網 http://www.eclipse.org/windowbuilder/download.php


複製所屬 Eclipse 版本 link 上的 URL,貼上


2017年4月2日 星期日

Hibernate Query 用法

Hibernate Query examples (HQL)
出處: mkyong.com
         
https://www.mkyong.com/hibernate/hibernate-query-examples-hql/

 HQL Select Query Example

Retrieve a stock data where stock code is “7277”.
Query query = session.createQuery("from Stock where stockCode = :code ");
query.setParameter("code", "7277");
List list = query.list();
Query query = session.createQuery("from Stock where stockCode = '7277' ");
List list = query.list();

2. HQL Update Query Example

Update a stock name to “DIALOG1” where stock code is “7277”.
Query query = session.createQuery("update Stock set stockName = :stockName" +
        " where stockCode = :stockCode");
query.setParameter("stockName", "DIALOG1");
query.setParameter("stockCode", "7277");
int result = query.executeUpdate();
Query query = session.createQuery("update Stock set stockName = 'DIALOG2'" +
        " where stockCode = '7277'");
int result = query.executeUpdate();

3. HQL Delete Query Example

Delete a stock where stock code is “7277”.
Query query = session.createQuery("delete Stock where stockCode = :stockCode");
query.setParameter("stockCode", "7277");
int result = query.executeUpdate();
Query query = session.createQuery("delete Stock where stockCode = '7277'");
int result = query.executeUpdate();

4. HQL Insert Query Example

In HQL, only the INSERT INTO … SELECT … is supported; there is no INSERT INTO … VALUES. HQL only support insert from another table. For example
"insert into Object (id, name) select oo.id, oo.name from OtherObject oo";
Insert a stock record from another backup_stock table. This can also called bulk-insert statement.
Query query = session.createQuery("insert into Stock(stock_code, stock_name)" +
       "select stock_code, stock_name from backup_stock");
int result = query.executeUpdate();
The query.executeUpdate() will return how many number of record has been inserted, updated or deleted.

Reference

  1. Hibernate 3.3.2 query documentation

2017年4月1日 星期六

Linux 誤刪檔案解決辦法

首先先用 wget 下載 extundelete-0.2.0.tar.bz2 這個檔案,然後使用以下指令進行解壓縮

如下載至 /temp
tar -xvf extundelete-0.2.0.tar.bz2
切換到解壓縮的目錄 /temp 執行 二次./configure
./configure
./configure

執行 make 編譯原始碼 make compiler 好的 執行檔在 src 目錄中 執行救回誤刪檔案 ./src/extundelete /dev/sda1 –restore-all

2017年3月29日 星期三

MySQL 如何找出 default Database 所在位置

Windows 版:
1.以 MS-DOS模式登入 MySQL
    mysql -u root -p

2.輸入以下指令
SHOW VARIABLES WHERE Variable_Name LIKE "%dir";





DataDir 就是  Database 所在位置

2017年3月26日 星期日

MS SQL 2008 儲存 Unicode 字元之解決

以 JSP + MS SQL 為例
將儲存欄位設定為 nchar 或 nvarchar 等 UNICODE 資料型態應該就可以了。

1.定義 DB 之SCHEMA 必須為 nvarchar

 

2.網頁編碼須為 utf-8
<%@ page language="java" import="java.util.*" contentType="text/html; charset=utf-8"  pageEncoding="utf-8"%>


3.Database DAO 必須以 UTF-8 連線
    <property name="connection.driver_class">com.microsoft.sqlserver.jdbc.SQLServerDriver</property>
    <property name="hibernate.connection.url">jdbc:sqlserver://127.0.0.1:1433;databaseName=myDB2;useUnicode=true;characterEncoding=UTF-8;</property>



參考資料:
原文出處:  
http://rogercode.blogspot.tw/2015/07/sql-serversql-server.html

[SQL Server]修改SQL Server資料庫字元編碼

目前網頁幾乎都用萬國碼UTF-8 and Unicode
若希望將資料庫的定序名稱更改為時,卻無法使用SQL Server Enterprise Manager直接修改,
可以使用下列語法修改:



ALTER DATABASE [DBName] SET SINGLE_USER WITH ROLLBACK IMMEDIATE
ALTER DATABASE [DBName] COLLATE SQL_Latin1_General_CP1_CI_AS
ALTER DATABASE [DBName] SET MULTI_USER WITH ROLLBACK IMMEDIATE

PS.[DBName]為您的資料庫名稱。

因為在改定序名稱時必須先鎖定資料庫
第一行要先將資料庫設定為SINGLE_USER(同一時間只能有一位使用者存取資料庫)
第二行修改定序名稱
第三行將資料庫改回 MULTI_USER
另外要執行這些指令值須先將所在的資料庫切換到master下。

註:
"Chinese_Taiwan_Stroke_CI_AS"為BIG5
"SQL_Latin1_General_CP1_CI_AS"為UTF8

Javascript 動態新增 input Element (不使用 Jquery)

圖例:
按新增作者後

<script>
    function addinput(){    
        var obj_0 = document.getElementsByName("addmember");
        var items="";
        //保存原有值
        for(i=0; i<obj_0.length ; i++){        
        if(items==""){
        items = document.getElementsByName("addmember")[i].value;
        }else{
        items += ","+ document.getElementsByName("addmember")[i].value;
        }        
        }
       
        if( obj_0.length==0 ){
        //第一次新增
          var obj = document.getElementById("content");
            obj.innerHTML = obj.innerHTML + "<br>作者:<input type='text' name='addmember' value='' />";                          
        }else{
        //第二次以後
        //先清除原有input 項目,再重新新增
        document.getElementById("content").innerHTML="";
        var obj = document.getElementById("content");
if( items.indexOf(",")>0 ){
            var ss =items.split(",");
                for(i=0; i<ss.length ; i++){
                    var val = ss[i];                  
                obj.innerHTML += "<br>作者:<input type='text' name='addmember' value='"+ val + "' />";        
                }
}else{              
                obj.innerHTML = "<br>作者:<input type='text' name='addmember' value='"+ items + "' />";        
}      
            obj.innerHTML += "<br>作者:<input type='text' name='addmember' value='' />";        
        }  
    }

</script>
</head>
<body>
<form name="myForm">
<div id="myDiv" style="display:none">test</div><br/>

作者:<input type="text" name="member" /><input type='button' id="add" value="新增作者" onclick="addinput();" /><br/>
<span id="content"></span><br/>

</form>
</body>


Java 不同編碼字串, 其字串長度大小計算

以 Java 開發專案, 在 DAO 寫入資料庫時, 常遇到JAVA 字串與資料庫編碼不一致, 有時會產生字串過長,導致無法寫入資料庫的情況. 這時就要在入庫前, 先驗證 JAVA 編碼字串是否超出資料庫欄位長度 JAVA 依 不同編碼, 其長度是不一樣的 如: ...