首页 数据库 mysql教程 MyGeneration获取所有ORACLE数据库的数据库名数据表命列名称

MyGeneration获取所有ORACLE数据库的数据库名数据表命列名称

Jun 07, 2016 pm 03:02 PM
oracle 数据库 获取

使用MyGeneration自动生成代码工具获取所有ORACLE数据库的数据库名数据表命列名称的具体操作步骤如下: 一、设置MyGeration的Default Settings中的数据库链接字符串Provider=OraOLEDB.Oracle.1;Password=myPassword;Persist Security Info=True;User ID=myID

使用MyGeneration自动生成代码工具获取所有ORACLE数据库的数据库名数据表命列名称的具体操作步骤如下:
一、设置MyGeration的Default Settings中的数据库链接字符串Provider=OraOLEDB.Oracle.1;Password=myPassword;Persist Security Info=True;User ID=myID;Data Source=myDataSource
二、复制下面代码到Interface Code选项卡的窗体中

public class GeneratedGui : DotNetScriptGui
{
 public GeneratedGui(ZeusContext context) : base(context) {}

 //-----------------------------------------
 // The User Interface Entry Point
 //-----------------------------------------
 public override void Setup()
 {
  // ** UNCOMMENT CODE BELOW TO SEE UI **

  //ui.Width  = 100;
  //ui.Height = 100;
  //GuiLabel lblDemo = ui.AddLabel("lblDemo", "Demo", "Demo Tooltip");
  //ui.ShowGui = true;
  
  //GuiLabel lblPath;
  //GuiTextBox txtNamespace;
  GuiComboBox cmbDatabase;
  GuiComboBox cmbTable;
  GuiComboBox cmbColumn;
 
  ui.Title = "读取所有数据表";
  ui.Width  = 450;
  ui.Height = 500;
  ui.BackColor = "wheat";
  ui.ShowGui = true;
  //添加窗体控件
  ui.AddLabel("lblPath","输出路径: ","Select the output path."); 
  string sOutputPath = "";   
  if( input.Contains("defaultOutputPath"))
  {
   sOutputPath = input["defaultOutputPath"].ToString();
  }
  //输出文件保存路径
  ui.AddTextBox("txtPath", sOutputPath, "Select the Output Path.");
  ui.AddFilePicker("btnPath", "选择路径", "Select the Output Path.", "txtPath", true);
  //程序命名空间
  ui.AddLabel("lblNamespace", "命名空间: ",  "Provide your objects namespace.");
  ui.AddTextBox("txtNamespace", "ZTE.TMobileUpdate", "Provide your objects namespace."); 
  //数据库下拉框
  ui.AddLabel("lblDatabases", "数据库选择:", "Select a database in the dropdown below.");
  cmbDatabase=ui.AddComboBox("cmbDatabase", "Select a database.");
  setupDatabaseDropdown(cmbDatabase);
  cmbDatabase.AttachEvent("onchange","cmbDatabase_onchange");
  //数据表选择
  ui.AddLabel("lblTables", "数据表选择:", "Select tables from the listbox below.");
  cmbTable = ui.AddComboBox("cmbTable", "Select tables:");
  setupTablesDropdown(cmbDatabase,cmbTable);
  cmbTable.AttachEvent("onchange","cmbTable_onchange");
  //视图选择
  ui.AddLabel("lblColumns", "字段选择:", "Select columns from the listbox below.");
  cmbColumn = ui.AddComboBox("cmbColumn", "Select columns:");
  
 }
 
 public void setupDatabaseDropdown( GuiComboBox Databases )
 {
  try
  { 
   if( MyMeta.IsConnected )
   {
    Databases.BindData( MyMeta.Databases );
    //判断数据库列表是否为空
    if( MyMeta.DefaultDatabase != null )
    {
     Databases.SelectedValue = MyMeta.DefaultDatabase.Alias;
     bindTables( Databases.SelectedValue );
    }
   }
  }
  catch
  {
  }
 }
 public void setupTablesDropdown(GuiComboBox Databases,GuiComboBox Tables)
 {
  try
  { 
   if( MyMeta.IsConnected )
   {
    //判断数据表列表是否为空
    if((Databases.SelectedValue != null)&&(Tables.SelectedValue != null))
    {
     bindColumns(Databases.SelectedValue,Tables.SelectedValue);
    }    
   }
  }
  catch
  {
  }
 }
 
 //数据库切换事件
 public void cmbDatabase_onchange( GuiComboBox control )
 {
  GuiComboBox cmbDatabases = ui["cmbDatabase"] as GuiComboBox; 
  bindTables( cmbDatabases.SelectedText );
 }
 //数据表切换事件
 public void cmbTable_onchange( GuiComboBox control )
 {
  GuiComboBox cmbDatabases = ui["cmbDatabase"] as GuiComboBox;
  GuiComboBox cmbTable = ui["cmbTable"] as GuiComboBox; 
  bindColumns(cmbDatabases.SelectedText, cmbTable.SelectedText);
 }
 
 public void bindTables( string sDatabase )
 { 
  try
  { 
   IDatabase db = MyMeta.Databases[sDatabase];
   GuiComboBox cmbTable = ui["cmbTable"] as GuiComboBox;
   cmbTable.BindData( db.Tables );
  }
  catch
  {
  }
 }
 
 public void bindColumns( string sDatabase,string sTable )
 { 
  try
  { 
   IDatabase db = MyMeta.Databases[sDatabase];
   ITable objTable=db.Tables[sTable];
   GuiComboBox cmbColumn = ui["cmbColumn"] as GuiComboBox;
   cmbColumn.BindData( objTable.Columns );
  }
  catch
  {
  }
 } 
}
三、复制下面代码到Template Code选项卡的窗体中
public class GeneratedTemplate : DotNetScriptTemplate
{
 public GeneratedTemplate(ZeusContext context) : base(context) {}

 //---------------------------------------------------
 // Render() is where you want to write your logic   
 //---------------------------------------------------
 public override void Render()
 {   
  if(context.Objects.ContainsKey("DnpUtils"))
  {
   DnpUtils.SaveInputToCache(context);
  }  
  string strFilenameBase = input["txtPath"].ToString();
  string strNamespace = input["txtNamespace"].ToString();
  string strDatabaseName  = input["cmbDatabase"].ToString();
  string strTableName  = input["cmbTable"].ToString();
  string strColumnName  = input["cmbColumn"].ToString();
  
  output.writeln("输出文件路径:"+strFilenameBase);
  output.writeln("命名空间名称:"+strNamespace);
  output.writeln("当前数据库名称:"+strDatabaseName);
  output.writeln("当前数据表名称:"+strTableName);
  output.writeln("当前选择列名称:"+strColumnName);
  GetAllDataBaseName();    
 }
 //输出所有的数据库名称
 private void GetAllDataBaseName()
 {
  foreach( IDatabase d in MyMeta.Databases )
   {
    GetAllTablesName(d.Alias);
   }  
 }
 //输出所有的数据表名称
 private void GetAllTablesName(string sDatabase)
 {  
  IDatabase objDatabase = MyMeta.Databases[sDatabase];
  output.writeln("当前数据库:"+sDatabase+"共有数据表总数:"+objDatabase.Tables.Count);
  foreach( ITable t in objDatabase.Tables )
   {
    GetAllColumnsName(sDatabase,t.Alias);
   }
 }
 private void GetAllColumnsName(string sDatabase,string sTable)
 {
  IDatabase objDatabase = MyMeta.Databases[sDatabase];
  ITable objTable=objDatabase.Tables[sTable];
  output.writeln("当前数据表:"+sTable+"共有数据列总数:"+objTable.Columns.Count);
  foreach( IColumn c in objTable.Columns )
   {
    if( c.IsInPrimaryKey )
    {
     output.writeln("主键名称:"+c.Alias);
    }
    else
    {
     output.writeln("普通列名:"+c.Alias);
    }
   }
 }

}
%>
四、点菜单上的运行箭头按钮,在Output选项卡的窗体中显示所有结果

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Java教程
1663
14
CakePHP 教程
1420
52
Laravel 教程
1315
25
PHP教程
1266
29
C# 教程
1239
24
MySQL:世界上最受欢迎的数据库的简介 MySQL:世界上最受欢迎的数据库的简介 Apr 12, 2025 am 12:18 AM

MySQL是一种开源的关系型数据库管理系统,主要用于快速、可靠地存储和检索数据。其工作原理包括客户端请求、查询解析、执行查询和返回结果。使用示例包括创建表、插入和查询数据,以及高级功能如JOIN操作。常见错误涉及SQL语法、数据类型和权限问题,优化建议包括使用索引、优化查询和分表分区。

为什么要使用mysql?利益和优势 为什么要使用mysql?利益和优势 Apr 12, 2025 am 12:17 AM

选择MySQL的原因是其性能、可靠性、易用性和社区支持。1.MySQL提供高效的数据存储和检索功能,支持多种数据类型和高级查询操作。2.采用客户端-服务器架构和多种存储引擎,支持事务和查询优化。3.易于使用,支持多种操作系统和编程语言。4.拥有强大的社区支持,提供丰富的资源和解决方案。

oracle怎么循环创建游标 oracle怎么循环创建游标 Apr 12, 2025 am 06:18 AM

Oracle 中,FOR LOOP 循环可动态创建游标, 步骤为:1. 定义游标类型;2. 创建循环;3. 动态创建游标;4. 执行游标;5. 关闭游标。示例:可循环创建游标,显示前 10 名员工姓名和工资。

HDFS配置CentOS需要哪些步骤 HDFS配置CentOS需要哪些步骤 Apr 14, 2025 pm 06:42 PM

在CentOS系统上搭建Hadoop分布式文件系统(HDFS)需要多个步骤,本文提供一个简要的配置指南。一、前期准备安装JDK:在所有节点上安装JavaDevelopmentKit(JDK),版本需与Hadoop兼容。可从Oracle官网下载安装包。环境变量配置:编辑/etc/profile文件,设置Java和Hadoop的环境变量,使系统能够找到JDK和Hadoop的安装路径。二、安全配置:SSH免密登录生成SSH密钥:在每个节点上使用ssh-keygen命令

oracle日志写满怎么办 oracle日志写满怎么办 Apr 12, 2025 am 06:09 AM

Oracle 日志文件写满时,可采用以下解决方案:1)清理旧日志文件;2)增加日志文件大小;3)增加日志文件组;4)设置自动日志管理;5)重新初始化数据库。在实施任何解决方案前,建议备份数据库以防数据丢失。

MySQL与其他数据库:比较选项 MySQL与其他数据库:比较选项 Apr 15, 2025 am 12:08 AM

MySQL适合Web应用和内容管理系统,因其开源、高性能和易用性而受欢迎。1)与PostgreSQL相比,MySQL在简单查询和高并发读操作上表现更好。2)相较Oracle,MySQL因开源和低成本更受中小企业青睐。3)对比MicrosoftSQLServer,MySQL更适合跨平台应用。4)与MongoDB不同,MySQL更适用于结构化数据和事务处理。

甲骨文在商业世界中的作用 甲骨文在商业世界中的作用 Apr 23, 2025 am 12:01 AM

Oracle不仅是数据库公司,还是云计算和ERP系统的领导者。1.Oracle提供从数据库到云服务和ERP系统的全面解决方案。2.OracleCloud挑战AWS和Azure,提供IaaS、PaaS和SaaS服务。3.Oracle的ERP系统如E-BusinessSuite和FusionApplications帮助企业优化运营。

oracle数据库怎么停止 oracle数据库怎么停止 Apr 12, 2025 am 06:12 AM

要停止 Oracle 数据库,请执行以下步骤:1. 连接到数据库;2. 优雅关机数据库(shutdown immediate);3. 完全关机数据库(shutdown abort)。

See all articles