您现在的位置: 中国男护士网 >> 考试频道 >> 计算机等级 >> 二级辅导 >> VFP >> 辅导 >> 正文    
  将DBF表导入到SQLSERVER中的函数 【注册男护士专用博客】          

将DBF表导入到SQLSERVER中的函数

www.nanhushi.com     佚名   不详 

  给大家一个自已写的将DBF表导入到SQL SERVER数据库中的函数
  我一直在我的程序中用,方便不少
  请多多指都教,有什么问题可以回帖或邮trywell@sohu.com
  连接句柄为CON,可以调用本函数之前执行如下语句CON=SQLSTRINGCONNECT("DRIVER=SQL SERVER;SERVER=(LOCAL);UID=SA;PWD=;DATABASE=你的数据库名")
  ***dbftosql()

  PROCEDURE DBFTOSQL
  PARA MDBF
  LOCAL I,MFIELD,MTYPE,MCOLUMN,MSQLTYPE,MLEN,MSQL1,MSQL2
  MFIELD=''
  MTYPE=''
  MCOLUMN=''
  MSQLTYPE=''
  MLEN=''
  MSQL1=''
  MSQL2=''
  IF !USED(MDBF)
  USE &MDBF
  ENDI
  SELE &MDBF
  I=1
  DO WHILE !EMPTY(FIELD(I))
  MFIELD=FIELD(I)
  MTYPE=TYPE(MFIELD)
  DO CASE
  CASE UPPER(TYPE(MFIELD))='C'
  MSQLTYPE='CHAR'
  CASE UPPER(TYPE(MFIELD))='Y'
  MSQLTYPE='MONEY'
  CASE UPPER(TYPE(MFIELD))='D'
  MSQLTYPE='DATETIME'
  CASE UPPER(TYPE(MFIELD))='T'
  MSQLTYPE='DATETIME'
  CASE UPPER(TYPE(MFIELD))='B'
  MSQLTYPE='FLOAT'
  CASE UPPER(TYPE(MFIELD))='F'
  MSQLTYPE='FLOAT'
  CASE UPPER(TYPE(MFIELD))='G'
  MSQLTYPE='IMAGE'
  CASE UPPER(TYPE(MFIELD))='I'
  MSQLTYPE='INT'
  CASE UPPER(TYPE(MFIELD))='L'
  MSQLTYPE='BIT'
  CASE UPPER(TYPE(MFIELD))='M'
  MSQLTYPE='TEXT'
  CASE UPPER(TYPE(MFIELD))='N'
  MSQLTYPE='FLOAT'
  ENDCASE
  IF 'C'$MTYPE
  MLEN='('+ALLT(STR(LEN(&MFIELD)))+')'
  ELSE
  MLEN=''
  ENDI
  IF EMPTY(MCOLUMN)
  MCOLUMN=FIELD(I)+SPACE(1)+ALLT(MSQLTYPE)+MLEN
  ELSE
  MCOLUMN=MCOLUMN+','+FIELD(I)+SPACE(1)+ALLT(MSQLTYPE)+MLEN
  ENDI
  IF EMPTY(MSQL1)
  MSQL1=FIELD(I)
  ELSE
  MSQL1=MSQL1+','+FIELD(I)
  ENDI
  IF EMPTY(MSQL2)
  MSQL2='?'+FIELD(I)
  ELSE
  MSQL2=MSQL2+',?'+FIELD(I)
  ENDI
  I=I+1
  ENDD
  MSQL='CREATE TABLE '+MDBF+SPACE(1)+'('+MCOLUMN+')'
  IF SQLEXEC(CON,MSQL)=1
  ENDI
  IF RECCOUNT()>0
  GO TOP
  DO WHILE !EOF()
  I=1
  DO WHILE !EMPTY(FIELD(I))
  XX=FIELD(I)
  IF XX=.NULL.
  REPL &XX WITH ''
  ENDI
  I=I+1
  ENDD
  MSQL='INSERT INTO '+MDBF+SPACE(1)+'('+MSQL1+')'+SPACE(1)+'VALUES ('+MSQL2+')'
  IF SQLEXEC(CON,MSQL)=1
  ENDI
  SKIP
  ENDD
  ENDI
  USE IN &MDBF
  RETU

 

文章录入:杜斌    责任编辑:杜斌 
  • 上一篇文章:

  • 下一篇文章:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
     

    联 系 信 息
    QQ:88236621
    电话:15853773350
    E-Mail:malenurse@163.com
    免费发布招聘信息
    做中国最专业男护士门户网站
    最 新 热 门
    最 新 推 荐
    相 关 文 章
    没有相关文章
    专 题 栏 目

      网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)                            【进男护士社区逛逛】
    姓 名:
    * 游客填写  ·注册用户 ·忘记密码
    主 页:

    评 分:
    1分 2分 3分 4分 5分
    评论内容:
  • 请遵守《互联网电子公告服务管理规定》及中华人民共和国其他各项有关法律法规。
  • 严禁发表危害国家安全、损害国家利益、破坏民族团结、破坏国家宗教政策、破坏社会稳定、侮辱、诽谤、教唆、淫秽等内容的评论 。
  • 用户需对自己在使用本站服务过程中的行为承担法律责任(直接或间接导致的)。
  • 本站管理员有权保留或删除评论内容。
  • 评论内容只代表网友个人观点,与本网站立场无关。