• <label id="pxtpz"><meter id="pxtpz"></meter></label>
      1. <span id="pxtpz"><optgroup id="pxtpz"></optgroup></span>

        當(dāng)前位置:雨林木風(fēng)下載站 > 技術(shù)開發(fā)教程 > 詳細(xì)頁面

        用VisualFoxpro開發(fā)主從結(jié)構(gòu)數(shù)據(jù)庫系統(tǒng)

        用VisualFoxpro開發(fā)主從結(jié)構(gòu)數(shù)據(jù)庫系統(tǒng)

        更新時(shí)間:2022-05-09 文章作者:未知 信息來源:網(wǎng)絡(luò) 閱讀次數(shù):

        孫向海 方旭升

          目前流行的數(shù)據(jù)庫開發(fā)平臺(tái)很多,如DELPHI、VB、PB等,有關(guān)用它們?nèi)绾伍_發(fā)基于C/S 模式的應(yīng)用系統(tǒng)的書籍、文章也較多,但是卻很少見到關(guān)于用Visual Foxpro (VFP)開發(fā)C/S 結(jié)構(gòu)的文章,即使有也只是泛泛而談,講的不具體,讀者看了之后,仍然不知道如何去開發(fā)。還有好多人對(duì)VFP的認(rèn)識(shí)還是停留在FOXBASE和FOXPRO的基礎(chǔ)上,經(jīng)常有人問,"用VFP能開發(fā)C/S結(jié)構(gòu)的系統(tǒng)嗎?",于是我一次又一次的充當(dāng)了VFP的解說員。其實(shí)用VFP開發(fā)基于C/S 模式的系統(tǒng)是可以的,而且原來所熟悉的各種技術(shù)在開發(fā)主從結(jié)構(gòu)時(shí)仍然完全適用,而我國(guó)有許多MIS系統(tǒng)開發(fā)人員都比較熟悉FOX系列的軟件,因此在此基礎(chǔ)上掌握VFP開發(fā)C/S結(jié)構(gòu)的MIS系統(tǒng),對(duì)于這些人來講加快了開發(fā)進(jìn)程,延續(xù)了知識(shí)的生命周期。因此我想把自己用VFP開發(fā)C/S 系統(tǒng)中的方法和經(jīng)驗(yàn)寫出來,好讓那些對(duì)VFP不太了解或者沒有用它開發(fā)過C/S 結(jié)構(gòu)的讀者對(duì)VFP有重新的認(rèn)識(shí)。

          一. 建立數(shù)據(jù)庫、建立ODBC 數(shù)據(jù)源

          主從結(jié)構(gòu)最大的優(yōu)點(diǎn)就是將工作合理分配于服務(wù)器與工作站以便讓它們同時(shí)發(fā)揮所長(zhǎng),主從結(jié)構(gòu)包括三個(gè)重要的部分-網(wǎng)絡(luò)操作系統(tǒng)、數(shù)據(jù)庫服務(wù)器及前端應(yīng)用程序。我們可以采用Visual FoxPro+SQL Server 7.0 + Windows NT Server 的組合方式。我們首先需在SQL Server 上建立所需的數(shù)據(jù)庫如:Ningguo ,并創(chuàng)建所需要的表,如maintable等。在SQL Server 上的數(shù)據(jù)庫建完之后,我們可以為剛才創(chuàng)建的數(shù)據(jù)庫創(chuàng)建一個(gè)用戶如:newguest,這樣我們就可以進(jìn)行下一步操作。

          在前臺(tái)的工作站上,操作系統(tǒng)采用Window 98/95 即可,在工作站建立連接到SQL Server的ODBC 數(shù)據(jù)來源(Data Source)。 我們新建了一個(gè)數(shù)據(jù)源first,連接到 SQL Server 上的Ningguo 數(shù)據(jù)庫。

          二.建立和數(shù)據(jù)庫相連的連接

          下面我們就進(jìn)入與Visual Foxpro 相關(guān)的部分。在以 Visual Foxpro 所開發(fā)的主從結(jié)構(gòu)中,遠(yuǎn)程視圖(Remote View)扮演著關(guān)鍵性的角色。遠(yuǎn)程視圖使得程序設(shè)計(jì)師能夠?qū)F(xiàn)有的技術(shù)直接應(yīng)用于主從結(jié)構(gòu)系統(tǒng)的開發(fā)上,而無須增加太多的負(fù)擔(dān)。當(dāng)我們想要在 Visual Foxpro 中存取其他數(shù)據(jù)庫系統(tǒng)的數(shù)據(jù)紀(jì)錄時(shí),便必須借助于遠(yuǎn)程視圖。在建立一個(gè)遠(yuǎn)程視圖之前,必須在數(shù)據(jù)庫中建立一個(gè)連接(Connection),它記錄了登入SQL Server 的相關(guān)信息并定義連接通道的一些設(shè)定信息。在數(shù)據(jù)庫設(shè)計(jì)器中新建一個(gè)連接,  分別在數(shù)據(jù)源、用戶標(biāo)識(shí)、密碼、數(shù)據(jù)庫所對(duì)應(yīng)的輸入框中輸入如前文所述的名稱,然后驗(yàn)證連接即可,當(dāng)然也可以用連接串連接,如:dsn=first;uid=newguest;pwd=123;database=ningguo,或許在某些情況下,我們?cè)趹?yīng)用系統(tǒng)執(zhí)行期間以程序控制方式更改連接的相關(guān)設(shè)定,我們就可以用DBSETPROP()函數(shù),比如我們要更改名為connect1 的連接串,可用如下的命令敘述:

          OPEN DATABASE test

          dbsetprop("connect1","connection","connectstring",;

          "dsn=first;uid=newguest;pwd=123;database=ningguo")

          三.建立遠(yuǎn)程視圖

          在連接成功的情況下,我們就可以建立遠(yuǎn)程視圖。我們既可以在數(shù)據(jù)庫設(shè)計(jì)器中用視圖向?qū)Ы⒁晥D,也可以用命令來建立視圖。下面以向?qū)槔齺磉M(jìn)行說明,在向?qū)е形覀兛梢允褂脭?shù)據(jù)源或者連接來創(chuàng)建視圖,一般而言,讓遠(yuǎn)程視圖透過已定義的連接來連接到所需的數(shù)據(jù)來源較好,因?yàn)檫B接本身就包含較完整的連接定義信息,而用數(shù)據(jù)源則每次使用遠(yuǎn)程視圖時(shí)便會(huì)出現(xiàn) SQL Server Login 對(duì)話框,顯然這是用戶所不希望看到的。接著選擇視圖所對(duì)應(yīng)的SQL Server 中的來源表即可。

          我們就視圖所需要的字段、聯(lián)接條件、篩選條件、排序、分組、更新條件應(yīng)分別進(jìn)行設(shè)置,以滿足我們的需要,要提到的是前后端的數(shù)據(jù)類型對(duì)應(yīng)的問題,Visual Foxpro 中的數(shù)據(jù)類型與 SQL Server 中的數(shù)據(jù)類型不盡相同,不過前后端的數(shù)據(jù)類型有一固定的關(guān)系。比如,某一個(gè)字段在SQL Server 上的數(shù)據(jù)類型是 money ,而在遠(yuǎn)程視圖中此字段的數(shù)據(jù)類型將是貨幣值類型,又例如,某一個(gè)字段在SQL Server 上的數(shù)據(jù)類型是 text ,而在遠(yuǎn)程視圖之中此字段的數(shù)據(jù)類型將是備注型,我們往往需要手動(dòng)去調(diào)節(jié)對(duì)應(yīng)的字段類型,例如,所有的 SQL Server 上的datetime 類型到了遠(yuǎn)程視圖中都要變成 date 型。我們可以在相應(yīng)的頁面來確定聯(lián)接關(guān)系、指定過濾條件、指定排序依據(jù),特別要注意的是在"更新頁面"欄,如果我們想要建立一個(gè)可更新的視圖,必須選中"發(fā)送SQL更新"欄,這樣針對(duì)視圖所作的任何變動(dòng),會(huì)主動(dòng)反映到后端的SQL Server 中去,你就可以直接使用所熟悉的Visual Foxpro 來更新后端數(shù)據(jù)。另外,我們指定鍵值欄、可更新字段、更新沖突的檢查方式以及后端的 SQL Server 如何執(zhí)行更新操作,視圖的建立就完成了。

          遠(yuǎn)程視圖一旦建立完成,我們就可以利用它來顯示與更新數(shù)據(jù)。由于遠(yuǎn)程視圖在外觀與使用上皆與表大同小異,因此即使其來源數(shù)據(jù)實(shí)際上是位于SQL Server 中,我們無須有任何顧慮,過去替 Visual Foxpro 本身的數(shù)據(jù)建立平行輸出/入界面、報(bào)表及標(biāo)簽的方法完全適用于遠(yuǎn)程視圖。我們可以在表單設(shè)計(jì)工具、報(bào)表設(shè)計(jì)工具與標(biāo)簽設(shè)計(jì)工具中,將遠(yuǎn)程視圖加至表單、報(bào)表或標(biāo)簽的數(shù)據(jù)環(huán)境組件中,并快速建立出數(shù)據(jù)源為遠(yuǎn)程視圖或其某字段的控制項(xiàng)。但是在實(shí)際應(yīng)用中,我們往往會(huì)遇到這樣的情況,如符合條件的數(shù)據(jù)紀(jì)錄很多,或者經(jīng)常要使用離線方式的系統(tǒng),我們除了簡(jiǎn)單的使用遠(yuǎn)程視圖之外,還必須靈活的運(yùn)用"有條件的遠(yuǎn)程視圖"和離線式視圖(Off-line View),盡量減少服務(wù)器端的數(shù)據(jù)下載量,減輕網(wǎng)絡(luò)的負(fù)荷,一些不常更新的數(shù)據(jù)甚至可以以DBF的形式直接放置在客戶端,提高整個(gè)系統(tǒng)的運(yùn)行效率。

          四.SQL Pass-Through (SPT) 技術(shù)的運(yùn)用

          要使一個(gè)主從結(jié)構(gòu)系統(tǒng)趨于完善,除了用遠(yuǎn)程視圖來構(gòu)筑主從結(jié)構(gòu)的主體,還必須輔以SQL Pass-Through 技術(shù)。所謂 SQL Pass-Through ,意指我們可以將任何符合 SQL Server 語法的命令敘述從前端透過連接通道送至后端的 SQL Server 來執(zhí)行,與SQL Server 進(jìn)行其他直接有效的溝通。利用 SQL Pass-Through 我們還可以直接去執(zhí)行儲(chǔ)存在SQL Server 上的儲(chǔ)存式程序(Stored Procedure),和系統(tǒng)儲(chǔ)存式程序(System Stored Procedure),比方說,我們可以從前端去執(zhí)行SQL Server的系統(tǒng)儲(chǔ)存式程序sp_addlogin ,來要求加入一個(gè)使用者帳號(hào)。一般而言,SPT函數(shù)的使用流程如下所示:

          (1) 首先使用SQLCONNECT()或SQLSTRINGCONNECT() 函數(shù)來連接值所需的數(shù)據(jù)源。

          (2) 成功的連接到SQL Server 之后,即可以透過連接通道進(jìn)行所需的各項(xiàng)處理。比如,我

          們可以使用SQLEXEC()函數(shù)將SQL命令送至SQL Server執(zhí)行。

          (3) 完成所有的操作后,應(yīng)用SQLDISCONNECT()函數(shù)切斷與數(shù)據(jù)源的連接。下面我們就

          舉一個(gè)典型的運(yùn)用SQL Pass-Through的例子:

          SET TALK OFF

          CLEAR ALL

          CLOSE ALL

          SQLSETPROP(0,"DispLogin",3) &&登錄失敗時(shí)不顯示ODBC登錄對(duì)話框

          nConnectHandle=SQLSTRINGCONNECT("dsn=first;uid=newguest;pwd=123;database=ningguo")

          IF nConnectHandle<0

          MessageBox("無法與數(shù)據(jù)庫連接",0+48,"異常情況")

          ELSE

          MessageBox("連接成功",0+48,"提示信息")

          SQLEXEC(nConnectHandle,"Select * from maintable")

          Browse

          Use in sqlresult

          ………..&&其他操作

          SQLDISCONNECT(nConnectHandle) &&切斷連接

          ENDIF

          通過這樣簡(jiǎn)單有效的代碼,我們就能對(duì)數(shù)據(jù)庫進(jìn)行有效的操作,以確保數(shù)據(jù)的完整性和安全性。在此列出所有的SQL Pass-Through 函數(shù)供大家參考:

          (1) 連接建立與切斷 SQLCONNECT() SQLSTRINGCONNECT() SQLDISCONNECT()

          (2) SQL命令敘述的執(zhí)行與控制 SQLCANCEL() SQLEXEC() SQLMORERESULTS() SQLPREPARE() SQLCOMMIT() SQLROLLBACK()

          (3) 數(shù)據(jù)來源信息 SQLCOLUMNS() SQLTABLES()

          (4) 存取連接通道的屬性 SQLGETPROP() SQLSETPROP()

          在用SQL Pass-Through時(shí),程序設(shè)計(jì)師能夠擁有較高的主導(dǎo)權(quán)與控制權(quán),因此若能夠?qū)⑦h(yuǎn)程視圖和SQL Pass-Through 技術(shù)緊密的結(jié)合起來,互補(bǔ)有無,我們的主從系統(tǒng)就可以無所不能了。

          五.結(jié)束語

          可以說,Visual Foxpro 是一個(gè)相當(dāng)不錯(cuò)的開發(fā)基于C/S結(jié)構(gòu)的數(shù)據(jù)庫應(yīng)用系統(tǒng)的前端軟件,在Internet 廣為流傳的今天,最新一代的系統(tǒng)結(jié)構(gòu)早就已發(fā)展至N-tier 結(jié)構(gòu),亦即我們所說的多階層結(jié)構(gòu)。N-tier 結(jié)構(gòu)其實(shí)是從主從結(jié)構(gòu)為基礎(chǔ)所衍生而來的,我們甚至可以說主從結(jié)構(gòu)就是2-tier 結(jié)構(gòu)。因此,只有徹底學(xué)會(huì)主從結(jié)構(gòu),并了解Visual Foxpro 在主從結(jié)構(gòu)中所扮演的角色,才能在將來的競(jìng)爭(zhēng)中立于不敗之地。

          參考文獻(xiàn):

          (1)Visual Foxpro6.x 中文版程序設(shè)計(jì) -應(yīng)用實(shí)務(wù)篇 章立民 中國(guó)鐵道出版社 1999.10

          (2)中文Visual Foxpro6.0 高級(jí)編程 合力工作室 清華大學(xué)出版社 1999.7

        溫馨提示:喜歡本站的話,請(qǐng)收藏一下本站!

        本類教程下載

        系統(tǒng)下載排行

        主站蜘蛛池模板: 日韩毛片免费无码无毒视频观看| 国产成人va亚洲电影| 男女作爱在线播放免费网站| 亚洲色偷偷狠狠综合网| 日韩视频免费一区二区三区| 青青草原精品国产亚洲av| 亚欧日韩毛片在线看免费网站| 日韩中文无码有码免费视频| 久久亚洲最大成人网4438| 免费下载成人电影| 亚洲精品美女网站| a级毛片无码免费真人久久| 国产亚洲精品a在线观看| 久久久WWW免费人成精品| 最近中文字幕免费mv视频7| 亚洲人成网站看在线播放| 久久不见久久见中文字幕免费| 亚洲精品乱码久久久久久蜜桃图片 | 亚洲国产日韩一区高清在线| 久爱免费观看在线网站| 亚洲大尺码专区影院| 在线播放免费人成视频在线观看| 伊人久久大香线蕉亚洲五月天 | 亚洲国产精品无码久久久秋霞1| 精品免费国产一区二区| 一级毛片免费毛片毛片| 亚洲AV无码一区二区乱孑伦AS | 色天使亚洲综合一区二区| 国产精品V亚洲精品V日韩精品| 99精品免费视品| 亚洲国产夜色在线观看| 天堂在线免费观看中文版| 免费精品国自产拍在线播放| 国产亚洲精品a在线观看app| 亚洲高清中文字幕免费| 一级毛片**免费看试看20分钟| 亚洲国产精品婷婷久久| 日韩伦理片电影在线免费观看| 狠狠躁狠狠爱免费视频无码| 亚洲国产综合精品| 亚洲一区视频在线播放|