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,这确实有效-但我没有一个可工作的示例(甚至不知道这是否可以工作-但有一些建议这可以/确实可以工作)。
这篇关于复制具有主键的访问表的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:复制具有主键的访问表
基础教程推荐
- MS Visual Studio .NET 的替代品 2022-01-01
- 有没有办法忽略 2GB 文件上传的 maxRequestLength 限制? 2022-01-01
- 为什么Flurl.Http DownloadFileAsync/Http客户端GetAsync需要 2022-09-30
- c# Math.Sqrt 实现 2022-01-01
- SSE 浮点算术是否可重现? 2022-01-01
- rabbitmq 的 REST API 2022-01-01
- 如何在 IDE 中获取 Xamarin Studio C# 输出? 2022-01-01
- 如何激活MC67中的红灯 2022-01-01
- 将 Office 安装到 Windows 容器 (servercore:ltsc2019) 失败,错误代码为 17002 2022-01-01
- 将 XML 转换为通用列表 2022-01-01