日本国产亚洲-日本国产一区-日本国产一区二区三区-日本韩国欧美一区-日本韩国欧美在线-日本韩国欧美在线观看

當前位置:雨林木風下載站 > 技術開發教程 > 詳細頁面

用VisualFoxpro開發主從結構數據庫系統

用VisualFoxpro開發主從結構數據庫系統

更新時間:2022-05-09 文章作者:未知 信息來源:網絡 閱讀次數:

孫向海 方旭升

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

  一. 建立數據庫、建立ODBC 數據源

  主從結構最大的優點就是將工作合理分配于服務器與工作站以便讓它們同時發揮所長,主從結構包括三個重要的部分-網絡操作系統、數據庫服務器及前端應用程序。我們可以采用Visual FoxPro+SQL Server 7.0 + Windows NT Server 的組合方式。我們首先需在SQL Server 上建立所需的數據庫如:Ningguo ,并創建所需要的表,如maintable等。在SQL Server 上的數據庫建完之后,我們可以為剛才創建的數據庫創建一個用戶如:newguest,這樣我們就可以進行下一步操作。

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

  二.建立和數據庫相連的連接

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

  OPEN DATABASE test

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

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

  三.建立遠程視圖

  在連接成功的情況下,我們就可以建立遠程視圖。我們既可以在數據庫設計器中用視圖向導建立視圖,也可以用命令來建立視圖。下面以向導為例來進行說明,在向導中我們可以使用數據源或者連接來創建視圖,一般而言,讓遠程視圖透過已定義的連接來連接到所需的數據來源較好,因為連接本身就包含較完整的連接定義信息,而用數據源則每次使用遠程視圖時便會出現 SQL Server Login 對話框,顯然這是用戶所不希望看到的。接著選擇視圖所對應的SQL Server 中的來源表即可。

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

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

  四.SQL Pass-Through (SPT) 技術的運用

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

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

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

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

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

  舉一個典型的運用SQL Pass-Through的例子:

  SET TALK OFF

  CLEAR ALL

  CLOSE ALL

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

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

  IF nConnectHandle<0

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

  ELSE

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

  SQLEXEC(nConnectHandle,"Select * from maintable")

  Browse

  Use in sqlresult

  ………..&&其他操作

  SQLDISCONNECT(nConnectHandle) &&切斷連接

  ENDIF

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

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

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

  (3) 數據來源信息 SQLCOLUMNS() SQLTABLES()

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

  在用SQL Pass-Through時,程序設計師能夠擁有較高的主導權與控制權,因此若能夠將遠程視圖和SQL Pass-Through 技術緊密的結合起來,互補有無,我們的主從系統就可以無所不能了。

  五.結束語

  可以說,Visual Foxpro 是一個相當不錯的開發基于C/S結構的數據庫應用系統的前端軟件,在Internet 廣為流傳的今天,最新一代的系統結構早就已發展至N-tier 結構,亦即我們所說的多階層結構。N-tier 結構其實是從主從結構為基礎所衍生而來的,我們甚至可以說主從結構就是2-tier 結構。因此,只有徹底學會主從結構,并了解Visual Foxpro 在主從結構中所扮演的角色,才能在將來的競爭中立于不敗之地。

  參考文獻:

  (1)Visual Foxpro6.x 中文版程序設計 -應用實務篇 章立民 中國鐵道出版社 1999.10

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

溫馨提示:喜歡本站的話,請收藏一下本站!

本類教程下載

系統下載排行

主站蜘蛛池模板: 久久精品国产99久久香蕉 | 国产成人精品午夜二三区 | 揄拍自拍 | 日本精品99| 亚洲v天堂v手机在线观看 | 女人18毛片免费视频播放 | 天堂网一区二区 | 四虎影院永久免费 | 日日碰日日操 | 国产精品变态重口在线 | 老司机免费福利午夜入口ae58 | 久久99国产精一区二区三区! | 亚洲一区欧美一区 | 亚洲国产成人私人影院 | 国产福利精品一区二区 | 亚洲日韩成人 | 思久久| 天天拍夜夜添久久精品免费 | 999久久久精品视频在线观看 | 亚洲日本视频在线观看 | 国产人成精品午夜在线观看 | 91精品推荐 | 校花超短裙暴露调教在线观看 | 18视频在线观看网站 | 天天操天天干天天射 | 草草浮力影院 | 欧美日韩视频一区二区在线观看 | 日本三级在线播放线观看2021 | 午夜成年视频 | 日本黄色a视频 | 亚洲啪啪| 伊人色在线观看 | jizzzz日本 | 国产一区亚洲二区 | s级毛片| 天天干视频在线观看 | 午夜影院福利 | 波多野吉衣一区二区三区四区 | 日本不卡免免费观看 | 综合久久国产对白 | 91撸吧|