开发者社区


C++/C | Java | .Net/Windows | Linux/Unix | 开源 | 其他
首页 - 编程
编程
全文搜索:   

导入带有分界符的文本文件
作者: Steven W. Disbrow
2000-06-29 21:36:43



设想

不幸的是,使用ASP将带有定界符的文本文件变成数据库表并不想所期望的那样简单。不管怎么说,ASP并非一个数据库工具,所以我们需要在实际导入数据前进行一些设置工作。

特别要注意的是,我们需要使用某种方法将导入数据的目标表的信息告诉ASP代码。至少要了解表中域的个数、名称、它们的类型(比如字符型、数字型、日期形等等) 以及每个域中最多可以包含的数据(如果是一个字符型的域)。使用一个简单的文本文件来描述目标数据库表是一个好的解决办法。表A列出了这样一个例子。

表A: 一个简单的数据库表描述文件

3
name, c, 50
age, n, 0
birthday, d, 0

文件的首行告诉我们该表有多少个域(在此例中是三个)。剩下的三行分别描述了表中每一个域的特征。每一行都含有域的名称、类型(n=数字型、c=字符型、d=日期型)以及域可以包含的字符个数。(注意最后一项信息只对字符域有意义。) 需要特别注意的是,这些域的排列顺序必须与它们在含有定界符的文本文件中的顺序相同!好,从表A中我们可以看出这个表有三个域:

  • name:一个可以容纳50个字符的字符型域
  • age:一个数字型域
  • birthday:一个日期型域

表B中,我们看到的是一个用tab作为定界符的简单的文本文件。它含有几个总统的姓名、他们就职时的年龄以及他们的生日。(注意这个文件中域的顺序与表A所示的文件是相同的。你还可以注意到第二条记录的age域含有一个非数字的值。)

表B: 一个非常简单的用tab字符定界的文件

Jimmy Carter	52	10/01/1924
Ronald Reagan	sixty-nine	02/06/1911
George Bush	64	06/12/1924

如表B所示,大多数文件都使用tab作为定界符。不过,定界符也可以是任意字符。因此,最好的解决方案应该能够处理任何定界符。

解决方案

表C出了这个问题的一种可能的解决方案。这是一个Visual Basic函数,它能够读取带有定界符的文本文件并且将数据加入到指定的数据库表中。

为了尽可能灵活,该函数带有几个不同的参数:

  • dbName--指明目标表所在的数据库名称。(如果用户使用的数据库系统不使用数据库名,只需要传给这个参数一个空字符串。)
  • tableName--指定目标表的名称。
  • sourceText--存有待导入的数据的定界符文本文件,如表B所示。
  • descriptors--含有目标数据库表的描述信息的文件的名称。
  • errorLog--记录错误信息的文件的名称。
  • tCon--一个起关联作用的对象,将dbName参数中的数据库名称和tableName参数中设置的表名称联系起来。

【上一页】 【下一页】
声明:
Builder.com.cn(原ZDNet China应用开发频道)原创文章版权所有,未经许可严禁转载,且不构成投资建议。
近期相关报道:
实用技术文档
J2me XML
C/C++ C#
Java Oracle
Mysql .Net
VB.NET CSS
SQL Server 数据库
SQL UNIX
Linux Jsp
PHP Perl
Javascript IIS
XHTML ColdFusion
ASP/ASP.NET Apache
AJAX
订阅技术邮件
订阅"技术圈"杂志!请在下面选择您感兴趣的专题,填写e-mail地址,然后按订阅按钮:
应用开发管理
VS.NET 周刊
Database 周刊
WEB Service周刊
JAVA 周刊
IT 认证
Windows服务器周刊
互联网开发
当Windows Server 2008专家得5000元现金大奖
CNET NETWORKS 中国: 爱卡汽车网 | CNET科技资讯网 | e询网 | CWEEK | 蜂鸟网 | GameSpot China | 个人电脑 | PChome | SPN | 网友世界 | ZDNet China | 中关村在线
CNET NETWORKS 美国: BNET | CNET.com | CNET Download.com | CNET News.com | CNET Reviews | CNET Shopper.com | GameSpot | MP3.com | mySimon | Release 1.0 | Search.com | TechRepublic | TV.com | Webshots | ZDNet
Copyright (c) 2006 CNET Networks 版权所有。 ZDNet 是CNET Networks公司注册服务商标。
ZDNet 公司标识是 CNET Networks公司注册服务商标。
中华人民共和国电信与信息服务业务经营许可证编号:京ICP证010391号