0

我有一个 Access 数据库,我在其中删除表,然后重新创建表。但是,我需要能够测试该表,以防表被删除但未创建(即当有人在 DTS 包启动后立即停止它时 -roll-eyes- )。如果我在 SQL 数据库中这样做,我会这样做:

IF (EXISTS (SELECT * FROM sysobjects WHERE name = 'Table-Name-to-look-for'))
BEGIN
drop table 'Table-Name-to-look-for'
END

但是如何为 Access 数据库执行此操作?

可选答案:有没有办法让 DTS 包忽略错误并直接进入下一步而不是检查它是否存在?

SQL Server 2000

4

3 回答 3

1

Microsoft Access 有一个名为 MSysObjects 的系统表,其中包含所有数据库对象(包括表)的列表。表对象具有类型 1、4 和 6。

引用类型很重要:

... 其中 Name='TableName' 并输入 (1,4,6)

否则,返回的可能是表以外的某个对象。

于 2008-08-25T14:03:17.400 回答
1

尝试相同的 T-SQL,但在 MS ACCESS 中,sys 对象表称为:MSysObjects。

试试这个:

SELECT * FROM MSysObjects WHERE Name = 'your_table';

看看它是否从那里工作。

如果您转到工具 -> 选项 -> 查看(选项卡)-> 并检查隐藏对象,系统对象,则可以查看这些表。所以你可以看到两者。如果您打开表,您应该会看到您的表名、查询等。不要手动更改它,否则数据库可能会恐慌 :)

马丁。

PD:您的 If Exists 还应该检查对象类型:

IF EXISTS (SELECT * FROM sysobjects WHERE id = object_id(N'[dbo].[Your_Table_Name]') AND OBJECTPROPERTY(id, N'IsUserTable') = 1)
于 2008-08-25T14:05:30.687 回答
1

我不确定您是否可以从 DTS 包中查询 Access 数据库中的系统对象表。

如果这不起作用,为什么不尝试从有问题的 Access 表中执行 SELECT *,然后 在失败时捕获错误?

于 2008-10-02T15:34:39.370 回答