复制具有主键的访问表

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

问题描述

使用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,这确实有效-但我没有一个可工作的示例(甚至不知道这是否可以工作-但有一些建议这可以/确实可以工作)。

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

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

DispatcherQueue null when trying to update Ui property in ViewModel(尝试更新ViewModel中的Ui属性时DispatcherQueue为空)
Drawing over all windows on multiple monitors(在多个监视器上绘制所有窗口)
Programmatically show the desktop(以编程方式显示桌面)
c# Generic Setlt;Tgt; implementation to access objects by type(按类型访问对象的C#泛型集实现)
InvalidOperationException When using Context Injection in ASP.Net Core(在ASP.NET核心中使用上下文注入时发生InvalidOperationException)
LINQ many-to-many relationship, how to write a correct WHERE clause?(LINQ多对多关系,如何写一个正确的WHERE子句?)