电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

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

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

瀏覽:15日期:2023-11-02 10:40:56
;;VFP因它簡單易學,可快速建立應(yīng)用軟件而深受廣大程序員喜愛,但其數(shù)據(jù)庫系統(tǒng)不安全也令廣大用戶非常頭痛。隨著MS SQL Server數(shù)據(jù)庫系統(tǒng)的推廣應(yīng)用,其強大的安全性能普遍受到好評。筆者在長期的編程實踐中,發(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)用軟件。現(xiàn)通過編寫一個簡單的通信錄例子和廣大VFP愛好者共同探討。 一、服務(wù)器端MS SQL Server數(shù)據(jù)庫設(shè)計 1. 在MS SQL Server中建立名為“SFXT”的數(shù)據(jù)庫。 2. 在SFXT數(shù)據(jù)庫中建立名為“通信錄”的數(shù)據(jù)表,表結(jié)構(gòu)如下: 列名(字段名) 數(shù)據(jù)類型 長度 姓名 chr 8 生日 datetime 8 電話 chr 11 email chr 30 并將姓名設(shè)置為主鍵。 3. 在“SFXT”數(shù)據(jù)庫中建立查詢出所有記錄的存儲過程。 SP_SearchAll CREATE PROCEDURE [SP_SearchAll] AS select * from 通信錄 order by 姓名 return 4. 在“SFXT”數(shù)據(jù)庫中建立插入新記錄的存儲過程 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è)計 1. 建立如(^15020603b^)的VFP表單界面。 2. 建立名為“SFXT”的ODBC數(shù)據(jù)源連接MS SQL Server中的SFXT數(shù)據(jù)庫。 可通過執(zhí)行上面VFP表單的按鈕“建立OBDC數(shù)據(jù)源”來完成;或者通過運行Windows控制面板中的“OBDC數(shù)據(jù)源”來完成。主要設(shè)置包括選擇SQL Server驅(qū)動程序,通信協(xié)議,登錄標識與密碼等。 “建立OBDC數(shù)據(jù)源”按鈕.CLICK事件: *函數(shù)說明SQLSTRINGCONNECT([cConnectString]) *省略連接字符串cConnectString時顯示''SQL數(shù)據(jù)源''對話框,可選擇或新建數(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è)置,“活動連接屬性設(shè)置”按鈕.CLICK事件。 * 注:用函數(shù)sqlgetprop()可返回設(shè)置的參數(shù)值 sqlsetprop(vconn,''asynchronous'',.f.) &&取假值時為結(jié)果集同步返回: 取真值時為異步返回 sqlsetprop(vconn,''ConnectTimeOut'',15) &&連接超時等待秒數(shù)設(shè)置,可取值0至600 sqlsetprop(vconn,''IdleTimeout'',0)&&空閑超時間隔秒數(shù),取值0為無限期超時等待 sqlsetprop(vconn,''Transactions'',1) &&取值1時為自動處理遠程事務(wù):取值2時為手工處理 5. “執(zhí)行存儲過程查詢數(shù)據(jù)”按鈕.CLICK事件。 *函數(shù)說明SQLEXEC(nConnectionHandle, [cSQLCommand, [CursorName]]) *nConnectionHandle 當前數(shù)據(jù)源活動連接句柄 *cSQLCommand執(zhí)行SQL SERVER存儲過程的SQL語句表達式 *CursorName返回執(zhí)行結(jié)果臨時表的名稱 sqlexec(vconn,''execute SP_SearchAll'',''我的通信錄'') browse 6. “執(zhí)行SQL語句查詢數(shù)據(jù)” 按鈕.CLICK事件。 *函數(shù)說明SQLEXEC(nConnectionHandle, [cSQLCommand, [CursorName]]) *nConnectionHandle 當前數(shù)據(jù)源活動連接句柄 *cSQLCommand需發(fā)送SQL語句表達式 *CursorName返回執(zhí)行結(jié)果臨時表的名稱 SQLEXEC(vconn, 'SELECT * FROM 通信錄', '我的通信錄') browse 7. “向存儲過程傳替參數(shù)插入新記錄” 按鈕.CLICK事件。 local vname,vbirthday,vtelephone,vemail,vsql *隨機產(chǎn)生新記錄舉例 vname = '姓名'+sys(3) &&姓名 vbirthday = dtoc(date()-int(rand()*10000)) &&生日 vtelephone = sys(3) &&電話 vemail = sys(3)+'@hotmail.com' &&電子郵箱 *將傳遞到存儲過程的參數(shù)轉(zhuǎn)換成字符串,并加引號形成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è)置當前表的屬性修改數(shù)據(jù)” 按鈕.CLICK事件。 * 注:用函數(shù)cursorgetprop()可返回設(shè)置的參數(shù)值 cursorsetprop('BatchUpdateCount',100) &&發(fā)送到緩沖表的遠程數(shù)據(jù)源的更新指令的數(shù)目 cursorsetprop('Buffering',3) &&設(shè)置當前表為開放式行緩沖 cursorsetprop('FetchSize',-1)&&從遠程表中提取全部查詢記錄 cursorsetprop('KeyFieldList','姓名')&&指定遠程表的主關(guān)鍵字段 cursorsetprop('SendUpdates',.t.) &&當前緩沖表更改內(nèi)容時發(fā)送SQL語句更新遠程表 cursorsetprop('Tables','通信錄') &&指定連接的遠程表名 *本地緩沖表與遠程表字段對應(yīng)關(guān)系 cursorsetprop('UpdateNameList','姓名 通信錄.姓名,生日 通信錄.生日,電話 通信錄.電話,email 通信錄.email') *指定可更新字段列表 cursorsetprop('UpdatableFieldList','姓名,生日,電話,email') cursorsetprop('UpdateType',1) &&遠程表更新方式,替換方式 cursorsetprop('WhereType',3)&&更新SQL語句中where子句包含主關(guān)鍵字與被修改過的字段 browse&&修改緩沖表數(shù)據(jù),移動記錄指針后,自動發(fā)送SQL語句更新遠程表 9. “斷開指向數(shù)據(jù)源的連接” 按鈕.CLICK事件。 sqldisconnect(vconn) 10.“關(guān)閉” 按鈕.CLICK事件。 thisform.release 以上我們利用VFP的SQL pass-through技術(shù)編寫了一個簡單的通信錄管理程序,實現(xiàn)對SQL Server數(shù)據(jù)庫中數(shù)據(jù)的插入、查詢、修改等基本功能,是一個典型的客戶/服務(wù)器(C/S)結(jié)構(gòu)的應(yīng)用程序。希望對讀者今后開發(fā)軟件有所幫助。
主站蜘蛛池模板: 高楼航空障碍灯厂家哪家好_航空障碍灯厂家_广州北斗星障碍灯有限公司 | 工业洗衣机_工业洗涤设备_上海力净工业洗衣机厂家-洗涤设备首页 bkzzy在职研究生网 - 在职研究生招生信息咨询平台 | 锡膏喷印机-全自动涂覆机厂家-全自动点胶机-视觉点胶机-深圳市博明智控科技有限公司 | 上海律师咨询_上海法律在线咨询免费_找对口律师上策法网-策法网 广东高华家具-公寓床|学生宿舍双层铁床厂家【质保十年】 | 纯化水设备-EDI-制药-实验室-二级反渗透-高纯水|超纯水设备 | 深圳市八百通智能技术有限公司官方网站| 冷轧机|两肋冷轧机|扁钢冷轧机|倒立式拉丝机|钢筋拔丝机|收线机-巩义市华瑞重工机械制造有限公司 | 成都治疗尖锐湿疣比较好的医院-成都治疗尖锐湿疣那家医院好-成都西南皮肤病医院 | 阴离子聚丙烯酰胺价格_PAM_高分子聚丙烯酰胺厂家-河南泰航净水材料有限公司 | 长沙一级消防工程公司_智能化弱电_机电安装_亮化工程专业施工承包_湖南公共安全工程有限公司 | 焊锡丝|焊锡条|无铅锡条|无铅锡丝|无铅焊锡线|低温锡膏-深圳市川崎锡业科技有限公司 | 百度网站优化,关键词排名,SEO优化-搜索引擎营销推广 | 安平县鑫川金属丝网制品有限公司,声屏障,高速声屏障,百叶孔声屏障,大弧形声屏障,凹凸穿孔声屏障,铁路声屏障,顶部弧形声屏障,玻璃钢吸音板 | 一体化污水处理设备-一体化净水设备-「山东梦之洁水处理」 | 权威废金属|废塑料|废纸|废铜|废钢价格|再生资源回收行情报价中心-中废网 | 不干胶标签-不干胶贴纸-不干胶标签定制-不干胶标签印刷厂-弗雷曼纸业(苏州)有限公司 | 照相馆预约系统,微信公众号摄影门店系统,影楼管理软件-盟百网络 | 超声骨密度仪,双能X射线骨密度仪【起草单位】,骨密度检测仪厂家 - 品源医疗(江苏)有限公司 | 四川职高信息网-初高中、大专、职业技术学校招生信息网 | 我爱古诗词_古诗词名句赏析学习平台 | 废气处理_废气处理设备_工业废气处理_江苏龙泰环保设备制造有限公司 | 薄壁轴承-等截面薄壁轴承生产厂家-洛阳薄壁精密轴承有限公司 | 深圳市东信高科自动化设备有限公司| bng防爆挠性连接管-定做金属防爆挠性管-依客思防爆科技 | 精密五金冲压件_深圳五金冲压厂_钣金加工厂_五金模具加工-诚瑞丰科技股份有限公司 | 高防护蠕动泵-多通道灌装系统-高防护蠕动泵-www.bjhuiyufluid.com慧宇伟业(北京)流体设备有限公司 | 高压互感器,电流互感器,电压互感器-上海鄂互电气科技有限公司 | 红立方品牌应急包/急救包加盟,小成本好项目代理_应急/消防/户外用品加盟_应急好项目加盟_新奇特项目招商 - 中红方宁(北京) 供应链有限公司 | 北京签证代办_签证办理_商务签证_旅游签证_寰球签证网 | 托盘租赁_塑料托盘租赁_托盘出租_栈板出租_青岛托盘租赁-优胜必达 | 透平油真空滤油机-变压器油板框滤油机-滤油车-华之源过滤设备 | 冷凝锅炉_燃气锅炉_工业燃气锅炉改造厂家-北京科诺锅炉 | 新能源汽车电池软连接,铜铝复合膜柔性连接,电力母排-容发智能科技(无锡)有限公司 | 品牌策划-品牌设计-济南之式传媒广告有限公司官网-提供品牌整合丨影视创意丨公关活动丨数字营销丨自媒体运营丨数字营销 | 超声波气象站_防爆气象站_空气质量监测站_负氧离子检测仪-风途物联网 | 屏蔽服(500kv-超高压-特高压-电磁)-徐吉电气 | 代办建筑资质升级-建筑资质延期就找上海国信启航 | 工业插头-工业插头插座【厂家】-温州罗曼电气 | 工业车间焊接-整体|集中除尘设备-激光|等离子切割机配套除尘-粉尘烟尘净化治理厂家-山东美蓝环保科技有限公司 | 珠宝展柜-玻璃精品展柜-首饰珠宝展示柜定制-鸿钛展柜厂家 | uv固化机-丝印uv机-工业烤箱-五金蚀刻机-分拣输送机 - 保定市丰辉机械设备制造有限公司 |