复制具有主键的访问表 [英] Copy Access table with primary keys

查看:35
本文介绍了复制具有主键的访问表的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

使用C#、ODBC和Jet4.0引擎处理(旧的)Access数据库。该任务要求我不使用DAO。

遗憾的是,Microsoft Jet 4.0数据库引擎不支持";rename";关键字。以下所有情况都引发异常:

  • 将表old_name重命名为new_name;
  • 将old_name重命名为new_name;
  • ALTER TABLE OLD_NAME RENAME为NEW_NAME;

但以下语法确实有效:

SELECT * INTO new_name FROM old_name;

问题在于未复制主键。

有没有办法创建表的副本,并在副本中保留哪些字段是主键?

推荐答案

使用ODBC,您可以获取/获取索引。大多数情况下,PK列都有一个称为主键的索引。这不是100%保证的。

因此,这在&q;大多数情况下都会起作用:

例如:

Sub Test22()

    Using con As New OdbcConnection(My.Settings.Test44ODBC2)
        '            Using cmdSQL As New OdbcCommand("SELECT TOP 1 * From PKTEST", con)

        con.Open()

        Dim schemaTable As New DataTable
        schemaTable = con.GetSchema("Indexes", New String() {Nothing, Nothing, "PKTEST"})
        Me.DataGridView1.DataSource = schemaTable

    End Using

 End Sub

输出:

但是,用户可以创建索引并为其指定不同的名称。

例如,我可以进入上表,将主键重命名为我想要的任何内容-请这样说:

所以,不是很好。

但是,虽然应用程序和您的大部分代码可以坚持ODBC?

如果您使用oleDB,则可以100%可靠地获取PK,并且不需要引用DAO。

因此,虽然上面显示我们使用";zoo";重命名了PK,但此oleDB代码仍将返回PK列,如下所示:

Sub GetoleDBGetKey()

    Using con As New OleDbConnection(My.Settings.TESTAce)
        Using cmdSQL As New OleDbCommand("SELECT * from PKTEST", con)

            con.Open()
            Dim schemaTable As DataTable = con.GetOleDbSchemaTable(OleDbSchemaGuid.Primary_Keys,
                            New Object() {Nothing, Nothing, "PKTEST"})

            Me.DataGridView1.DataSource = schemaTable
        End Using
    End Using
End Sub

因此,oleDB将100%工作。

上面的ODBC片段?那么,我们必须假设";PrimaryKey";,而这实际上并不是一个要求(它被命名为";PrimaryKey";)

因此,您可以考虑oleDB。

我挖得不是很深,但我觉得ODBC拿不到可靠的PK。

您可以使用我上面的ODBC getSchema。有一些代码片段建议您打开连接、打开读取器并使用数据读取器的getschema,这确实有效-但我没有一个可工作的示例(甚至不知道这是否可以工作-但有一些建议这可以/确实可以工作)。

这篇关于复制具有主键的访问表的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆