麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學院 > 開發設計 > 正文

如何在JAVA SE中使用Hibernate

2019-11-18 13:34:19
字體:
來源:轉載
供稿:網友

  目前人們很輕易發現Hibernate正迅速的成為流行的J2EE的O/R映射工具和數據集成框架(假如不是最流行的)。Hibernate為企業應用開發者操作關系數據庫的提供了清楚明了而又強大的工具。然而假如你需要在外部訪問那些包裝在J2EE web應用里的實體,情況又怎樣呢?你的開發跟應用獨立分開,卻又相同的實體以訪問你的數據嗎?又或者你得編寫附加的web組件來治理對數據的內部訪問嗎?

  在很多情況下,這些問題都會出現。我的情況是我的公司需要將來自多個供給商,有著多種文件格式的記錄導入到數據庫里。我想起我以前經常使用的方法,那就是編寫Shell和SQL教本(甚至是存儲過程)來導入數據。但是由于我們的數據模型太過復雜,我決定在web應用之外盡可能的利用現有的實體,SPRing DAO以及服務并且開發一個自定義的J2SE命令行數據加載工具。

  大問題:你該怎樣呢?

  現在很多Hibernate的文檔和范例都是綁定在容器上。不管是web應用還是內部的大型應用,總會使用到容器的。人們有很好的理由去使用它。容器是設計來提供對各種特性的支持,例如事務處理,線程以及安全。現今,這些特性都是開發中等規模和企業應用所必需的工具。然而當你需要在容器之外訪問實體時,你該怎樣呢?你是使用現有的架構和代碼呢,還是會從一個不同的角度來解決問題,比如說完全采用另一種開發語言?當然,我們沒有正確答案。在本文的余下部分,我將說明我的方法:就是在Spring容器之外重用現有的實體/POJO.

  起初,腳本語言,例如Perl,Python,Ruby甚至Tcl(是的,我以前也做過這個)看起來有很多優勢。它們能省下很多時間,可以輕易得到初始結果,還能規避許多Hibernate潛在的復雜度。人們完全可能只用幾行代碼就可以連接數據庫,查詢結果,已經打印輸出到終端屏幕或者日志文件。然而,取決于你的數據模型,事情也(總是)會變得相當復雜。譬如說你有一個表 person, 其中有一個外鍵屬于表 address.當我們添加數據的時候,表address沒有正確的插入數據,就會導致表person 也不能插入了。這是個很典型的事務處理方面的問題。也許有人會說在腳本語言中這個問題不難解決,就像在你的主程序里一樣。可是問題仍然存在,為什么要這樣做呢?業務邏輯不是已經在你的應用里面了嗎?為什么要在寫一遍代碼呢?而且這并不是唯一的情況,你必須重復你的工作和業務邏輯,這樣就會帶來出錯的可能。

  然而,有些人會覺得這樣也行,他們使用自己覺得最適合的工具。也許你已經因為程序之外的原因而有了某種獨立的架構;也許你會在獨立的數據庫里加載和測試數據,然后在通過各種測試后再遷移到產品的數據庫里;又也許你把數據庫維護外包出去,你只需要把相關文件發給合作伙伴讓他們去處理那些問題。總之,總會有很多理由不使用現有的Hibernate數據層。沒有誰對誰錯,只是假如你可以也愿意在你的應用之外使用現有的代碼,請往下看。我會告訴你一些方法,這能解決你不少的煩惱噢。

  配置

  假如你覺得可以在容器之外使用現有的Hibernate對象的話,那你首先要做的事就是得自己手工治理所有的配置項,在本文余下部分我所采用的方法是使用一個基于命令行的java程序。既然你已經配置了Hibernate xml配置文件,你應該知道需要提供的參數,例如JNDI DataSource名,實體映射文件,還有其他一些處理SQL日志的屬性。假如你想使用命令行程序的話,你就得解決如何解析XML文件和把它添加到配置項中的這些問題。雖然解析XML文件也不難,但這本身并不是我們的重點。因此,我建議使用propetries文件,properties文件比較直觀而且輕易加載并從中讀取數據。下面是配置Hibernate所需要的最小屬性集(不包括任何實體映射)。

  清單1:

hibernate.dialect=net.sf.hibernate.dialect.PostgreSQLDialect
hibernate.connection.driver_class=org.postgresql.Driver
hibernate.connection.url=jdbc:postgresql://devserver/devdb
hibernate.connection.username=dbuser
hibernate.connection.passWord=dbpassword
hibernate.query.substitutions yes 'Y'

  正如你所看到的,上面的屬性值指定了數據庫方言,JDBC驅動,數據庫url,用戶名,用戶密碼,以及是否使用查找替換。只要定義以上幾項數值并保存在文件hibernate.properties里(要放置在你的類路徑里面哦),就能很輕松的加載,填充到Hibernate Configuation類里面。

  清單2:

Properties props = new Properties();
try {
    props.load(props.getClass().getResourceAsStream("hibernate.properties"));
}catch(Exception e){
    System.out.println("Error loading hibernate properties.");
    e.printStackTrace();
    System.exit(0);
}

String driver = props.getProperty("hibernate.connection.driver_class");
String connUrl = props.getProperty("hibernate.connection.url");
String username = props.getProperty("hibernate.connection.username");
String password = props.getProperty("hibernate.connection.password");            

// In my examples, I use Postgres, but Hibernate
// supports virtually every popular dbms out there.
Class.forName("org.postgresql.Driver");
Connection conn = DriverManager.getConnection(connUrl, username, password);

Configuration cfg = new Configuration();
cfg.setProperties( props );
sessionFactory sessions = cfg.buildSessionFactory();
Session session = sessions.openSession(conn);



發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 最新在线黄色网址 | 久久久久亚洲美女啪啪 | 中文字幕涩涩久久乱小说 | 精品av在线播放 | 亚洲极色| 欧美日韩在线播放 | 久久精品性视频 | 午夜精品小视频 | 久草在线手机视频 | 久久福利精品 | 国产精品久久久久久久不卡 | 国产成人综合在线视频 | 在线成人免费观看www | 久久草在线视频免费 | 久久99久久99免费视频 | 国产羞羞视频在线观看免费应用 | 毛片免费观看视频 | 婷婷亚洲一区二区三区 | 国产91丝袜在线播放 | 日本精品视频一区二区三区四区 | 中午日产幕无线码1区 | 亚洲第一成av人网站懂色 | 视频一区二区三区中文字幕 | 在线播放av网址 | 竹内纱里奈和大战黑人 | 欧美一区二区黄 | 精品一区二区三区中文字幕老牛 | 国产精品资源手机在线播放 | 福利在线播放 | 热99在线视频 | 国产一级淫片在线观看 | 欧美日韩专区国产精品 | 日本在线播放一区二区三区 | 久久99国产精品视频 | 91网站链接| 色妞视频男女视频 | 久久欧美亚洲另类专区91大神 | 一级电影免费看 | 毛片毛片 | 在线看小早川怜子av | 国产一级aa大片毛片 |