hibernate獲取資料庫
① 如何使用Nhibernate動態連接Oracle資料庫
一、使用配置文件nfig)連接資料庫
下面以使用Nhibernate2.2連接Oracle10資料庫為例,給出連接配置信息如下:
<configSections>
<section name="hibernate-configuration" type="NHibernate.Cfg.ConfigurationSectionHandler, NHibernate" />
</configSections>
<hibernate-configuration xmlns="urn:nhibernate-configuration-2.2">
<session-factory name="NHibernate.Test">
<property name="connection.driver_class">NHibernate.Driver.OracleClientDriver</property>
<property name="nnection_string">User ID=hzga;Password=hzga;Data Source=orcl;Persist Security Info=True;</property>
<property name="show_sql">false</property>
<property name="dialect">NHibernate.Dialect.Oracle10gDialect</property>
<property name="query.substitutions">true 1, false 0, yes 'Y', no 'N'</property>
<property name="proxyfactory.factory_class">NHibernate.ByteCode.LinFu.ProxyFactoryFactory, NHibernate.ByteCode.LinFu</property>
</session-factory>
</hibernate-configuration>
二、通過提供一個IDictionary實例連接資料庫
下面還是以使用Nhibernate2.2連接Oracle10資料庫為例,給出連接配置信息如下:
cfg = new Configuration();
IDictionary<string, string> connProps = new Dictionary<string, string>();
connProps.Add("connection.driver_class", "NHibernate.Driver.OracleClientDriver");
connProps.Add("nnection_string", "User ID=hzga;Password=hzga;Data Source=orcl;Persist Security Info=True;");
connProps.Add("query.substitutions", "true 1, false 0, yes 'Y', no 'N'");
connProps.Add("dialect", "NHibernate.Dialect.Oracle10gDialect");
connProps.Add("proxyfactory.factory_class", "NHibernate.ByteCode.LinFu.ProxyFactoryFactory, NHibernate.ByteCode.LinFu");
cfg.SetProperties(connProps);
cfg.AddAssembly(AssemblyName);
sessions = cfg.BuildSessionFactory();
三、如何使用Nhibernate動態直接連接Oracle資料庫
上述兩種方式都可以成功連接到Oracle資料庫,但是前提條件是運行程序時需要安裝Oracle客戶端。在程序發布部署的時候安裝Oracle客戶端是一件非常麻煩的事件,那麼有沒有一種比較好的方法可以直接連接Oracle資料庫,同時又不必安裝Oracle客戶端呢。
答案是肯定的,下面提供兩種方式直接連接Oracle資料庫:
1、通過OleDB和Oracle公司的驅動
cfg = new Configuration();
IDictionary<string, string> connProps = new Dictionary<string, string>();
connProps.Add("connection.driver_class", "NHibernate.Driver.OleDbDriver");
connProps.Add("nnection_string", "Provider=OraOLEDB.Oracle.1;User ID=hzga;Password=hzga;Data Source=(DESCRIPTION = (ADDRESS_LIST= (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.13.148)(PORT = 1521))) (CONNECT_DATA = (SERVICE_NAME = orcl)))");
connProps.Add("query.substitutions", "true 1, false 0, yes 'Y', no 'N'");
connProps.Add("dialect", "NHibernate.Dialect.Oracle10gDialect");
connProps.Add("proxyfactory.factory_class", "NHibernate.ByteCode.LinFu.ProxyFactoryFactory, NHibernate.ByteCode.LinFu");
cfg.SetProperties(connProps);
cfg.AddAssembly(AssemblyName);
sessions = cfg.BuildSessionFactory();
2、通過OLEDB和微軟公司的Oracle驅動
cfg = new Configuration();
IDictionary<string, string> connProps = new Dictionary<string, string>();
connProps.Add("connection.driver_class", "NHibernate.Driver.OleDbDriver");
connProps.Add("nnection_string", " Provider=MSDAORA.1;User ID=lportal;Password=lportal;Data Source=(DESCRIPTION = (ADDRESS_LIST= (ADDRESS = (PROTOCOL = TCP)(HOST = zhbrserver)(PORT = 1521))) (CONNECT_DATA = (SERVICE_NAME = orcl)))");
connProps.Add("query.substitutions", "true 1, false 0, yes 'Y', no 'N'");
connProps.Add("dialect", "NHibernate.Dialect.Oracle10gDialect");
connProps.Add("proxyfactory.factory_class", "NHibernate.ByteCode.LinFu.ProxyFactoryFactory, NHibernate.ByteCode.LinFu");
cfg.SetProperties(connProps);
cfg.AddAssembly(AssemblyName);
sessions = cfg.BuildSessionFactory();
② hibernate中,用HQL查詢如何獲取資料庫中年齡欄位最大的那條記錄HQL語句怎麼寫
可以用子查詢:
hql語句
"from User where age=(select max(age) from User) "
相應的sql語句是
SELECT * FROM USER WHERE AGE=(SELECT MAX(AGE) FROM USER);
③ hibernate怎麼獲取資料庫表欄位等信息
hibernate怎麼獲取資料庫表欄位等信息
教你個方法:
List result = session.createSQLQuery(sql)
.setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP).list()
用這個方法可以把資料庫查詢出來的每一行封裝成一個Map類型,Key為資料庫欄位,Value為值,
然後把這些Map放到了一個List裡面,
如果你只返回一條記錄:
那麼
Map<String, Object> map = (Map<String, Object>) result.get(0);
即可得到你這一行記錄轉換層的Map,
如果有多條,迭代List即可。
希望對你有幫助
④ hibernate 讀取數據 只有1000條!好奇怪
文檔修復、恢復方法 一、文檔格式法 這種方法是將損壞的Word文檔轉換為另一種格式,然後再將它轉換回Word文檔格式。這是最簡單和最徹底的文檔恢復方法。所以如果遇到顯示混亂的情況,推薦首先使用這種方法。步驟如下: 1.在Word中打開損壞的文檔,選擇文件另存為,在保存類型列表中,選擇RTF格式(?....rtf),然後單擊保存按鈕。 2.關閉損壞的文檔,打開剛才保存的RTF文件,選擇文件另存為,在保存類型列表中,選擇Word文檔(?.doc),然後單擊保存按鈕。 3.關閉RTF文檔,打開DOC文檔。 Word文檔與RTF的相互轉換將保留其格式,如果這種轉換沒有修復文件,則可以嘗試與其他格式相互轉換,這將不同程度地保留Word文檔的格式。如果使用這些格式均無法解決本問題,可將文檔轉換為純文本格式(?.txt),再轉換回Word格式。由於純文本的簡單性,有可能修復損壞處,但是Word文檔的所有格式設置都將丟失。 二、重設格式法 Word用文檔中的最後一個段落標記關聯各種格式設置信息,特別是節與樣式的格式設置信息。這樣,硬碟壞了怎麼辦 227,如果我們將最後一個段落標記之外的所有內容復制到新文檔,就有可能將損壞的內容留在原始文檔中。步驟如下: 1.在Word中打開損壞的文檔,選擇工具選項,然後選擇編輯選項卡,取消使用智能段落選擇范圍復選框前的鉤。這樣,杭州筆記本維修,選定整個段落時,Word將不會自動選定段落標記。然後單擊確定按鈕。 2.選定最後一個段落標記之外的所有內容,方法是:按Ctrl+End組合鍵,然後按Ctrl+Shift+Home組合鍵。 3.在常用工具欄中,依次單擊復制、新建和粘貼按鈕。 三、重建模板法 Word在Normal.dot模板文件中存儲默認信息,如果該文件被損壞,Word文檔也有可能出問題。創建新的Normal模板的步驟如下: 1.關閉已打開的Word程序。 2.選擇開始查找文件或文件夾,在名稱框中,鍵入Normal.dot,在搜索下拉列表中選擇安裝Word的分區,然後單擊開始查找按鈕。 3.右鍵單擊搜索結果列表中的Normal.dot,然後選擇菜單中的重命名,隨便輸入一個新的名稱,然後確定。 4.啟動Word程序。 由於Word無法識別重命名後的Normal.dot文件,西數硬碟維修,Word只能重新創建一個新的Normal模板。創建新的Normal模板後,可以嘗試打開損壞的文檔。如果問題解決了,那就表明舊的Normal模板確實已經損壞,資料庫修復 555。此外,如果你的文檔還用到了Normal.dot之外的其他模板,為解決問題,也請嘗試重新創建該模板或使用它的較早版本。