Foxtable(狐表)用户栏目专家坐堂 → [求助]高速合并报错_列“编号”被约束为是唯一的。值“”已存在


  共有4972人关注过本帖树形打印复制链接

主题:[求助]高速合并报错_列“编号”被约束为是唯一的。值“”已存在

帅哥哟,离线,有人找我吗?
有点甜
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:版主 帖子:85326 积分:427815 威望:0 精华:5 注册:2012/10/18 22:13:00
  发帖心情 Post By:2014/3/29 9:37:00 [显示全部帖子]

 这个因为编号作为主键引发的问题,导入的时候,必须赋值和唯一。只能变通一下导入,用下面的代码

 

Dim Book As New XLS.Book(ProjectPath & "2.xls")
Dim Sheet As XLS.Sheet = Book.Sheets(0)
Tables("test").StopRedraw()
'注意以下数组中列名称的顺序,必须和Excel表中的列顺序一致
Dim nms() As String = {"编号","标题"}

Tables("test").AddNew()

'注意下面的循环变量从1开始,而不是从0开始,因为Excel表的第一行是标题
For n As Integer = 1 To Sheet.Rows.Count -1
    Dim bh As String = sheet(n,0).Text
    If DataTables("test").Find("编号 = '" & bh & "'") Is Nothing Then '如果不存在同编号的订单
        Dim r As Row = Tables("test").AddNew()
        For m As Integer = 0 To nms.Length - 1
            Tables("test").rows(r.index-1)(nms(m)) = Sheet(n,m).Value
        Next
    End If
Next
Tables("Test").Current.Delete
Tables("test").ResumeRedraw()


 回到顶部
帅哥哟,离线,有人找我吗?
有点甜
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:版主 帖子:85326 积分:427815 威望:0 精华:5 注册:2012/10/18 22:13:00
  发帖心情 Post By:2014/3/31 20:14:00 [显示全部帖子]

以下是引用雪糕在2014-3-31 19:52:00的发言:
按您的方法试了,把数据库清空,然后把空格都删除还是不成,同样的报错

 

我用例子测试没有报错。你清空数据以后,记得保存。


 回到顶部