日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

VFP中用SPT訪問SQL Server數(shù)據(jù)庫

瀏覽:26日期:2023-11-02 10:40:56
;;VFP因它簡(jiǎn)單易學(xué),可快速建立應(yīng)用軟件而深受廣大程序員喜愛,但其數(shù)據(jù)庫系統(tǒng)不安全也令廣大用戶非常頭痛。隨著MS SQL Server數(shù)據(jù)庫系統(tǒng)的推廣應(yīng)用,其強(qiáng)大的安全性能普遍受到好評(píng)。筆者在長(zhǎng)期的編程實(shí)踐中,發(fā)現(xiàn)利用VFP的SQL pass-through(SPT)技術(shù)結(jié)合MS SQL Server數(shù)據(jù)庫系統(tǒng),也能像VB、Delphi、PowerBuilder一樣輕松開發(fā)出優(yōu)秀的客戶/服務(wù)器(C/S)應(yīng)用軟件?,F(xiàn)通過編寫一個(gè)簡(jiǎn)單的通信錄例子和廣大VFP愛好者共同探討。 一、服務(wù)器端MS SQL Server數(shù)據(jù)庫設(shè)計(jì) 1. 在MS SQL Server中建立名為“SFXT”的數(shù)據(jù)庫。 2. 在SFXT數(shù)據(jù)庫中建立名為“通信錄”的數(shù)據(jù)表,表結(jié)構(gòu)如下: 列名(字段名) 數(shù)據(jù)類型 長(zhǎng)度 姓名 chr 8 生日 datetime 8 電話 chr 11 email chr 30 并將姓名設(shè)置為主鍵。 3. 在“SFXT”數(shù)據(jù)庫中建立查詢出所有記錄的存儲(chǔ)過程。 SP_SearchAll CREATE PROCEDURE [SP_SearchAll] AS select * from 通信錄 order by 姓名 return 4. 在“SFXT”數(shù)據(jù)庫中建立插入新記錄的存儲(chǔ)過程 SP_InsertData。 CREATE PROCEDURE [SP_InsertData] @name [char] (10), @birthday [datetime] , @telephone [char] (11), @email [char] (30) AS insert into 通信錄(姓名,生日,電話,email) values (@name,@birthday,@telephone,@email) return 二、客戶端VFP的SQL pass-through技術(shù)設(shè)計(jì) 1. 建立如(^15020603b^)的VFP表單界面。 2. 建立名為“SFXT”的ODBC數(shù)據(jù)源連接MS SQL Server中的SFXT數(shù)據(jù)庫。 可通過執(zhí)行上面VFP表單的按鈕“建立OBDC數(shù)據(jù)源”來完成;或者通過運(yùn)行Windows控制面板中的“OBDC數(shù)據(jù)源”來完成。主要設(shè)置包括選擇SQL Server驅(qū)動(dòng)程序,通信協(xié)議,登錄標(biāo)識(shí)與密碼等。 “建立OBDC數(shù)據(jù)源”按鈕.CLICK事件: *函數(shù)說明SQLSTRINGCONNECT([cConnectString]) *省略連接字符串cConnectString時(shí)顯示''SQL數(shù)據(jù)源''對(duì)話框,可選擇或新建數(shù)據(jù)源 sqlstringconnect() 3. 兩種連接MS SQL Server數(shù)據(jù)源的方式。 使用現(xiàn)有數(shù)據(jù)源名稱建立連接,“建立連接方式1”按鈕.CLICK事件。 public vodbc,vuser,vpwd,vconn vodbc='sfxt' &&連接SQL SERVER數(shù)據(jù)庫ODBC數(shù)據(jù)源名稱 vuser='sa' &&訪問SQL SERVER數(shù)據(jù)庫的登錄用戶名,sa為系統(tǒng)用戶 vpwd='5213' &&用戶登錄密碼,為sa系統(tǒng)用戶設(shè)置的密碼 vconn=SQLCONNECT(vodbc, vuser,vpwd) if vconn>0 messagebox('連接成功!',,'ODBC數(shù)據(jù)源') else messagebox('連接失敗!',,'ODBC數(shù)據(jù)源') endif 使用連接字符串建立數(shù)據(jù)源連接,“建立連接方式2”按鈕.CLICK事件。 public vconn vconn=SQLSTRINGCONNECT('dsn=sfxt:uid=sa:pwd=5213') if vconn>0 messagebox('連接成功!',,'ODBC數(shù)據(jù)源') else messagebox('連接失??!',,'ODBC數(shù)據(jù)源') endif 4. 數(shù)據(jù)源連接的主要參數(shù)設(shè)置,“活動(dòng)連接屬性設(shè)置”按鈕.CLICK事件。 * 注:用函數(shù)sqlgetprop()可返回設(shè)置的參數(shù)值 sqlsetprop(vconn,''asynchronous'',.f.) &&取假值時(shí)為結(jié)果集同步返回: 取真值時(shí)為異步返回 sqlsetprop(vconn,''ConnectTimeOut'',15) &&連接超時(shí)等待秒數(shù)設(shè)置,可取值0至600 sqlsetprop(vconn,''IdleTimeout'',0)&&空閑超時(shí)間隔秒數(shù),取值0為無限期超時(shí)等待 sqlsetprop(vconn,''Transactions'',1) &&取值1時(shí)為自動(dòng)處理遠(yuǎn)程事務(wù):取值2時(shí)為手工處理 5. “執(zhí)行存儲(chǔ)過程查詢數(shù)據(jù)”按鈕.CLICK事件。 *函數(shù)說明SQLEXEC(nConnectionHandle, [cSQLCommand, [CursorName]]) *nConnectionHandle 當(dāng)前數(shù)據(jù)源活動(dòng)連接句柄 *cSQLCommand執(zhí)行SQL SERVER存儲(chǔ)過程的SQL語句表達(dá)式 *CursorName返回執(zhí)行結(jié)果臨時(shí)表的名稱 sqlexec(vconn,''execute SP_SearchAll'',''我的通信錄'') browse 6. “執(zhí)行SQL語句查詢數(shù)據(jù)” 按鈕.CLICK事件。 *函數(shù)說明SQLEXEC(nConnectionHandle, [cSQLCommand, [CursorName]]) *nConnectionHandle 當(dāng)前數(shù)據(jù)源活動(dòng)連接句柄 *cSQLCommand需發(fā)送SQL語句表達(dá)式 *CursorName返回執(zhí)行結(jié)果臨時(shí)表的名稱 SQLEXEC(vconn, 'SELECT * FROM 通信錄', '我的通信錄') browse 7. “向存儲(chǔ)過程傳替參數(shù)插入新記錄” 按鈕.CLICK事件。 local vname,vbirthday,vtelephone,vemail,vsql *隨機(jī)產(chǎn)生新記錄舉例 vname = '姓名'+sys(3) &&姓名 vbirthday = dtoc(date()-int(rand()*10000)) &&生日 vtelephone = sys(3) &&電話 vemail = sys(3)+'@hotmail.com' &&電子郵箱 *將傳遞到存儲(chǔ)過程的參數(shù)轉(zhuǎn)換成字符串,并加引號(hào)形成SQL語句。 vsql=''execute SP_InsertData ''+'''''+vname+''','''+vbirthday+''','''+vtelephone+''','''+vemail+''''' if sqlexec(vconn,vsql)>0 &&發(fā)送SQL語句 messagebox('插入新記錄成功!',,'信息') else messagebox('插入新記錄不成功!',,'信息') endi sqlexec(vconn,''execute SP_SearchAll'',''我的通信錄'') browse 8. “設(shè)置當(dāng)前表的屬性修改數(shù)據(jù)” 按鈕.CLICK事件。 * 注:用函數(shù)cursorgetprop()可返回設(shè)置的參數(shù)值 cursorsetprop('BatchUpdateCount',100) &&發(fā)送到緩沖表的遠(yuǎn)程數(shù)據(jù)源的更新指令的數(shù)目 cursorsetprop('Buffering',3) &&設(shè)置當(dāng)前表為開放式行緩沖 cursorsetprop('FetchSize',-1)&&從遠(yuǎn)程表中提取全部查詢記錄 cursorsetprop('KeyFieldList','姓名')&&指定遠(yuǎn)程表的主關(guān)鍵字段 cursorsetprop('SendUpdates',.t.) &&當(dāng)前緩沖表更改內(nèi)容時(shí)發(fā)送SQL語句更新遠(yuǎn)程表 cursorsetprop('Tables','通信錄') &&指定連接的遠(yuǎn)程表名 *本地緩沖表與遠(yuǎn)程表字段對(duì)應(yīng)關(guān)系 cursorsetprop('UpdateNameList','姓名 通信錄.姓名,生日 通信錄.生日,電話 通信錄.電話,email 通信錄.email') *指定可更新字段列表 cursorsetprop('UpdatableFieldList','姓名,生日,電話,email') cursorsetprop('UpdateType',1) &&遠(yuǎn)程表更新方式,替換方式 cursorsetprop('WhereType',3)&&更新SQL語句中where子句包含主關(guān)鍵字與被修改過的字段 browse&&修改緩沖表數(shù)據(jù),移動(dòng)記錄指針后,自動(dòng)發(fā)送SQL語句更新遠(yuǎn)程表 9. “斷開指向數(shù)據(jù)源的連接” 按鈕.CLICK事件。 sqldisconnect(vconn) 10.“關(guān)閉” 按鈕.CLICK事件。 thisform.release 以上我們利用VFP的SQL pass-through技術(shù)編寫了一個(gè)簡(jiǎn)單的通信錄管理程序,實(shí)現(xiàn)對(duì)SQL Server數(shù)據(jù)庫中數(shù)據(jù)的插入、查詢、修改等基本功能,是一個(gè)典型的客戶/服務(wù)器(C/S)結(jié)構(gòu)的應(yīng)用程序。希望對(duì)讀者今后開發(fā)軟件有所幫助。
標(biāo)簽: Sql Server 數(shù)據(jù)庫
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
久久不卡国产精品一区二区| 玖玖精品视频| 国产探花一区二区| 欧美日韩一区二区三区在线电影| 日本免费新一区视频| 日韩福利在线观看| 国产亚洲精品精品国产亚洲综合| 国产乱码精品一区二区三区四区 | 卡一精品卡二卡三网站乱码| 国产日韩免费| 国产精品手机在线播放| 久久99影视| 国产精品精品| 久久国产影院| 红桃视频国产一区| 日韩专区一卡二卡| 日韩激情啪啪| 精品久久久久久久| 久久国产欧美| 美日韩精品视频| 青青青国产精品| 欧美成人一二区| 久久天堂av| 亚洲综合图色| 国产精品香蕉| 国产精品99视频| 免费av一区二区三区四区| 亚洲免费婷婷| 国产精品嫩模av在线| 久久久久久亚洲精品美女| 欧美精品日日操| 国产一区二区精品| 国产精品天天看天天狠| 伊伊综合在线| 视频一区二区三区入口| 国产精品免费精品自在线观看| 中文在线中文资源| 蜜桃国内精品久久久久软件9| 日本成人在线一区| 亚洲深夜视频| 一区二区三区国产盗摄| 久久精品福利| 在线午夜精品| 国产精品九九| 亚洲午夜91| 国产日韩一区| 久久精品国产99久久| 日韩精品一区二区三区中文在线| 精品中文字幕一区二区三区四区| 欧美日韩国产亚洲一区| 欧美视频久久| 99热国内精品| 日本亚洲最大的色成网站www| 国产91在线播放精品| 在线国产一区二区| 国产精品115| 欧美日韩激情在线一区二区三区| 日本欧美一区二区在线观看| 特黄毛片在线观看| 亚洲精品系列| 日韩中文在线电影| 青青草国产精品亚洲专区无| 群体交乱之放荡娇妻一区二区| 日本一不卡视频| 久久久久免费av| 欧美日本精品| 亚洲精品123区| 国产乱子精品一区二区在线观看| 激情综合激情| 精品亚洲精品| 日韩国产欧美一区二区三区| 久久久久国产精品一区三寸 | 天使萌一区二区三区免费观看| 精品视频在线观看网站| 在线一区二区三区视频| 日韩国产一区| 国产日韩欧美三区| 美女精品一区| 99久久99久久精品国产片果冰 | 高清在线一区| 日韩一区中文| 国产亚洲午夜| 99成人超碰| 成人在线视频免费看| 日韩有吗在线观看| 妖精视频成人观看www| 国产一区二区久久久久| 日本va欧美va瓶| 午夜在线精品偷拍| 99精品在线| 久久久久久一区二区| 国产欧美日韩综合一区在线播放| 免费精品视频在线| 久久精品播放| 91看片一区| 日韩成人精品一区| 免费看一区二区三区| 奇米亚洲欧美| 日韩国产一二三区| 伊人精品久久| 蘑菇福利视频一区播放| 九色精品91| 久久美女精品| 久久精品亚洲人成影院| 正在播放日韩精品| 国产成人精选| 国语精品一区| 久久精品一本| 国产麻豆精品| 国产乱码精品一区二区三区四区| 日韩国产精品久久久| 四虎在线精品| 日韩中文av| 亚洲日本久久| 亚州精品视频| 亚洲毛片在线| 婷婷精品在线观看| 天堂久久一区| 视频一区中文字幕精品| 亚洲2区在线| 日韩动漫一区| 青青伊人久久| 国产精品片aa在线观看 | 麻豆久久一区| 国产精品久久久久久久免费软件| 日韩精品一级| 欧美私人啪啪vps| 欧美天堂在线| 国产精品成人一区二区网站软件| 国产精品多人| 精品一区二区三区亚洲| 国产精品国产三级国产在线观看| 国产一区二区视频在线看| 国产一区二区三区探花| 国产一区二区三区天码| 国产成人77亚洲精品www| 最新中文字幕在线播放 | 国产v日韩v欧美v| 日韩欧美视频专区| 在线看片不卡| 亚洲网址在线观看| 91麻豆精品| 久久精品国产99国产| 日韩欧美一区二区三区在线视频 | 日韩成人一级| 国产精品欧美三级在线观看| 精品黄色一级片| 色天使综合视频| 国产精品视区| 97久久亚洲| 国产网站在线| 91久久久久| 91欧美精品| 精品理论电影在线| 久久精品动漫| 日本欧洲一区二区| 国产欧美精品久久| 都市激情国产精品| 不卡在线一区| 在线精品国产亚洲| 国产精品久久久久77777丨| 国产精品福利在线观看播放| 国产精品99一区二区| 亚洲精品视频一二三区| 欧美激情99| 免费精品国产的网站免费观看| 巨乳诱惑日韩免费av| 国产欧美日韩一区二区三区在线| 国产精品成人a在线观看| 欧美女激情福利| 欧美久久香蕉| 天堂资源在线亚洲| 日本免费在线视频不卡一不卡二| 97精品一区二区| 婷婷亚洲综合| 日韩欧美另类中文字幕| 国产精品二区不卡| 日本欧洲一区二区| 国产成人免费| 日韩在线一区二区| 精品日韩在线| 视频一区视频二区中文| 精品久久久中文字幕| 亚洲制服少妇| 国产一区二区三区国产精品| 国产亚洲在线观看| 精品高清久久| 一区二区亚洲视频| 亚洲精品福利电影| 亚洲精品日韩久久| 热三久草你在线| 日本不卡中文字幕| 欧美日韩国产v| 热久久久久久| 黑丝一区二区三区| 福利精品在线| 日本亚洲欧美天堂免费| 99久久婷婷这里只有精品| 欧美日韩一区二区国产 | 日韩欧美美女在线观看|