不幸的是,使用ASP将带有定界符的文本文件变成数据库表并不想所期望的那样简单。不管怎么说,ASP并非一个数据库工具,所以我们需要在实际导入数据前进行一些设置工作。
特别要注意的是,我们需要使用某种方法将导入数据的目标表的信息告诉ASP代码。至少要了解表中域的个数、名称、它们的类型(比如字符型、数字型、日期形等等) 以及每个域中最多可以包含的数据(如果是一个字符型的域)。使用一个简单的文本文件来描述目标数据库表是一个好的解决办法。表A列出了这样一个例子。
3 name, c, 50 age, n, 0 birthday, d, 0
文件的首行告诉我们该表有多少个域(在此例中是三个)。剩下的三行分别描述了表中每一个域的特征。每一行都含有域的名称、类型(n=数字型、c=字符型、d=日期型)以及域可以包含的字符个数。(注意最后一项信息只对字符域有意义。) 需要特别注意的是,这些域的排列顺序必须与它们在含有定界符的文本文件中的顺序相同!好,从表A中我们可以看出这个表有三个域:
在表B中,我们看到的是一个用tab作为定界符的简单的文本文件。它含有几个总统的姓名、他们就职时的年龄以及他们的生日。(注意这个文件中域的顺序与表A所示的文件是相同的。你还可以注意到第二条记录的age域含有一个非数字的值。)
Jimmy Carter 52 10/01/1924 Ronald Reagan sixty-nine 02/06/1911 George Bush 64 06/12/1924
如表B所示,大多数文件都使用tab作为定界符。不过,定界符也可以是任意字符。因此,最好的解决方案应该能够处理任何定界符。
表C出了这个问题的一种可能的解决方案。这是一个Visual Basic函数,它能够读取带有定界符的文本文件并且将数据加入到指定的数据库表中。
为了尽可能灵活,该函数带有几个不同的参数: