Foxtable(狐表)用户栏目专家坐堂 → 能否这样动态创建表


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

主题:能否这样动态创建表

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


加好友 发短信 一级勋章 三级勋章 二级勋章
等级:超级版主 帖子:6318 积分:33963 威望:0 精华:10 注册:2008/8/31 20:56:00
  发帖心情 Post By:2011/9/9 [显示全部帖子]

肯定可以。

不过节点列的数据得换换,因为狐表是不支持纯数字的表名的。


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


加好友 发短信 一级勋章 三级勋章 二级勋章
等级:超级版主 帖子:6318 积分:33963 威望:0 精华:10 注册:2008/8/31 20:56:00
  发帖心情 Post By:2011/9/9 0:05:00 [显示全部帖子]

这里有现成的例子,原理差不多,可参考。

 

http://www.datasoft.com.cn/dispbbs.asp?boardid=2&id=7936&authorid=0&page=0&star=1

 

 

 

 


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


加好友 发短信 一级勋章 三级勋章 二级勋章
等级:超级版主 帖子:6318 积分:33963 威望:0 精华:10 注册:2008/8/31 20:56:00
  发帖心情 Post By:2011/9/9 0:06:00 [显示全部帖子]

以下是引用kevin在2011-9-9 0:02:00的发言:

节点只是用来作为表名的的依据,如表中的节点为0的(对应的)名称做表名。

节点为1的名称做列名。

 

 

麻烦你帮我做一下这个例子可以吗》?

 

一样的,狐表同样不支持纯数字做为列名。


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


加好友 发短信 一级勋章 三级勋章 二级勋章
等级:超级版主 帖子:6318 积分:33963 威望:0 精华:10 注册:2008/8/31 20:56:00
  发帖心情 Post By:2011/9/9 0:34:00 [显示全部帖子]

稍做了下修改。

唯一的缺憾是GetUniqueValues没有排序功能,所创建的列顺序会打乱。

 

 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:管理项目40.table


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


加好友 发短信 一级勋章 三级勋章 二级勋章
等级:超级版主 帖子:6318 积分:33963 威望:0 精华:10 注册:2008/8/31 20:56:00
  发帖心情 Post By:2011/9/9 0:49:00 [显示全部帖子]

改成这样吧。

 

Dim dr As DataRow = DataTables("基础设置").Find("节点 = 0")
Dim Name As String
If dr IsNot Nothing Then
    Name = dr("名称")
Else
    MessageBox.Show("未设置表名称!")
    Return
End If
For Each dt As DataTable In DataTables
    If dt.Name.Contains(Name) Then
        MessageBox.Show(Name & "表已经存在,不能重复创建!")
        Return
    End If
Next
Dim drs As List(Of DataRow) = DataTables("基础设置").Select("[名称] <> '" & Name & "'","_Identify")
Dim Builder As New ADOXBuilder
Builder.Open()
Dim tbl As ADOXTable = Builder.NewTable(Name)

For Each r As DataRow In drs
    If r.IsNull("字符长度") Then
        tbl.AddColumn(r("名称"),r("数据类型"))
    Else
        tbl.AddColumn(r("名称"),r("数据类型"),r("字符长度"))
    End If
Next
Builder.AddTable(tbl)
Builder.Close()
syscmd.Project.Open(ProjectFile)
MainTable = Tables(Name)


 回到顶部