创建表时抛出错误
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 列放入主键中!使用INT
或BIGINT
或其他东西 - 不是三列的组合,中间有一个ntext
....如何解决?只是不要将 ntext
列放在索引中 - 正如错误非常清楚地表明......
【参考方案1】:
我认为问题在于您在主键中使用了 tablename ntext
列 - 不要这样做!不要将这么长的列放入主键!这真是个坏主意。
使用INT
或BIGINT
或类似的东西 - 不是三列的组合,中间有一个ntext
....
如何解决? 只是不要将ntext
列放在索引中 - 正如错误非常清楚地表明...
【讨论】:
以上是关于创建表时抛出错误的主要内容,如果未能解决你的问题,请参考以下文章
通过 terraform 创建 Azure App 服务时抛出错误此处不应出现名为“zone_redundant”的参数
Glassfish 管理控制台在创建 JDBC 池时抛出 java.lang.IllegalStateException