日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢(xún)
選擇下列產(chǎn)品馬上在線(xiàn)溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷(xiāo)解決方案
實(shí)現(xiàn)數(shù)據(jù)庫(kù)動(dòng)態(tài)連接——簡(jiǎn)便高效的數(shù)據(jù)操作方式(對(duì)數(shù)據(jù)庫(kù)的動(dòng)態(tài)連接)

隨著現(xiàn)代互聯(lián)網(wǎng)技術(shù)的不斷發(fā)展,數(shù)據(jù)庫(kù)的使用已經(jīng)無(wú)法避免。不僅是大型企業(yè)需要使用數(shù)據(jù)庫(kù)存儲(chǔ)數(shù)據(jù),越來(lái)越多的小型企業(yè)和個(gè)人用戶(hù)也開(kāi)始使用數(shù)據(jù)庫(kù),用于存儲(chǔ)各種數(shù)據(jù),包括個(gè)人記錄、商業(yè)交易、客戶(hù)資料等等。但是,對(duì)于使用者來(lái)說(shuō),如何高效地對(duì)數(shù)據(jù)庫(kù)進(jìn)行操作卻是一個(gè)不小的問(wèn)題。而實(shí)現(xiàn)數(shù)據(jù)庫(kù)動(dòng)態(tài)連接則可以使用簡(jiǎn)便、高效的方式來(lái)解決這個(gè)問(wèn)題。

成都創(chuàng)新互聯(lián)長(zhǎng)期為超過(guò)千家客戶(hù)提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊(duì)從業(yè)經(jīng)驗(yàn)10年,關(guān)注不同地域、不同群體,并針對(duì)不同對(duì)象提供差異化的產(chǎn)品和服務(wù);打造開(kāi)放共贏平臺(tái),與合作伙伴共同營(yíng)造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為東烏珠穆沁企業(yè)提供專(zhuān)業(yè)的成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站制作,東烏珠穆沁網(wǎng)站改版等技術(shù)服務(wù)。擁有10年豐富建站經(jīng)驗(yàn)和眾多成功案例,為您定制開(kāi)發(fā)。

何為數(shù)據(jù)庫(kù)動(dòng)態(tài)連接

先來(lái)介紹一些基礎(chǔ)概念。所謂數(shù)據(jù)庫(kù),就是按照一定的數(shù)據(jù)結(jié)構(gòu),存儲(chǔ)在計(jì)算機(jī)設(shè)備上的數(shù)據(jù)。而動(dòng)態(tài)連接,指的是通過(guò)使用特殊程序代碼,將一個(gè)程序與另一個(gè)程序進(jìn)行連接。在數(shù)據(jù)庫(kù)中,動(dòng)態(tài)連接通常用于在程序和數(shù)據(jù)之間建立一條通路,使得程序可以隨時(shí)訪問(wèn)和獲取數(shù)據(jù)信息,同時(shí)也可以將程序中產(chǎn)生的數(shù)據(jù)寫(xiě)入到數(shù)據(jù)庫(kù)中。這樣,不僅可以保證數(shù)據(jù)的安全性和完整性,也能夠快速、準(zhǔn)確地對(duì)數(shù)據(jù)進(jìn)行分析和處理。

實(shí)現(xiàn)數(shù)據(jù)庫(kù)動(dòng)態(tài)連接的方式

實(shí)現(xiàn)數(shù)據(jù)庫(kù)動(dòng)態(tài)連接并不是一件容易的事情,需要對(duì)計(jì)算機(jī)編程有一定的了解。下面將介紹兩種實(shí)現(xiàn)動(dòng)態(tài)連接的方式,需要讀者具備一定的編程基礎(chǔ)才能夠理解。

1.通過(guò)編寫(xiě)程序?qū)?shù)據(jù)庫(kù)和編程語(yǔ)言進(jìn)行連接

這種方式較為耗時(shí)且需要一定的程序設(shè)計(jì)技巧,但可以實(shí)現(xiàn)數(shù)據(jù)庫(kù)和編程語(yǔ)言之間的程序連接,并且可以動(dòng)態(tài)獲取數(shù)據(jù)庫(kù)中的數(shù)據(jù)。

具體實(shí)現(xiàn)步驟如下:

(1)選擇合適的編程語(yǔ)言,例如Java、Python等等。

(2)安裝相關(guān)的數(shù)據(jù)庫(kù)驅(qū)動(dòng)程序,例如Java程序需要安裝JDBC(Java數(shù)據(jù)庫(kù)連接)驅(qū)動(dòng)程序。

(3)通過(guò)編寫(xiě)程序,使用JDBC等驅(qū)動(dòng)程序連接數(shù)據(jù)庫(kù),獲取數(shù)據(jù)庫(kù)中的數(shù)據(jù)或者向數(shù)據(jù)庫(kù)中存儲(chǔ)數(shù)據(jù)。

(4)注意程序中的安全問(wèn)題,保證程序連接的數(shù)據(jù)庫(kù)用戶(hù)名、密碼等敏感信息不被泄露。

這種方式可以應(yīng)用于許多不同的編程語(yǔ)言,具有較好的靈活性和兼容性。但是,需要較長(zhǎng)時(shí)間進(jìn)行程序編寫(xiě)和調(diào)試,初學(xué)者較難掌握。

2.使用ORM框架簡(jiǎn)化數(shù)據(jù)庫(kù)連接

ORM(Object-Relational Mapping)框架是一種將面向?qū)ο蟮木幊棠J脚c關(guān)系型數(shù)據(jù)庫(kù)相結(jié)合的開(kāi)發(fā)模式,其中,對(duì)象表示程序中的實(shí)體,而關(guān)系數(shù)據(jù)庫(kù)是一個(gè)關(guān)系型結(jié)構(gòu),ORM框架將二者之間的映射關(guān)系進(jìn)行了統(tǒng)一處理。ORM框架可以大大簡(jiǎn)化程序員對(duì)數(shù)據(jù)庫(kù)的操作,使得程序操作數(shù)據(jù)庫(kù)的代碼更加精簡(jiǎn)和易于維護(hù)。

具體實(shí)現(xiàn)步驟如下:

(1)選擇適用的ORM框架,例如Hibernate、MyBatis等等。

(2)安裝相關(guān)的ORM框架和數(shù)據(jù)庫(kù)驅(qū)動(dòng)程序,例如使用MyBatis,則需要安裝MyBatis和JDBC驅(qū)動(dòng)程序。

(3)通過(guò)ORM框架進(jìn)行數(shù)據(jù)庫(kù)連接,并使用相關(guān)業(yè)務(wù)邏輯進(jìn)行數(shù)據(jù)查詢(xún)或操作。

(4)無(wú)需編寫(xiě)SQL語(yǔ)句,ORM框架會(huì)自動(dòng)進(jìn)行數(shù)據(jù)關(guān)系映射,并生成所需的SQL語(yǔ)句,大大簡(jiǎn)化程序代碼量。

這種方式的優(yōu)勢(shì)在于可以快速地構(gòu)建數(shù)據(jù)訪問(wèn)層,不需要編寫(xiě)復(fù)雜的SQL查詢(xún)語(yǔ)句,也不需要關(guān)心數(shù)據(jù)庫(kù)的配置和連接等問(wèn)題。同時(shí), ORM框架也是一個(gè)開(kāi)源的項(xiàng)目,代碼質(zhì)量比較穩(wěn)定,具有較強(qiáng)的可移植性,很容易和其他Web應(yīng)用程序進(jìn)行整合。不過(guò)ORM框架本身比較復(fù)雜,初學(xué)者需要進(jìn)行一定的學(xué)習(xí)和模擬,才能真正掌握其使用方法。

實(shí)現(xiàn)數(shù)據(jù)庫(kù)動(dòng)態(tài)連接可以大大提高程序員的工作效率和數(shù)據(jù)處理能力,也可以大大降低工作難度和錯(cuò)誤率。無(wú)論是基于編程語(yǔ)言的方式還是基于ORM框架的方式,都需要掌握一定的計(jì)算機(jī)編程知識(shí),同時(shí)需要注意數(shù)據(jù)庫(kù)的安全性和數(shù)據(jù)完整性。希望讀者能夠通過(guò)本文更深入的了解數(shù)據(jù)庫(kù)動(dòng)態(tài)連接的方式,掌握其基本技術(shù)方法,從而在數(shù)據(jù)管理和應(yīng)用開(kāi)發(fā)中能夠更加得心應(yīng)手。

相關(guān)問(wèn)題拓展閱讀:

  • delphi通過(guò)INI文件設(shè)置數(shù)據(jù)庫(kù)動(dòng)態(tài)連接,打不開(kāi)表格,手動(dòng)將ADOquery打開(kāi),提示無(wú)效的授權(quán)說(shuō)明
  • 動(dòng)態(tài)數(shù)據(jù)庫(kù)的什么是動(dòng)態(tài)鏈接庫(kù)?

delphi通過(guò)INI文件設(shè)置數(shù)據(jù)庫(kù)動(dòng)態(tài)連接,打不開(kāi)表格,手動(dòng)將ADOquery打開(kāi),提示無(wú)效的授權(quán)說(shuō)明

1、建議檢查從 INI 中讀取數(shù)據(jù)庫(kù)連接配置后,能否正確連信隱接到數(shù)據(jù)庫(kù)。

2、建議將 Query 組件的腔枝打開(kāi)操作伍坦敏放到窗體(或數(shù)據(jù)模塊)的初始化事件中,比如 OnFormCreate。

動(dòng)態(tài)數(shù)據(jù)庫(kù)的什么是動(dòng)態(tài)鏈接庫(kù)?

DLL三個(gè)字母對(duì)于你來(lái)說(shuō)一定很熟悉吧,它是Dynamic Link Library 的縮寫(xiě)形式,函數(shù)的可執(zhí)行代碼位于一個(gè) DLL 中,該 DLL 包含一個(gè)或多個(gè)已被編譯、鏈接并與使用它們的進(jìn)程分開(kāi)存儲(chǔ)的函數(shù)。DLL 還有助于共享數(shù)據(jù)和資源。多個(gè)仔瞎缺應(yīng)用程序可同時(shí)訪問(wèn)內(nèi)存中單個(gè) DLL 副本的內(nèi)容。

動(dòng)態(tài)鏈接庫(kù)是一個(gè)能夠被應(yīng)用程序和其它的DLL調(diào)用的過(guò)程和函數(shù)的體,它里面包含的是公共代碼或資源。由于DLL代碼使用了內(nèi)存共享技術(shù),在某些地方windows也給了DLL一些更高的權(quán)限,因而DLL中可以實(shí)現(xiàn)一些一般程序所不能實(shí)現(xiàn)的功能,如實(shí)現(xiàn)windows的HOOK、ISAPI等。

同時(shí),DLL還為不同語(yǔ)言間代碼共享提供了一條方便的途徑。因而DLL在編程時(shí)應(yīng)用較為廣泛,本文將介紹如何在 Delphi 中建立和使用DLL。

從使用效果看,DLL和unit 很像,它們都可以被別的工程模塊所調(diào)用,但二者在內(nèi)部的實(shí)現(xiàn)機(jī)制上確存在著差別。如果一個(gè)程序模塊中用uses語(yǔ)句引用了某個(gè)unit,編譯程序在編譯該模塊時(shí),便會(huì)連同unit一起編譯,并把編譯后的可執(zhí)行代碼鏈接到本程序模塊中,這就是一個(gè)程序模塊能夠調(diào)用所引用unit中過(guò)程和函數(shù)的原因。

當(dāng)同一個(gè)unit被多個(gè)工程所引用時(shí),則每個(gè)工程中都含有該unit的可執(zhí)行代碼,當(dāng)含有該unit的多個(gè)工程同時(shí)執(zhí)行時(shí),unit的可執(zhí)行代碼會(huì)隨不同工程而多次被調(diào)入內(nèi)存,造成內(nèi)存資源的浪費(fèi)。DLL則不同,它即使被某個(gè)工程調(diào)用,編譯后仍是獨(dú)立的。

也就是說(shuō)編譯后,一個(gè)DLL庫(kù)形成一個(gè)單獨(dú)的可執(zhí)行文件,而不與任何其它神此的可執(zhí)行文件連接在一起,因而DLL庫(kù)并不從屬于某個(gè)特定的工念辯程,當(dāng)多個(gè)工程調(diào)用同一個(gè)DLL庫(kù)時(shí)只有之一個(gè)工程把DLL庫(kù)調(diào)入內(nèi)存,其余工程并不重復(fù)調(diào)入同一個(gè)DLL庫(kù)到內(nèi)存,而是到同一個(gè)共享內(nèi)存區(qū)讀取。并且,DLL的執(zhí)行代碼是在程序運(yùn)行期間動(dòng)態(tài)調(diào)入的,而不是如unit在程序運(yùn)行時(shí)就與整個(gè)工程一起調(diào)入內(nèi)存。這樣便可消除unit帶來(lái)的相同代碼多處占用內(nèi)存的弊病。Delphi中DLL庫(kù)的建立

在Delphi環(huán)境中,編寫(xiě)一個(gè)DLL同編寫(xiě)一個(gè)一般的應(yīng)用程序并沒(méi)有太大的區(qū)別。事實(shí)上作為DLL主體的DLL函數(shù)的編寫(xiě),除了在內(nèi)存、資源的管理上有所不同外,并不需要其它特別的手段。

一般工程文件的格式為:

program 工程標(biāo)題;

uses 子句;

程序體

而DLLs工程文件的格式為:

library 工程標(biāo)題;

uses 子句;

exprots 子句; 1.一般工程文件的頭標(biāo)用program關(guān)鍵字,而DLL工程文件頭標(biāo)用library 關(guān)鍵字。不同的關(guān)鍵字通知編譯器生成不同的可執(zhí)行文件。用program關(guān)鍵字生成的是.exe文件,而用library關(guān)鍵字生成的是.dll文件;

2.假如DLL要輸出供其它應(yīng)用程序使用的函數(shù)或過(guò)程,則必須將這些函數(shù)或過(guò)程列在exports子句中。而這些函數(shù)或過(guò)程本身必須用export編譯指令進(jìn)行編譯。 在Delphi主菜單file 中選new…項(xiàng),在彈出的窗口中雙擊DLL圖標(biāo),便會(huì)自動(dòng)給出DLL源模塊框架,如下:

Library project1;

{…注釋…}

uses

SysUtils, Classes;

begin

end.

接下來(lái)便可在USES和begin之間加入想在該DLL中實(shí)現(xiàn)的過(guò)程和函數(shù)的定義,并用export和exprots保字把它們引出,以便別的模塊引用,在begin和end之間加入初始化代碼,初始化代碼是用來(lái)對(duì)DLL變量初始化的。應(yīng)注意,即便無(wú)初始化代碼begin與end也不可省略,如下例:

library minmax;

function Min(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.

經(jīng)編譯后,并以minmax.DLL存盤(pán)后,一個(gè)DLL庫(kù)文件便形成了。 訪問(wèn)DLL庫(kù)有兩種方式,一種是靜態(tài)引用,另一種是動(dòng)態(tài)引用。

用靜態(tài)引用這種方法裝入DLL要做兩件事情:為DLL 庫(kù)創(chuàng)建一個(gè)輸入單元,以及用USES把輸入單元連接到要使用DLL 函數(shù)的程序模塊中。為DLL庫(kù)創(chuàng)建的輸入單元與普通的單元的區(qū)別僅在于:在它的接口處聲明的過(guò)程、函數(shù),并不在它的實(shí)現(xiàn)部分給出真正的實(shí)現(xiàn)代碼,而是用external關(guān)鍵字把過(guò)程、函數(shù)的實(shí)現(xiàn)細(xì)節(jié)委托給外部DLL模塊。

external命令的使用語(yǔ)法如下:

procedure /function 過(guò)程/函數(shù)名;external DLL模塊名;

下面給出為上面創(chuàng)建的minmax.DLL庫(kù)寫(xiě)的輸入單元源文件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.

一個(gè)應(yīng)用程序若想調(diào)用minmax.DLL中的函數(shù),只須在其uses語(yǔ)句中加入testdll 單元即可。

動(dòng)態(tài)裝入DLL,要用到Windows的三個(gè)API函數(shù)。Loadlibrary、Freelibrary和GetprocAddress 。 loadlibrary函數(shù)用來(lái)裝入DLL庫(kù),其調(diào)用格式如下:

function loadlobrary (DLLfileName:Pchar): THandle:

當(dāng)不再需要一個(gè)DLL庫(kù)時(shí),應(yīng)調(diào)用FreeLibrary函數(shù)將其釋放,以空出寶貴的內(nèi)存資源,其調(diào)用格式如下:

procedure FreeLibrary (Libmodule:THandle)

Libmodule 為由LoadLibrary調(diào)用得到的DLL庫(kù)句柄。在用loadlobrary 函數(shù)裝入某個(gè)DLL庫(kù)和調(diào)用FreeLibrary釋放該DLL庫(kù)之間的程序段中, 可以使用該DLL庫(kù)中的過(guò)程和函數(shù),具體使用方法是:用GetprocAddress函數(shù)把DLL庫(kù)中函數(shù)的地址傳遞給程序中某個(gè)函數(shù)變量,再用該變量實(shí)現(xiàn)DLL函數(shù)的調(diào)用。GetprocAddress函數(shù)聲名如下

function GetprocAddress (Libmodule:THandle:procname:pchar):TFarProc:

如下例所示:

type

TTimeRec = record

Second: Integer;

Minute: Integer;

Hour: Integer;

end;

TGetTime = procedure(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;

在調(diào)用動(dòng)態(tài)鏈接庫(kù)時(shí)應(yīng)注意, 所需動(dòng)態(tài)鏈接庫(kù)須與應(yīng)用程序在同一目錄或Windows System 目錄下。

動(dòng)態(tài)鏈接庫(kù)是 Windows下程序組織的一種重要方式,使用動(dòng)態(tài)鏈接庫(kù)可以極大地保護(hù)用戶(hù)在不同開(kāi)發(fā)工具、不同時(shí)期所做的工作,提高編程效率。

動(dòng)態(tài)鏈接庫(kù)(Dynamic Link Library 或者 Dynamic-link Library,縮寫(xiě)為 DLL),是微軟公司在微軟Windows操作系統(tǒng)中,實(shí)現(xiàn)共享函數(shù)庫(kù)概念脊返彎的一種方式。這些庫(kù)函數(shù)的擴(kuò)展名是 ”.dll”、”.ocx”(包含ActiveX控制的庫(kù))或者 “.drv”(舊式的系統(tǒng)驅(qū)動(dòng)程序)。

動(dòng)態(tài)鏈接提供了一種方法,使進(jìn)程可以調(diào)用不屬于其可執(zhí)行代碼的函數(shù)。函數(shù)的可執(zhí)行代碼位于一個(gè) DLL 文件中,該 DLL 包含一個(gè)或多個(gè)已被編譯、鏈接并與使用它們的進(jìn)程分開(kāi)存儲(chǔ)的函數(shù)。DLL 還有助于共享數(shù)據(jù)和資源。多個(gè)應(yīng)用程序可同時(shí)訪問(wèn)內(nèi)存中單櫻悶個(gè) DLL 副本的內(nèi)容。

使用動(dòng)態(tài)鏈接庫(kù)可以更為容易地將更新應(yīng)用于各個(gè)模塊,而不會(huì)影響該程序的其他部分。例如,世嘩您有一個(gè)大型網(wǎng)絡(luò)游戲,如果把整個(gè)數(shù)百M(fèi)B甚至數(shù)GB的游戲的代碼都放在一個(gè)應(yīng)用程序里,日后的修改工作將會(huì)十分費(fèi)時(shí),而如果把不同功能的代碼分別放在數(shù)個(gè)動(dòng)態(tài)鏈接庫(kù)中,您無(wú)需重新生成或安裝整個(gè)程序就可以應(yīng)用更新。

動(dòng)態(tài)鏈接庫(kù)(Dynamic Link Library,縮寫(xiě)為 DLL),是微軟公司在微軟世嘩Windows操作系統(tǒng)中,實(shí)現(xiàn)共享函數(shù)庫(kù)概念的一種方式。這些庫(kù)函數(shù)的擴(kuò)展名是 ”.dll”、”.ocx”(包含ActiveX控制的庫(kù))或者 “.drv”(舊式的系統(tǒng)驅(qū)動(dòng)程序)。它并不是可執(zhí)行的文件,而是能向多個(gè)程序提供公用代碼函數(shù)和數(shù)據(jù)的封裝庫(kù),程序所需要的一些函數(shù)和數(shù)據(jù)被事先封裝在DLL文件中,當(dāng)程序運(yùn)行時(shí)可以主程序需要調(diào)用這些DLL動(dòng)態(tài)鏈接庫(kù),使進(jìn)程可以調(diào)用不屬于其可執(zhí)行代碼的函數(shù)。函數(shù)的可執(zhí)行代碼位于一個(gè) DLL 文件中,該 DLL 包含一個(gè)或多個(gè)已被編譯、鏈接并與使用它們的進(jìn)程分開(kāi)存儲(chǔ)的函數(shù),同時(shí)有助于共享數(shù)據(jù)和資源,多個(gè)應(yīng)用程序可同時(shí)訪問(wèn)內(nèi)存中單個(gè) DLL 副本的內(nèi)容,使用動(dòng)態(tài)鏈接庫(kù)可以更為容易地將更新應(yīng)用于各個(gè)模塊,而不會(huì)影響該程序的其他部分。例如,您有一個(gè)大型網(wǎng)絡(luò)游戲,如果把整個(gè)數(shù)百M(fèi)B甚至數(shù)GB的游戲的代碼都放在一個(gè)應(yīng)用程序里,日后的修改工作將會(huì)十分費(fèi)時(shí),而如果把不同功能的代碼分別放在數(shù)個(gè)動(dòng)態(tài)鏈接庫(kù)中,您無(wú)需重脊返彎新櫻悶生成或安裝整個(gè)程序就可以應(yīng)用更新。

關(guān)于對(duì)數(shù)據(jù)庫(kù)的動(dòng)態(tài)連接的介紹到此就結(jié)束了,不知道你從中找到你需要的信息了嗎 ?如果你還想了解更多這方面的信息,記得收藏關(guān)注本站。

香港服務(wù)器選創(chuàng)新互聯(lián),2H2G首月10元開(kāi)通。
創(chuàng)新互聯(lián)(www.cdcxhl.com)互聯(lián)網(wǎng)服務(wù)提供商,擁有超過(guò)10年的服務(wù)器租用、服務(wù)器托管、云服務(wù)器、虛擬主機(jī)、網(wǎng)站系統(tǒng)開(kāi)發(fā)經(jīng)驗(yàn)。專(zhuān)業(yè)提供云主機(jī)、虛擬主機(jī)、域名注冊(cè)、VPS主機(jī)、云服務(wù)器、香港云服務(wù)器、免備案服務(wù)器等。


網(wǎng)頁(yè)名稱(chēng):實(shí)現(xiàn)數(shù)據(jù)庫(kù)動(dòng)態(tài)連接——簡(jiǎn)便高效的數(shù)據(jù)操作方式(對(duì)數(shù)據(jù)庫(kù)的動(dòng)態(tài)連接)
網(wǎng)站鏈接:http://m.5511xx.com/article/dhphjch.html