Ⅰ Hibernate如何動態鏈接資料庫
一.導包 mysql
二.在默認src下創建hibernate.cfg.xml
1.創建xml文件,命名為hibernate.cfg.xml
2.添加約束
(在org.hibernate/hibernate-configuration-3.0.dtd中)
1 <!DOCTYPE hibernate-configuration PUBLIC2 "-//Hibernate/Hibernate Configuration DTD 3.0//EN"3 "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration> <session-factory> <property name="dialect">org.hibernate.dialect.MySQLDialect</property> <property name="connection.url">jdbc:mysql://localhost:3306/houserentsys</property> <!-- houserentsys是資料庫名稱 -->
<property name="connection.driver_class">com.mysql.jdbc.Driver</property> <property name="connection.username">root</property> <property name="connection.password">123456</property>
<property name="show_sql">true</property> <property name="format_sql">false</property> <!-- 設置為false就會不換行 --> <property name="hbm2ddl.auto">update</property> <!-- 進行操作時不會刪除重建-->
<!--hbm2ddl.auto屬性:
create:表示啟動的時候先drop,再create
c
reate-drop: 也表示創建,只不過再系統關閉前執行一下drop
update: 這個操作啟動的時候會去檢查schema是否一致,如果不一致會做scheme更新
validate: 啟動時驗證現有schema與你配置的hibernate是否一致,如果不一致就拋出異常,並不做更新
-->
<mapping resource="e/tsinghua/entity/mapping/district.xml"/> <mapping resource="e/tsinghua/entity/mapping/street.xml"/>
</session-factory></hibernate-configuration>
hbm2ddl.auto屬性:
create:表示啟動的時候先drop,再create
create-drop: 也表示創建,只不過再系統關閉前執行一下drop
update: 這個操作啟動的時候會去檢查schema是否一致,如果不一致會做scheme更新
validate: 啟動時驗證現有schema與你配置的hibernate是否一致,如果不一致就拋出異常,並不做更新
三.實體 實現序列化介面 封裝屬性和構造方法 實體.xml 位置隨意
(在org.hibernate/hibernate-mapping-3.0.dtd中)
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
在hibernate.cfg.xml 添加 映射文件的引用
<mapping resource="e.tsinghua.entity.mapping.district"/>
七個步驟(在新建的執行文件Test.java中)
//1.載入配置文件
Configuration cfg=new Configuration().configure();
//2.獲得sessionfactory
ServiceRegistry serviceRegistry=new ServiceRegistryBuilder().applySettings(cfg.getProperties()).buildServiceRegistry();
SessionFactory sf=cfg.buildSessionFactory(serviceRegistry);
//3.創建session
Session session=sf.openSession();
//4.創建事務
Transaction tx=session.beginTransaction();
//5.操作
District dis=new District(100,"海淀區");
session.save(dis);
//6.提交 回滾
tx.commit();//tx.rollback();
//7.釋放資源
Ⅱ 什麼是動態連接數據DLL,靜態鏈接資料庫LIB
動態鏈接庫(指的是運行時動態載入),當你運行一個可執行文件時(exe),該exe會調用系統API (Loadlibrary)去載入某個dll,從而使用其中的函數或數據,
靜態鏈接庫(lib),是指在編譯一個exe的時候,編譯器去載入的庫,這樣就直接將要用的函數或數據直接編譯到exe中,成為一個整體,方便轉移,但體積大
Ⅲ c# 資料庫動態鏈接!
你可以在自己的bin目錄下新建文件(如.txt,.dat,.ini,.config都可以)
我這邊以.ini為例說下:
( 下面等號右邊的 DataSource = D:\zmd\自己的例子ileLostOrNot\frmDataBaseChange\bin\Debug\Data\地質災害查詢統計資料庫.mdb 這
里是我的資料庫的絕對路徑,(用戶)要修改就是在這里(修改成自己的~~,很方便的~))
--------------------------------------------------你在.ini文件中寫如下代碼,從下行開始復制,這行不要
;用戶自行連接字元串strConnetion
[UserManagestrConnetion]
Source =D:\zmd\自己的例子\FileLostOrNot\frmDataBaseChange\bin\Debug\Data\地質災害查詢統計資料庫.mdb
-----------------------------------------------------------------------------------到上面為止,這行不要
下面是你程序中的代碼:
首先引用中添加(Nini.dll)文件(沒有可以找我要,也可以自己去下),再引用空間
using Nini.Config;
using System.Data.SqlClient;
某個事件中添加如下代碼:
string configfile = Application.StartupPath + @"\iTelluro.GlobeEngine.ini";
IConfigSource ConfigSource = new IniConfigSource(configfile);
string strSource = ConfigSource.Configs["UserManagestrConnetion"].Get("Source");
string sqlConnectionString="server=(local);"+"integrated security=SSPI;"+"database=" + strSource ;//這個連接字元串不知道對不,我一般用的都Access的
(string SqlConnectionString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + strSource ;//我連接的是Access的資料庫,你自己修改下連接字元串吧)
SqlConnection sqlCon= new SqlConnection(SqlConnectionString);
sqlCon.Open();
//下面的你應該很熟習
DataSet ds = new DataSet();
SqlDataAdapter da = new SqlDataAdapter("自己的sql查詢語句", sqlCon);
da.Fill(ds);
你先試下吧,不行的話,可以在hi我~~
Ⅳ Excel動態鏈接外部資料庫
你所說的動態資料庫是什麼類型的文件?有幾個方法可以實現,首先最接近你描述的方法是數據透視表.其次是插入對象操作.再者是公式函數SUMIF,VLOOKUP,等號等之類的操作,不太明白你具體的情況.暫時沒確定哪種適合.
Ⅳ 動態資料庫的什麼是動態鏈接庫
DLL三個字母對於你來說一定很熟悉吧,它是Dynamic Link Library 的縮寫形式,函數的可執行代碼位於一個 DLL 中,該 DLL 包含一個或多個已被編譯、鏈接並與使用它們的進程分開存儲的函數。DLL 還有助於共享數據和資源。多個應用程序可同時訪問內存中單個 DLL 副本的內容。
動態鏈接庫是一個能夠被應用程序和其它的DLL調用的過程和函數的集合體,它裡麵包含的是公共代碼或資源。由於DLL代碼使用了內存共享技術,在某些地方windows也給了DLL一些更高的許可權,因而DLL中可以實現一些一般程序所不能實現的功能,如實現windows的HOOK、ISAPI等。
同時,DLL還為不同語言間代碼共享提供了一條方便的途徑。因而DLL在編程時應用較為廣泛,本文將介紹如何在 Delphi 中建立和使用DLL。
從使用效果看,DLL和unit 很像,它們都可以被別的工程模塊所調用,但二者在內部的實現機制上確存在著差別。如果一個程序模塊中用uses語句引用了某個unit,編譯程序在編譯該模塊時,便會連同unit一起編譯,並把編譯後的可執行代碼鏈接到本程序模塊中,這就是一個程序模塊能夠調用所引用unit中過程和函數的原因。
當同一個unit被多個工程所引用時,則每個工程中都含有該unit的可執行代碼,當含有該unit的多個工程同時執行時,unit的可執行代碼會隨不同工程而多次被調入內存,造成內存資源的浪費。DLL則不同,它即使被某個工程調用,編譯後仍是獨立的。
也就是說編譯後,一個DLL庫形成一個單獨的可執行文件,而不與任何其它的可執行文件連接在一起,因而DLL庫並不從屬於某個特定的工程,當多個工程調用同一個DLL庫時只有第一個工程把DLL庫調入內存,其餘工程並不重復調入同一個DLL庫到內存,而是到同一個共享內存區讀取。並且,DLL的執行代碼是在程序運行期間動態調入的,而不是如unit在程序運行時就與整個工程一起調入內存。這樣便可消除unit帶來的相同代碼多處佔用內存的弊病。Delphi中DLL庫的建立
在Delphi環境中,編寫一個DLL同編寫一個一般的應用程序並沒有太大的區別。事實上作為DLL主體的DLL函數的編寫,除了在內存、資源的管理上有所不同外,並不需要其它特別的手段。
一般工程文件的格式為:
program 工程標題;
uses 子句;
程序體
而DLLs工程文件的格式為:
library 工程標題;
uses 子句;
exprots 子句; 1.一般工程文件的頭標用program關鍵字,而DLL工程文件頭標用library 關鍵字。不同的關鍵字通知編譯器生成不同的可執行文件。用program關鍵字生成的是.exe文件,而用library關鍵字生成的是.dll文件;
2.假如DLL要輸出供其它應用程序使用的函數或過程,則必須將這些函數或過程列在exports子句中。而這些函數或過程本身必須用export編譯指令進行編譯。 在Delphi主菜單file 中選new...項,在彈出的窗口中雙擊DLL圖標,便會自動給出DLL源模塊框架,如下:
Library project1;
{...注釋...}
uses
SysUtils, Classes;
begin
end.
接下來便可在USES和begin之間加入想在該DLL中實現的過程和函數的定義,並用export和exprots保字把它們引出,以便別的模塊引用,在begin和end之間加入初始化代碼,初始化代碼是用來對DLL變數初始化的。應注意,即便無初始化代碼begin與end也不可省略,如下例:
library minmax;
function Min(X, Y: Integer): Integer; export;
begin
if X < Y then Min := X else Min := Y;
end;
function Max(X, Y: Integer): Integer; export;
begin
if X > Y then Max := X else Max := Y;
end;
exports
Min index 1,
Max index 2;
begin
end.
經編譯後,並以minmax.DLL存檔後,一個DLL庫文件便形成了。 訪問DLL庫有兩種方式,一種是靜態引用,另一種是動態引用。
用靜態引用這種方法裝入DLL要做兩件事情:為DLL 庫創建一個輸入單元,以及用USES把輸入單元連接到要使用DLL 函數的程序模塊中。為DLL庫創建的輸入單元與普通的單元的區別僅在於:在它的介面處聲明的過程、函數,並不在它的實現部分給出真正的實現代碼,而是用external關鍵字把過程、函數的實現細節委託給外部DLL模塊。
external命令的使用語法如下:
procere /function 過程/函數名;external DLL模塊名;
下面給出為上面創建的minmax.DLL庫寫的輸入單元源文件testdll .pas,從中可看出輸入單元與一般單元的一些差別,代碼如下所示:
unit testdll;
interface
uses
function Min (X, Y: Integer): Integer;
function Max (X, Y: Integer): Integer;
implementation
function Min; external 『minmax.DLL』;
function Max; external 『minmax.DLL』;
end.
一個應用程序若想調用minmax.DLL中的函數,只須在其uses語句中加入testdll 單元即可。
動態裝入DLL,要用到Windows的三個API函數。Loadlibrary、Freelibrary和GetprocAddress 。 loadlibrary函數用來裝入DLL庫,其調用格式如下:
function loadlobrary (DLLfileName:Pchar): THandle:
當不再需要一個DLL庫時,應調用FreeLibrary函數將其釋放,以空出寶貴的內存資源,其調用格式如下:
procere FreeLibrary (Libmole:THandle)
Libmole 為由LoadLibrary調用得到的DLL庫句柄。在用loadlobrary 函數裝入某個DLL庫和調用FreeLibrary釋放該DLL庫之間的程序段中, 可以使用該DLL庫中的過程和函數,具體使用方法是:用GetprocAddress函數把DLL庫中函數的地址傳遞給程序中某個函數變數,再用該變數實現DLL函數的調用。GetprocAddress函數聲名如下
function GetprocAddress (Libmole:THandle:procname:pchar):TFarProc:
如下例所示:
type
TTimeRec = record
Second: Integer;
Minute: Integer;
Hour: Integer;
end;
TGetTime = procere(var Time: TTimeRec);
THandle = Integer;
var
Time: TTimeRec;
Handle: THandle;
GetTime: TGetTime;
...
begin
Handle := LoadLibrary('DATETIME.DLL');
if Handle <> 0 then
begin
@GetTime := GetProcAddress(Handle, 'GetTime');
if @GetTime <> nil then
begin
GetTime(Time);
with Time do
WriteLn('The time is ', Hour, ':', Minute, ':', Second);
end;
FreeLibrary(Handle);
end;
end;
在調用動態鏈接庫時應注意, 所需動態鏈接庫須與應用程序在同一目錄或Windows System 目錄下。
動態鏈接庫是 Windows下程序組織的一種重要方式,使用動態鏈接庫可以極大地保護用戶在不同開發工具、不同時期所做的工作,提高編程效率。
Ⅵ win10升級後,出現無法定位序數1於動態鏈接庫,該怎麼解決
解決方法:
1、首先取得許可權,TrustedInstaller許可權.只要將下面的注冊表文件導入,就有TrustedInstaller許可權。
Ⅶ 我安裝資料庫的時候無法找到動態鏈接資料庫,在所有程序中也沒有顯示,這是什麼原因呢,其他軟體會顯示
動態鏈接庫(DLL)它是Dynamic Link Library 的縮寫形式,:
(1)你所指的資料庫路徑不對。。。。重新設置一下就可以了。
(2)你的有些程序是不是在重裝系統前安裝的?在某些程序安裝的時候,它會寫一些動態連接資料庫文件在C盤,也就是系統盤,你重裝了系統之後就被刪除了,那些程序當然不能用,建議把不能用的程序重新安裝一次
(3)修復方法步驟
-------------------------------------
一、系統可以啟動登陸的修復方法:(轉載請註明出自Coderui的博客,謝謝)
1:把系統程序「lsass.exe」文件和系統DLL組件程序「mfc40u.dll」文件同時改名,Windows系統是支持運行著的程序改名的。(如果您能終止掉系統程序「lsass.exe」和DLL組件「mfc40u.dll」的運行也可以)。
2:復制一個正常的系統程序「lsass.exe」文件保存為「C:\WINDOWS\system32\lsass.exe」文件。
3:復制一個正常的系統DLL組件程序「mfc40u.dll」文件保存為「C:\WINDOWS\system32\mfc40u.dll」文件。
4:按照上邊的1-3步驟操作完畢後,重新啟動一次計算機,一切修復完畢。
5:系統修復完畢後,要使用殺毒軟體去查殺病毒。因為該病毒為木馬下載器,它可能已經在您的計算機系統中安裝了其它惡意程序(20款以上)。
-------------------------------------
二、系統無法啟動登陸的修復方法:(轉載請註明出自Coderui的博客,謝謝)
1:使用PE盤或DOS盤啟動系統(這種情況下,安全模式是無法登陸的)。
2:復制一個正常的系統程序「lsass.exe」文件保存為「C:\WINDOWS\system32\lsass.exe」文件。
3:復制一個正常的系統DLL組件程序「mfc40u.dll」文件保存為「C:\WINDOWS\system32\mfc40u.dll」文件。
4:按照上邊的1-3步驟操作完畢後,重新啟動一次計算機,一切修復完畢。
5:系統修復完畢後,要使用殺毒軟體去查殺病毒。因為該病毒為木馬下載器,它可能已經在您的計算機系統中安裝了其它惡意程序(20款以上)。
-------------------------------------
注意:
上述三個文件一般都可以在系統「C:\WINDOWS\system32\dllcache」目錄下找到正常完好的系統備份文件。如果實在沒有找到的話,可以去同一個版本的其它計算機系統中拷貝。
最好是斷開網路修復系統,因為該病毒為木馬下載器,它會連接網路向您的計算機中安裝20多款其它惡意程序(如網路游戲盜號木馬等)。
因為該病毒並沒有去破壞或修改您系統中的注冊表,請您不要去重新注冊系統DLL組件「mfc40u.dll」,不然可能會帶去不必要的麻煩。
還有就是你安裝的資料庫是否跟電腦上現有軟體有沖突,需要進行相應設置,而你一直默認安裝了,如sql server 2005跟visul studio 2005/2008.
希望對您有用。