本文介绍了复制具有主键的访问表的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
使用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,这确实有效-但我没有一个可工作的示例(甚至不知道这是否可以工作-但有一些建议这可以/确实可以工作)。
这篇关于复制具有主键的访问表的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!