pb 动态创建表字段、数据表

ybbuuuuss 2014-05-09 06:16:56
各位,请教。现想实现如下功能:
GRID类型的数据表里从某表中查询了50个字段,程序发放给客户,但可能客户那的数据表是旧版本的,字段可能只有30个,想动态的检测都少了哪些字段,然后动态的添加上。添加完之后再创建一个个自定义的数据表,字段及类型与这个这50个字段的表完全一样的(我是有其它的用处)。
请问各位高手,如何实现,请帮写一些代码,谢谢!
...全文
361 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
A啦Dbit 2014-05-12
  • 打赏
  • 举报
回复
咱用的方法就是每一个列都执行add一下
sbks 2014-05-12
  • 打赏
  • 举报
回复
查询数据库的系统表. sysobjects,该表包含了所有的数据库对象名,包括表,视图,存储过程等.syscolumns,该表包含了表对象的定义,包括字段定义以及字段的各种属性
ybbuuuuss 2014-05-12
  • 打赏
  • 举报
回复
两位好,主要是前期的判断没有呀,就是说判断都少了哪些字段呀(题目上写的,因为不同版本直接更新到最新版,所以少哪些字段不很确定,但程序里的GRID表格里确定了),不知道,我说的大家能明白不
WorldMobile 2014-05-12
  • 打赏
  • 举报
回复
1.需要你把最新的表保存在一个配置文件或者一个数据窗口里,然后在程序运行时,判断一下最新表里的字段在用户的数据库上是否有,如果没有,自动生成动态的SQL,然后动态执行。判断用户数据库上的字段是否有可以用系统表,也可以用 select * from table来动态创建一个数据窗口,然后再比对。 2.也可以不判断目前的结构,直接执行sql,如果alter table add column_nam varchar2(100)之类的,如果没有,会执行成功,如果有,会失败但不影响。 3.最重要的一点,数据结构改动后,后台的触发器和存储过程等可能会部分失效,需要重新编译
北京大丸子 2014-05-10
  • 打赏
  • 举报
回复
学习了,收藏
A啦Dbit 2014-05-09
  • 打赏
  • 举报
回复
引用 1 楼 xiajinxian 的回复:
sqlca.autocommit=true //自动提交,不能少 ls_sql="create table a( a int null ....) " //建表 execute immediate :ls_sql; if sqlca.sqlcode=-1 then messagebox('',sqlca.sqlerrtext) ls_sql="alter table a add b int null" //加字段 execute immediate :ls_sql; if sqlca.sqlcode=-1 then messagebox('',sqlca.sqlerrtext) sqlca.sqlautocommit=false
最好加上判断
A啦Dbit 2014-05-09
  • 打赏
  • 举报
回复
sqlca.autocommit=true //自动提交,不能少 ls_sql="create table a( a int null ....) " //建表 execute immediate :ls_sql; ls_sql="alter table a add b int null" //加字段 execute immediate :ls_sql; sqlca.sqlautocommit=false
Powerbuilder 9.0实用教程》源代码 1.本源代码包括以下章节源代码: 第01章 认识PowerBuilder 9.0、第05章 创建应用程序、第06章 创建窗体、第07章 创建菜单和工具栏、第10章 应用程序的调试和发布、第11章 典型小型实例赏析、第12章 图书管理系统实例和第13章 学生选课系统实例。 2.源代码使用方法参见《附录A 源代码的使用方法》文件。 __________________________________________________________________ 注意: 1.建议读者下载源文件后,将该源文件进行备份,读者使用副本源文件进行学习,这样一但出问题就不用再从网上下载了。 2.将源文件中“数据库文件”文件夹一定要复制到C盘根目录下,这样才能保证您连接数据库文件成功,具体方法参见《附录A 源代码的使用方法》。 对于书中源代码除了数据库外其他都能正常使用,而示例中数据库需要用户在自己的计算机上注册后才能使用,如果不注册数据源就运行应用程序是检索不到任何数据的,下面以连接学生选课系统数据库为例具体介绍如何连接数据库文件。 第1章 认识PowerBuilder 9.0 1 1.1 PowerBuilder 9.0简介 1 1.1.1 中国软件业现状 1 1.1.2 为什么要学习PowerBuilder 9.0 2 1.1.3 PowerBuilder的概述 2 1.1.4 PowerBuilder的特点 3 1.1.5 PowerBuilder 9.0的新特性 6 1.2 安装PowerBuilder 9.0软硬件需求 9 1.2.1 软件环境需求 9 1.2.2 硬件环境需求 9 1.3 PowerBuilder 9.0功能界面介绍 10 1.3.1 PowerBuilder 9.0界面简介 10 1.3.2 常用功能菜单 10 1.4 工作环境设置 16 1.4.1 工具栏的设置 16 1.4.2 窗口排列 19 1.4.3 快捷键设置 20 1.4.4 系统选项设置 21 1.5 用5分钟制作一个简单实例 22 1.5.1 实例运行界面 22 1.5.2 新建一个工作空间对象 22 1.5.3 新建一个应用程序对象 23 1.5.4 创建窗体 23 1.5.5 为应用程序添加open事件代码 25 1.6 小结 27 1.7 习题 27 第2章 编程基础知识 28 2.1 PowerScript脚本语言书写规则 28 2.1.1 忽略大小写 28 2.1.2 语句的断行、续行和分割 28 2.1.3 注释 29 2.2 数据类型 29 2.3 变量和作用域 30 2.3.1 定义变量 30 2.3.2 引用变量 30 2.3.3 变量的作用域 30 2.4 操作符 31 2.5 标识符 32 2.5.1 标识符的构成 32 2.5.2 匈牙利命名法 32 2.6 常用代词 33 2.7 控制语句 34 2.7.1 判断语句 34 2.7.2 循环语句 36 2.8 结构 38 2.8.1 创建结构 38 2.8.2 使用结构 40 2.9 函数 40 2.9.1 Open()和Close()函数 41 2.9.2 MessageBox()函数 41 2.9.3 类型转换函数 41 2.9.4 类型判断函数 42 2.9.5 其他函数 42 2.10 ODBC数据源与专用数据库接口 43 2.10.1 什么是ODBC数据源 43 2.10.2 专用数据库接口 43 2.10.3 连接数据库 44 2.10.4 配置ODBC 48 2.11 SQL语言 49 2.11.1 SQL语言的格式 49 2.11.2 在PowerBuilder 9中使用SQL语句 51 2.12 类和对象的概念 56 2.12.1 继承 57 2.12.2 重载和多态性 57 2.12.3 封装 57 2.12.4 属性、事件和函数 57 2.13 在PowerBuilder 9.0中实现面向对象编程 58 2.13.1 创建对象 58 2.13.2 设置对象属性 59 2.13.3 编写事件代码 59 2.13.4 实现继承对象 60 2.14 用户对象和用户事件 61 2.14.1 用户对象分类 61 2.14.2 定义用户对象 62 2.14.3 使用用户对象 64 2.14.4 用户事件 66 2.15 小结 67 2.16 习题 68 第3章 创建数据库 69 3.1 数

752

社区成员

发帖
与我相关
我的任务
社区描述
PowerBuilder 数据库相关
社区管理员
  • 数据库相关社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧