Home Database Mysql Tutorial MyGeneration获取所有ORACLE数据库的数据库名数据表命列名称

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

Jun 07, 2016 pm 03:02 PM
oracle database Obtain

使用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选项卡的窗体中显示所有结果

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Hot Topics

Java Tutorial
1664
14
PHP Tutorial
1266
29
C# Tutorial
1239
24
MySQL: An Introduction to the World's Most Popular Database MySQL: An Introduction to the World's Most Popular Database Apr 12, 2025 am 12:18 AM

MySQL is an open source relational database management system, mainly used to store and retrieve data quickly and reliably. Its working principle includes client requests, query resolution, execution of queries and return results. Examples of usage include creating tables, inserting and querying data, and advanced features such as JOIN operations. Common errors involve SQL syntax, data types, and permissions, and optimization suggestions include the use of indexes, optimized queries, and partitioning of tables.

Why Use MySQL? Benefits and Advantages Why Use MySQL? Benefits and Advantages Apr 12, 2025 am 12:17 AM

MySQL is chosen for its performance, reliability, ease of use, and community support. 1.MySQL provides efficient data storage and retrieval functions, supporting multiple data types and advanced query operations. 2. Adopt client-server architecture and multiple storage engines to support transaction and query optimization. 3. Easy to use, supports a variety of operating systems and programming languages. 4. Have strong community support and provide rich resources and solutions.

How to create cursors in oracle loop How to create cursors in oracle loop Apr 12, 2025 am 06:18 AM

In Oracle, the FOR LOOP loop can create cursors dynamically. The steps are: 1. Define the cursor type; 2. Create the loop; 3. Create the cursor dynamically; 4. Execute the cursor; 5. Close the cursor. Example: A cursor can be created cycle-by-circuit to display the names and salaries of the top 10 employees.

What steps are required to configure CentOS in HDFS What steps are required to configure CentOS in HDFS Apr 14, 2025 pm 06:42 PM

Building a Hadoop Distributed File System (HDFS) on a CentOS system requires multiple steps. This article provides a brief configuration guide. 1. Prepare to install JDK in the early stage: Install JavaDevelopmentKit (JDK) on all nodes, and the version must be compatible with Hadoop. The installation package can be downloaded from the Oracle official website. Environment variable configuration: Edit /etc/profile file, set Java and Hadoop environment variables, so that the system can find the installation path of JDK and Hadoop. 2. Security configuration: SSH password-free login to generate SSH key: Use the ssh-keygen command on each node

What to do if the oracle log is full What to do if the oracle log is full Apr 12, 2025 am 06:09 AM

When Oracle log files are full, the following solutions can be adopted: 1) Clean old log files; 2) Increase the log file size; 3) Increase the log file group; 4) Set up automatic log management; 5) Reinitialize the database. Before implementing any solution, it is recommended to back up the database to prevent data loss.

Oracle's Role in the Business World Oracle's Role in the Business World Apr 23, 2025 am 12:01 AM

Oracle is not only a database company, but also a leader in cloud computing and ERP systems. 1. Oracle provides comprehensive solutions from database to cloud services and ERP systems. 2. OracleCloud challenges AWS and Azure, providing IaaS, PaaS and SaaS services. 3. Oracle's ERP systems such as E-BusinessSuite and FusionApplications help enterprises optimize operations.

MySQL vs. Other Databases: Comparing the Options MySQL vs. Other Databases: Comparing the Options Apr 15, 2025 am 12:08 AM

MySQL is suitable for web applications and content management systems and is popular for its open source, high performance and ease of use. 1) Compared with PostgreSQL, MySQL performs better in simple queries and high concurrent read operations. 2) Compared with Oracle, MySQL is more popular among small and medium-sized enterprises because of its open source and low cost. 3) Compared with Microsoft SQL Server, MySQL is more suitable for cross-platform applications. 4) Unlike MongoDB, MySQL is more suitable for structured data and transaction processing.

How to stop oracle database How to stop oracle database Apr 12, 2025 am 06:12 AM

To stop an Oracle database, perform the following steps: 1. Connect to the database; 2. Shutdown immediately; 3. Shutdown abort completely.

See all articles