隨筆-57  評論-202  文章-17  trackbacks-0
            2005年7月20日
          最近在弄swing,需要由JComponent生成BufferedImage,在CSDN上發現一個好例子。下面是范例:

          Rectangle?rect?=?comp.getBounds();
          ?BufferedImage?bufImage?
          =?new?BufferedImage(rect.width,
          ???????????rect.height,
          ???????????BufferedImage.TYPE_INT_RGB);
          ?Graphics?g?
          =?bufImage.getGraphics();
          ?g.translate(
          -rect.x,?-rect.y);
          ?comp.paint(g);

          這樣,JComponent中的圖像就保存到BufferedImage中了。
          原文的鏈接:http://dev.csdn.net/article/13/13531.shtm
          posted @ 2006-04-14 23:41 小米 閱讀(1391) | 評論 (1)編輯 收藏
          ??????? 好久沒有寫blog了,距離上次寫幾乎已經是半年前的事情了。?這半年發生了不少事情。首先換了家公司,進了家金融企業,每天要西裝革履的,一開始還真是不習慣。?這里開發是用的spring框架,以后要多研究研究spring的東西了。
          ??????? 第二件事就是和戀愛了三年的女友結婚了,從此兩人長相廝守,不知道時間久了會不會審美疲勞。呵呵。
          ??????? 第三件事就是在深圳買了自己的小房子,雖然是小小的兩房,不過我們已經很知足了。?而且剛好是趕在房價大漲前買的,還算走了點運氣。換到現在,都不知道去哪里買好了。
          ??????? 在這里要向一些留言和發郵件給我的網友道歉,前段時間實在是太忙,沒有空回復你們的信息和郵件。請原諒!
          posted @ 2006-03-29 19:43 小米 閱讀(798) | 評論 (0)編輯 收藏
                最近真是多事情忙,而且可能要忙到9月底。好久沒有上來更新我的博客了,暫且發發牢騷。
          posted @ 2005-08-10 17:32 小米 閱讀(1191) | 評論 (1)編輯 收藏
                這一節是非常實用的一節,我在閱讀此書的時候,一直在迷惑,究竟應該怎樣管理Session呢?因為Session的管理是如此重要,類似于以前寫程序對JDBC Connection的管理。看完此節后,終于找到了方法。
                在各種Session管理方案中,ThreadLocal模式得到了大量使用。ThreadLocal是Java中一種較為特殊的線程綁定機制。通過ThreadLocal存取的數據,總是與當前線程相關,也就是說,JVM為每個運行的線程,綁定了私有的本定實例存取空間,從而為多線程環境經常出現的并發訪問問題提供了一種隔離機制。
                下面是Hibernate官方提供的一個ThreadLocal工具:


          import net.sf.hibernate.
          *;
          import net.sf.hibernate.cfg.
          *;
          import org.apache.log4j.Logger;

          /**
           * <p>Title: </p>
           *
           * <p>Description: Session的管理類</p>
           *
           * <p>Copyright: Copyright (c) 2005</p>
           *
           * <p>Company: </p>
           *
           * @author George Hill
           * @version 1.0
           
          */


          public class HibernateUtil {

            
          private static final Logger log = Logger.getLogger(HibernateUtil.class);

            
          private static final SessionFactory sessionFactory;

            
          /**
             * 初始化Hibernate配置
             
          */

            
          static {
              
          try {
                
          // Create the SessionFactory
                sessionFactory = new Configuration().configure().buildSessionFactory();
              }
           catch (Throwable ex) {
                log.error(
          "Initial SessionFactory creation failed.", ex);
                
          throw new ExceptionInInitializerError(ex);
              }

            }


            
          public static final ThreadLocal session = new ThreadLocal();

            
          /**
             * 根據當前線程獲取相應的Session
             * @return Session
             * @throws HibernateException
             
          */

            
          public static Session currentSession() throws HibernateException {
              Session s 
          = (Session) session.get();
              
          // Open a new Session, if this Thread has none yet
              if (s == null{
                s 
          = sessionFactory.openSession();
                session.
          set(s);
              }

              
          return s;
            }


            
          /**
             * 返回Session給相應的線程
             * @throws HibernateException
             
          */

            
          public static void closeSession() throws HibernateException {
              Session s 
          = (Session) session.get();
              session.
          set(null);
              
          if (s != null)
                s.close();
            }


          }


                針對WEB程序,還可以利用Servlet2.3的Filter機制,輕松實現線程生命周期內的Session管理。下面是一個通過Filter進行Session管理的典型案例:

          public class PersistenceFilter implements Filter {
            
          protected static ThreadLocal hibernateHolder = new ThreadLocal();

            
          public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
              hibernateHolder.
          set(getSession());
              
          try {
                
                chain.doFilter(request, response);
                
              }
           finally {
                Session session 
          = (Session) hibernateHolder.get();
                
          if (session != null{
                  hibernateHolder.
          set(null);
                  
          try {
                    session.close();
                  }
           catch (HibernateException ex) {
                    
          throw new ServletException(ex);
                  }

                }

              }

            }

            
          }
          posted @ 2005-07-29 19:43 小米 閱讀(3945) | 評論 (1)編輯 收藏
                數據分頁顯示,是很多B/S系統會遇到的問題。現在大多數主流數據庫都提供了數據部分讀取機制,而對于某些沒有提供相應機制的數據而言,Hibernate也通過其它途徑實現了分頁,如通過Scrollable ResultSet,如果JDBC不支持Scrollable ResultSet,Hibernate也會自動通過ResultSet的next方法進行記錄定位。Hibernate的Criteria、Query等接口提供了一致的方法設定分頁范圍。下面是書中的例子:

          Criteria criteria = session.createCriteria(TUser.class);
          Criteria.add(Expression.eq(
          "age""20"));
          //從檢索結果中獲取第100條記錄開始的20條記錄
          criteria.setFirstResult(100);
          criteria.setFetchSize(
          20);

                不過,我在測試的時候總是不能夠正常工作,把setFetchSize方法換成setMaxResults方法才行。換成最新的mysql-connector-java-3.1.10-bin-g.jar驅動也是一樣。
          posted @ 2005-07-26 18:12 小米 閱讀(5561) | 評論 (4)編輯 收藏

                Hibernate通過Lifecycle、Validatable接口制定了實體對象CRUD過程中的回調方式。
                Lifecycle接口中的onSave、onUpdate、onDelete方法,如果返回true則意味著需要中止執行相應的操作過程。如果代碼運行期間拋出了CallbackException,對應的操作也會被中止。注意,不要試圖在這些方法中調用Session進行持久化操作,這些方法中Session無法正常使用。
                Validatable.validate方法將在實體被持久化之前得到調用以對數據進行驗證。此方法在實體對象的生命周期內可能被數次調用,因此,此方法僅用于數據本身的邏輯校驗,而不要試圖在此實現業務邏輯的驗證。



                Hibernate還引入了Interceptor,為持久化事件的捕獲和處理提供了一個非侵略性的實現。Interceptor接口定義了Hibernate中的通用攔截機制。Session創建時即可指定加載相應的Interceptor,之后,此Session的持久化操作動作都將首先經由此攔截器捕獲處理。簡單的加載范例如下:

          SessionFactory factory = config.buildSessionFactory();
          Interceptor it 
          = new MyInterceptor();
          session 
          = sessionFactory.openSession(it);

                需要注意的是,與Lifecycle相同,Interceptor的方法中不可通過Session實例進行持久化操作。
          posted @ 2005-07-21 18:35 小米 閱讀(3371) | 評論 (1)編輯 收藏
                有興趣的可以去參加看看,網址:http://www.javachina.cn/Index.jsp
          posted @ 2005-07-20 14:55 小米 閱讀(1027) | 評論 (2)編輯 收藏

                最近真是忙,事情都擠到一塊去了。 終于有時間又看了幾頁書。
                言歸正傳,Hibernate中的Collection類型分為有序集和無序集兩類。這里所謂的有序和無序,是針對Hibernate數據持久過程中,是否保持數據集合中的記錄排列順序加以區分的。無序集有Set,Bag,Map幾種,有序集有List一種。有序集的數據在持久化過程中,會將集合中元素排列的先后順序同時固化到數據庫中,讀取時也會返回一個具備同樣排列順序的數據集合。
                Hibernate中的Collection類型是用的自己的實現,所以在程序中,不能夠把接口強制轉化成相應的JDK Collection的實現。



                結果集的排序有兩種方式:
                1. Sort
                   Collection中的數據排序。
                2. order-by
                   對數據庫執行Select SQL時,由order by子句實現的數據排序方式。

                需要注意的是,order-by特性在實現中借助了JDK 1.4中的新增集合類LinkedHashSet以及LinkedHashMap。因此,order-by特性只支持在1.4版本以上的JDK中運行。

          posted @ 2005-07-20 10:56 小米 閱讀(3948) | 評論 (0)編輯 收藏
          主站蜘蛛池模板: 隆尧县| 襄樊市| 普定县| 临安市| 克山县| 武定县| 普洱| 惠东县| 正镶白旗| 怀化市| 南木林县| 两当县| 秦皇岛市| 安塞县| 都江堰市| 枣庄市| 福州市| 铁岭市| 句容市| 延寿县| 宁武县| 永昌县| 错那县| 福建省| 九台市| 临沧市| 林甸县| 涞水县| 自贡市| 高邑县| 甘谷县| 烟台市| 伊通| 肥城市| 定边县| 巫溪县| 沙湾县| 枣阳市| 万盛区| 沙坪坝区| 孝义市|