Rss & SiteMap

Foxtable(狐表) http://www.foxtable.com

新一代数据库软件,完美融合Access、Foxpro、Excel、vb.net之优势,人人都能掌握的快速软件开发工具!
共9 条记录, 每页显示 10 条, 页签: [1]
[浏览完整版]

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

1楼
kevin 发表于:2011/9/8 23:55:00

表A中,有‘节点’和'名称'列,

 

'节点'列的数据如下:0、1;希望通过点击按钮,实现:以节点为0的名称作表名,以节点为1的名称为列名;

备注:点击创建表以后,表A的数据清空

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

2楼
czy 发表于:2011/9/9

肯定可以。

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

3楼
kevin 发表于:2011/9/9 0:02:00

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

节点为1的名称做列名。

 

 

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

4楼
czy 发表于:2011/9/9 0:05:00

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

 

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

 

 

 

 

5楼
czy 发表于:2011/9/9 0:06:00
以下是引用kevin在2011-9-9 0:02:00的发言:

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

节点为1的名称做列名。

 

 

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

 

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

6楼
kevin 发表于:2011/9/9 0:09:00

我有下载,但是我的表需要加上条件:节点为0 的做表名,节点为1的做列名。

这个我做不来,还请老师帮忙一下,对了,我忘记加上字符长度的列了,呵呵

7楼
czy 发表于:2011/9/9 0:34:00

稍做了下修改。

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

 

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

8楼
czy 发表于: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)

9楼
涛声依旧5666 发表于:2011/9/12 14:45:00

For Each dt As DataTable In DataTables
If dt.Name.Contains(Name) Then
MessageBox.Show(Name & "表已经存在,不能重复创建!")
Return
End If
Next
 

改成以下代码更好:

 

If  DataTables.Contains(Name) Then
        MessageBox.Show(Name & "表已经存在,不能重复创建!")
        Return
End If

共9 条记录, 每页显示 10 条, 页签: [1]

Copyright © 2000 - 2018 foxtable.com Tel: 4000-810-820 粤ICP备11091905号

Powered By Dvbbs Version 8.3.0
Processed in .03906 s, 4 queries.