创建表时抛出错误

Posted

技术标签:

【中文标题】创建表时抛出错误【英文标题】:Error Throw when Table Creation 【发布时间】:2015-12-03 05:36:41 【问题描述】:

在我的应用程序中,我使用以下代码通过 vb.net 创建了一个 SQL Server Compact 表:

 Dim connStringCS As String = "Data Source= Test.sdf; LCID= 1033; 
 Case Sensitive=true"

 Dim xconn As New SqlCeConnection(connStringCS)
 xconn.Open()
 Dim xcmd As New SqlCeCommand()
 xcmd.Connection = xconn
 xcmd.CommandText = "CREATE TABLE datalog(schema_oid binary NOT
 NULL,tablename ntext NOT NULL, " _
 & " refno nvarchar(30) NOT NULL, lastupdated datetime NOT NULL,
 status nvarchar(1) NOT NULL , " _
 & " PRIMARY KEY (schema_oid,tablename,refno)) "

 xcmd.ExecuteNonQuery()

我收到一个错误

长值数据类型不能被索引

我在这里做错了什么?

如何解决?

【问题讨论】:

我认为问题在于您在主键中使用了tablename ntext - 不要这样做!不要将这样的 long 列放入主键中!使用INTBIGINT 或其他东西 - 不是三列的组合,中间有一个ntext....如何解决?只是不要将 ntext 列放在索引中 - 正如错误非常清楚地表明...... 【参考方案1】:

我认为问题在于您在主键中使用了 tablename ntext 列 - 不要这样做!不要将这么长的列放入主键!这真是个坏主意。

使用INTBIGINT 或类似的东西 - 不是三列的组合,中间有一个ntext....

如何解决? 只是不要将ntext 列放在索引中 - 正如错误非常清楚地表明...

【讨论】:

以上是关于创建表时抛出错误的主要内容,如果未能解决你的问题,请参考以下文章

当列是整数和小数的混合时,创建表时使用哪种数据类型?

通过 terraform 创建 Azure App 服务时抛出错误此处不应出现名为“zone_redundant”的参数

使用 POST 方法上传 JSON 对象时抛出错误请求异常

尝试发送嵌入时抛出错误

Glassfish 管理控制台在创建 JDBC 池时抛出 java.lang.IllegalStateException

ORA-00942 在 EXECUTE IMMEDIATE 创建表后引用表时出错