



全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
VFP中用SPT访问SQL SERVER数据库详解VFP因它简单易学,可快速建立应用软件而深受广大程序员喜爱,但其数据库系统不安全也是令广大用户非常头痛。随着MSSQLSERVER数据库系统的推广应用,其强大的安全性能普遍受到好评。笔者在长期的编程实践中发现利用VFP的SQLPASS-THROUGH(SPT)技术结合MSSQLSERVER数据库系统,也能象VB、DELPHI、POWERBUILDER一样轻松开发出优秀的客户/服务器(C/S)应用软件。现通过编写一个简单的通信录例子和广大VFP爱好者共同探讨。一、服务器端MSSQLSERVER数据库设计1、在MSSQLSERVER中建立名为“SFXT”的数据库。2、在SFXT数据库中建立名为“通信录”的表,结构如下:列名(字段名)数据类型长度姓名CHAR8生日DATETIME8电话CHAR11EMAILCHAR30并将姓名设置为主键3、在SFXT数据库中建立查询出所有记录的存储过程SP_SEARCHALLCREATEPROCEDURESP_SEARCHALLASSELECT*FROM通信录ORDERBY姓名RETURN4、在SFXT数据库中建立插入新记录的存储过程SP_INSERTDATACREATEPROCEDURESP_INSERTDATANAMECHAR(10),BIRTHDAYDATETIME,TELEPHONECHAR(11),EMAILCHAR(30)ASINSERTINTO通信录(姓名,生日,电话,EMAIL)valueS(NAME,BIRTHDAY,TELEPHONE,EMAIL)RETURN二、客户端VFP的SQLPASS-THROUGH技术设计1、建立VFP表单界面,按钮内容如下建立ODBC数据源建立连接方式1建立连接方式2活动连接属性设置执行存储过程查询数据执行SQL语句查询数据向存储过程传替参数插入新记录设置当前表的属性修改数据断开指向数据源的连接退出程序2、建立名为SFXT的ODBC数据源连接MSSQLSERVER中的SFXT数据库可通过执行上面VFP表单的按钮建立ODBC数据源来完成;或者通过运行WINDOWS控制面板中的ODBC数据源来完成,主要设置包括选择SQLSERVER驱动程序,通信协议,登录标识与密码等。建立ODBC数据源按钮的CLICK事件:*函数说明SQLSTRINGCONNECT(CCONNECTSTRING)*省略连接字符串CCONNECTSTRING时显示SQL数据源对话框,可选择或新建数据源。SQLSTRINGCONNECT()3、两种连接MSSQLSERVER数据源的方式。使用现有数据源名称建立连接,建立连接方式1按钮CLICK事件:PUBLICVODBC,VUSER,VPWD,VCONNVODBC=SFXT&连接SQLSERVER数据库ODBC数据源名称VUSER=SA&访问SQLSERVER数据库的登录用户名,SA为系统用户VPWD=5213&用户登录密码,为SA系统用户设置的密码VCONN=SQLCONNECT(VODBC,VUSER,VPWD)IFVCONN0MESSAGEBOX(连接成功!,64,ODBC数据源)ELSEMESSAGEBOX(连接失败!,64,ODBC数据源)ENDIF使用连接字符串建立数据源连接,“建立连接方式2”按钮CLICK事件:PUBLICVCONNVCONN=SQLSTRINGCONNECT(DSN=SFXT;UID=SA;PWD=5213)IFVCONN0MESSAGEBOX(连接成功!,64,ODBC数据源)ELSEMESSAGEBOX(连接失败!,64,ODBC数据源)ENDIF4、数据源连接的主要参数设置,“活动连接属性设置”按钮CLICK事件:*注:用函数SQLGETPROP()可返回设置的参数SQLSETPROP(VCONN,ASYNCHRONOUS,.F.)&取假值时结果为同步返回,取真值时为异步返回SQLSETPROP(VCONN,CONNECTTIMEOUT,15)&连接超时等待秒数设置,可取值0至600SQLSETPROP(VCONN,IDLETIMEOUT,0)&空闲超时间隔秒数,取0为无限期等待SQLSETPROP(VCONN,TRANSACTIONS,1)&取1时为自动处理远程事务,取2为手工处理5、执行存储过程查询数据按钮CLICK事件:*函数说明SQLEXEC(NCONNECTIONHANDLE,CSQLCOMMAND,CURSORNAME)*NCONNECTIONHANDLE当前数据源活动连接句柄*CSQLCOMMAND执行SQLSERVER存储过程的SQL语句表达式*CURSORNAME返回执行结果临时表的名称SQLEXEC(VCONN,EXECUTESP_SEARCHALL,我的通信录)BROWSE6、执行SQL语句查询数据按钮CLICK事件:*函数说明SQLEXEC(NCONNECTIONHANDLE,CSQLCOMMAND,CURSORNAME)*NCONNECTIONHANDLE当前数据源活动连接句柄*CSQLCOMMAND执行SQLSERVER存储过程的SQL语句表达式*CURSORNAME返回执行结果临时表的名称SQLEXEC(VCONN,SELECT*FROM通信录,我的通信录)BROWSE7、向存储过程传替参数插入新记录按钮CLICK事件:LOCALVNAME,VBIRTHDAY,VTELEPHONE,VEMAIL,VSQL*随机产生新记录举例VNAME=姓名+SYS(3)&姓名VBIRTHDAY=DTOC(DATE()-INT(RAND()*10000)&生日VTELEPHONE=SYS(3)&电话VEMAIL=SYS(3)+HOTMAIL.COM&电子邮箱*将传递到存储过程的参数转换成字符串,并加引号形成SQL语句VSQL=EXECUTESP_INSERTDATA+VNAME+,+VBIRTHDAY+,+VTELEPHONE+,+VEMAIL+IFSQLEXEC(VCONN,VSQL)0MESSAGEBOX(插入记录成功!,64,信息)ELSEMESSAGEBOX(插入记录失败!,64,信息)ENDIFSQLEXEC(VCONN,EXECUTESP_SEARCHALL,我的通信录)BROWSE8、设置当前表的属性修改数据按钮CLICK事件:*注:用函数CURSORGETPROP()可返回设置的参数CURSORSETPROP(BATCHUPDATECOUNT,100)&发送到缓冲表的远程数据源的更新指令的数目CURSORSETPROP(BUFFERING,3)&设置当前表为开放式行缓冲CURSORSETPROP(FETCHSIZE,-1)&从远程表中提取全部查询记录CURSORSETPROP(KEYFIELDLIST,姓名)&指定远程表的主关键字段CURSORSETPROP(SENDUPDATES,.T.)&当前缓冲表更改内容时发送SQL语句更新远程表CURSORSETPROP(TABLES,通信录)&指定连接的远程表名*本地缓冲表与远程表字段对应关系CURSORSETPROP(UPDATENAMELIST,姓名通信录.姓名,生日通信录.生日,电话通信录.电话,;EMAIL通信录.EMAIL)*指定可更新字段列表CURSORSETPROP(UPDATABLEFIELDLIST,姓名,生日,电话,EMAIL)CURSORSETPROP(UPDATETYPE,1)&远程表更新方式,替换方式CUR
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 二零二五年度大型建筑设施定期检查与维修服务合同
- 2025版建筑工程质量检测资料承包合同规范文本
- 二零二五年度企业临时应急资金借款合同模板
- 二零二五电信营业厅设施优化与装修合同范本
- 2025版担保合同备案与登记程序范本
- 二零二五年度精装修公寓工程合同模板大全
- 二零二五版不锈钢装饰条加工及销售协议
- 二零二五年度旅游度假村股权收购与资源整合合同
- 二零二五年度智慧型方自卸车租赁服务协议
- 潞安化工安全知识培训课件
- 粮食仓储(粮库)安全生产标准化管理体系全套资料汇编(2019-2020新标准实施模板)
- 喜茶运营管理手册和员工操作管理手册
- 比亚迪汉DM-i说明书
- 心肾综合征及其临床处理
- 普通高中课程方案
- 2022年山东高考生物试卷真题及答案详解(精校版)
- GB/T 38936-2020高温渗碳轴承钢
- 高考地理一轮复习课件 【知识精讲+高效课堂】 农业区位因素及其变化
- 教师专业发展与名师成长(学校师范专业公共课)
- 互通立交设计课件
- 生物竞赛辅导 动物行为学第七章 行为发育(38)课件
评论
0/150
提交评论