Oracle Metadata
http://www.devart.com/dotconnect/oracle/articles/metadata.html
http://dcx.sybase.com/1101/en/dbprogramming_en11/ianywhere-data-sqlanywhere-saconnection-getschem6330755502-0.html
Oracle SQL Developer
Toad DBA Suite for Oracle
http://software.dell.com/products/toad-dba-suite-for-oracle/
Oracle SQL Developer
http://www.oracle.com/technetwork/developer-tools/sql-developer/downloads/index.html
In this overload first parameter is name of a collection, and second
parameter is the array of restrictions to be applied when querying information.
Quantity of elements in the array must be less or equal to the value that is
returned by GetSchema() method in the second cell of the row that corresponds to
the collection name. (Or from the table below, which is much more handy.) If the
second argument is null (Nothing), the function behaves like the previous
overload (that takes a single parameter).
GetSchema Method Reference
| Collection Name | Number of restrictions | Remarks |
|---|---|---|
| MetaDataCollections | 0 | Returns this list. Same as using GetSchema() method without parameters. |
| ReservedWords | 0 | Lists all reserved words used in the server. |
| Users | 1 | Lists all users on the server. When restricted by username, returns information about specific user. |
| Tables | 2 | GetSchema("Tables") Returns the list of all tables on the server that you have access to. The first restriction for this collection is name of a schema. If specified, the method returns all tables within the schema. The second restriction is table name. Note that masks are not allowed in dotConnect for Oracle. |
| Views | 2 | GetSchema("Views") Returns the list of all views on the server that you have access to. The first restriction for this collection is name of a schema. If specified, the method returns all views within the schema. The second restriction is the name of the view. |
| Columns | 3 | Returns the list of columns, their type and some extra information. GetSchema("Columns") Returns the list of all columns in all schemas of the table. Restricted by schema name, the method returns all columns in the specified schema. The second restriction is name of a table that GetSchema method should search in. At last, you can specify column name. |
| Indexes | 4 | Returns the list of indexes and their details. The first restriction is name of a schema the indexes belongs to. The second restriction is name of the index. The third restriction is name of a table that uses the index. The last restriction is name of schema the table belongs to. |
| IndexColumns | 5 | Returns information about columns included in indexes. The following restrictions may be specified: Name of the schema for indexes; Index name; Name of the schema for tables; Table name; Column name. |
| Functions | 2 | Returns the list of functions on the server. The following restrictions may be specified: Schema name; Function name. |
| Procedures | 3 | Returns the list of procedures on the server. The following restrictions may be specified: Schema name; Package name; Procedure name. |
| Arguments | 4 | Returns the list of procedure and function arguments. The following restrictions may be specified: Schema name; Package name; Procedure name; Argument name. |
| Synonyms | 2 | Returns the list of synonyms on the server. The following restrictions may be specified: Schema name; Synonym name. |
| Sequences | 2 | Returns the list of sequences on the server. The following restrictions may be specified: Schema name; Sequence name. |
| Packages | 2 | Returns the list of packages on the server. The following restrictions may be specified: Schema name; Package name. |
| PackageBodies | 2 | Returns the list of package bodies on the server that you have access to. The following restrictions may be specified: Schema name; Package name. |
| ForeignKeys | 3 | Returns the list of foreign keys on the server. The following restrictions may be specified: Schema name; Key name; Table name. |
| ForeignKeyColumns | 3 | Returns the list of columns of foreign keys on the server. The following restrictions may be specified: Schema name; Key name; Table name. |
| Triggers | 2 | Returns the list of triggers on the server that you have access to. The following restrictions may be specified: Schema name; Trigger name. |
| Clusters | 2 | Returns the list of clusters on the server that you have access to. The following restrictions may be specified: Schema name; Cluster name. |
| TypeName | ProviderDbType | ColumnSize | CreateFormat | CreateParameters | DataType |
| BFILE | 1 | 4294967296 | BFILE | System.Byte[] | |
| BLOB | 2 | 4294967296 | BLOB | System.Byte[] | |
| CHAR | 3 | 2000 | CHAR({0}) | size | System.String |
| CLOB | 4 | 4294967296 | CLOB | System.String | |
| DATE | 6 | 19 | DATE | System.DateTime | |
| FLOAT | 29 | 38 | FLOAT | System.Decimal | |
| INTERVAL DAY TO SECOND | 7 | 0 | INTERVAL DAY({0}) TO SECOND({1}) | dayprecision,secondsprecision | System.TimeSpan |
| INTERVAL YEAR TO MONTH | 8 | 0 | INTERVAL YEAR({0}) TO MONTH | yearprecision | System.Int32 |
| LONG | 10 | 2147483647 | LONG | System.String | |
| LONG RAW | 9 | 2147483647 | LONG RAW | System.Byte[] | |
| NCHAR | 11 | 2000 | NCHAR({0}) | size | System.String |
| NCLOB | 12 | 4294967296 | NCLOB | System.String | |
| NUMBER | 13 | 38 | NUMBER ({0},{1}) | precision,scale | System.Decimal |
| NVARCHAR2 | 14 | 4000 | NVARCHAR2({0}) | size | System.String |
| RAW | 15 | 2000 | RAW({0}) | size | System.Byte[] |
| ROWID | 16 | 3950 | ROWID | System.String | |
| TIMESTAMP | 18 | 27 | TIMESTAMP({0}) | precision of fractional seconds | System.DateTime |
| TIMESTAMP WITH LOCAL TIME ZONE | 19 | 27 | TIMESTAMP({0} WITH LOCAL TIME ZONE) | precision of fractional seconds | System.DateTime |
| TIMESTAMP WITH TIME ZONE | 20 | 34 | TIMESTAMP({0} WITH TIME ZONE) | precision of fractional seconds | System.DateTime |
| VARCHAR2 | 22 | 4000 | VARCHAR2({0}) | size | System.String |
/// <summary>
/// 对于本文的Oracle安装来说,data source对应着Oracle_Client\oracle\ora92\network\admin\tnsnames.ora配置文件中的网络服务名
/// Data Source=(DESCRIPTION = (ADDRESS_LIST= (ADDRESS = (PROTOCOL = TCP)(HOST = geovin)(PORT = 1521))) (CONNECT_DATA = (SERVICE_NAME = geovindu)));user id=sysdba;password=0214;Persist Security Info=True;";
/// 涂聚文 20150516
/// </summary>
public partial class Form1 : Form
{
public string connectionString = @"Data Source=(DESCRIPTION = (ADDRESS_LIST= (ADDRESS = (PROTOCOL = TCP)(HOST = geovistu-xwvuyh)(PORT = 1521))) (CONNECT_DATA = (SERVICE_NAME = oracle9i)));user id=geovin;password=0214;Persist Security Info=True;";
/// <summary>
///
/// </summary>
/// <returns></returns>
DataTable setDatat()
{
DataTable dt = new DataTable();
dt.Columns.Add("id", typeof(int));
dt.Columns.Add("name", typeof(string));
dt.Rows.Add(1, "Procedures");
dt.Rows.Add(2, "DataTypes");
dt.Rows.Add(3, "Foreign Keys");
dt.Rows.Add(4, "Databases");
dt.Rows.Add(5, "dbo");
dt.Rows.Add(6, "Arguments");
dt.Rows.Add(7, "Collection Name");
dt.Rows.Add(8, "DatasourceInformation");
dt.Rows.Add(9, "MetaDataCollections");
dt.Rows.Add(10, "ForeignKeyColumns");
dt.Rows.Add(11, "Functions");
dt.Rows.Add(12, "IndexColumns");
dt.Rows.Add(13, "Indexes");
dt.Rows.Add(14, "PrimaryKeys");
dt.Rows.Add(15, "ReservedWords");
dt.Rows.Add(16, "Restrictions");
dt.Rows.Add(17, "Triggers");
dt.Rows.Add(18, "UDFs");
dt.Rows.Add(19, "UniqueKeys");
dt.Rows.Add(20, "UserPrivileges");
dt.Rows.Add(21, "Users");
dt.Rows.Add(22, "ViewColumns"); //DataTable dt = connection.GetSchema("Tables", strRestricted);
dt.Rows.Add(23, "Tables");
dt.Rows.Add(24, "Columns");//表的列的详细,有主键TABLE_CATALOG,TABLE_SCHEMA,TABLE_NAME,COLUMN_NAME,ORDINAL_POSITION,COLUMN_DEFAULT,IS_NULLABLE,DATA_TYPE,CHARACTER_MAXIMUM_LENGTH,NUMERIC_PRECISION,NUMERIC_SCALE,DATETIME_PRECISION,CHARACTER_SET_NAME,COLLATION_NAME,COLUMN_TYPE,COLUMN_KEY,EXTRA,PRIVILEGES,COLUMN_COMMENT
dt.Rows.Add(25, "Views");
dt.Rows.Add(26, "Indexes");//表的列
dt.Rows.Add(27, "IndexColumns");//主键 return dt;
}
/// <summary>
///
/// </summary>
public Form1()
{
InitializeComponent();
} /// <summary>
///
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void Form1_Load(object sender, EventArgs e)
{
this.txtConnection.Text = connectionString;
this.comboBox1.DataSource = setDatat();
this.comboBox1.DisplayMember = "name";
this.comboBox1.ValueMember = "id";
} /// <summary>
///
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void button1_Click(object sender, EventArgs e)
{
try
{
using (OracleConnection connection = new OracleConnection(connectionString))
{
connection.Open();
//MessageBox.Show(connection.State.ToString());
DataTable dt = connection.GetSchema(this.comboBox1.Text.Trim());
this.dataGridView1.DataSource = dt;
this.textBox1.Text = GetColumnNames(dt); }
}
catch (Exception ex)
{
MessageBox.Show(ex.Message.ToString());
ex.Message.ToString();
}
}
/// <summary>
///
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void button2_Click(object sender, EventArgs e)
{
string connString = "Provider=OraOLEDB.Oracle.1;User ID=geovin;Password=0214;Data Source=(DESCRIPTION = (ADDRESS_LIST= (ADDRESS = (PROTOCOL = TCP)(HOST = geovistu-xwvuyh)(PORT = 1521))) (CONNECT_DATA = (SERVICE_NAME = oracle9i)))";
OleDbConnection conn = new OleDbConnection(connString);
try
{
conn.Open();
//MessageBox.Show(conn.State.ToString());
DataTable dt = conn.GetSchema(this.comboBox1.Text.Trim());
this.dataGridView1.DataSource = dt;
this.textBox1.Text = GetColumnNames(dt);
}
catch (Exception ex)
{
MessageBox.Show(ex.Message.ToString());
}
finally
{
conn.Close();
}
}
用
using Oracle.DataAccess.Client;
MetaDataCollections
DataSourceInformation
DataTypes
Restrictions
ReservedWords
Users
Tables
Columns
Views
Synonyms
Sequences
Functions
Procedures
Packages
PackageBodies
IndexColumns
Indexes
ProcedureParameters
Arguments
UniqueKeys
PrimaryKeys
ForeignKeys
ForeignKeyColumns
JavaClasses
XMLSchemas
Oracle Metadata的更多相关文章
- Oracle Metadata Management (OMM)元数据管理 12.2.1发布
元数据管理元数据管理是解决大量关键业务和技术挑战的基础,这些挑战包括元数据实体有多少,上游数据变化的影响,在浏览器中提供友好的分析展现界面,或提供企业范围内的元数据现状分析和改进视图.OMM是一款基于 ...
- [Oracle][Metadata]如何查找与某一个功能相关的数据字典名
当Oracel的一个新功能出来的时候,我们可能不知道所有与此功能关联的数据字典名称,那么如何才能得到这些 meta data 的 meta data 呢? 可以通过 dicitonary 来查看: 例 ...
- ssma for oracle
SQL Server Migration Assistant (SSMA) for Oracle lets you quickly convert Oracle database schemas to ...
- 使用Microsoft SQL Server Migration Assistant for Oracle迁移数据库
前言:使用Microsoft SQL Server Migration Assistant for Oracle迁移Oracle数据库到SqlServer数据库. 准备:Oracle11g.SqlSe ...
- Oracle ADF 开发必读
MARK:http://www.oracle.com/technetwork/cn/articles/adf/index-086064-zhs.html 第 1 部分- 借助 Subversion 进 ...
- Oracle Enterprise Metadata Management (简称OEMM,Oracle元数据管理)12.1.3.0.1已经发布
在数据处理及数据仓库建设中,元数据管理是必不可少的,OEMM可以解决元数据管理过程中各种关键业务问题和技术挑战,其中包括如何元数据的统计信息,了解变更数据之后对下游的影响范围,而且OEMM站在业务的角 ...
- Oracle简单常用的数据泵导出导入(expdp/impdp)命令举例(下)
<Oracle简单常用的数据泵导出导入(expdp/impdp)命令举例(上)> <Oracle简单常用的数据泵导出导入(expdp/impdp)命令举例(下)> 目的:指导项 ...
- Oracle导出excel
oracle导出excel(非csv)的方法有两种,1.使用sqlplus spool,2.使用包体 现将网上相关代码整理后贴出以备不时之需: 使用sqlplus: 使用sqlplus需要两个文件: ...
- MySQL 之 Metadata Locking 研究
MySQL5.5 中引入了 metadata lock. 顾名思义,metadata lock 不是为了保护表中的数据的,而是保护 database objects(元数据)的.包括表结构.schem ...
随机推荐
- 2019年北航OO第二次博客总结
一.多线程电梯系列作业设计策略 1. 第一次作业——"FAFS傻瓜电梯" 第一次作业是先来先服务的"傻瓜电梯",我当时觉得这个设计未免太简单了,于是就在傻瓜电梯 ...
- FlowPortal-BPM——管理员、功能的权限设置
一.管理员设置 管理工具→安全组→安全组名称→管理授权→[添加管理人员]→[设置管理人员权限] 二.访问功能权限设置 (1)模块访问权限 (2)访问控制→[在需要的文件夹下]新建子资源→[资源名称]. ...
- 阿里云服务器18个数据中心测试IP地址以及测试方法
我们用户在选择阿里云服务器的时候是不是感觉阿里云的数据中心太多太多,确实阿里云服务器机房是有很多,国外国外机房大约有18个,甚至更多,因为还在不断的增加机房.对于商家而言增加不同的机房可以满足不同的项 ...
- Python turtle库学习笔记
1.简介 Python的turtle库的易操作,对初学者十分友好.对于初学者来说,刚学编程没多久可以写出许多有趣的可视化东西,这是对学习编程极大的鼓舞,可以树立对编程学习的信心.当然turtle本身也 ...
- 收集vcftools所有用法
VCFtools用来处理VCF文档. 筛选特定突变 比较文件 总结突变 转化文件格式 验证并合并文件 取突变交集和差集 Get basic file statistics input可以为VCF或BC ...
- Universal-Image-Loader完全解析(下)
Universal-Image-Loader完全解析(下) 在这篇文章中,我会继续跟大家分享有关于Universal-Image-Loader框架的相关知识,这次主要分享的是框架中图片缓存方面的知识. ...
- wap 往下拉自动加载更多数据
var stop=true; $(window).scroll(function(){ totalheight = parseFloat($(window).height()) + parseFloa ...
- ifram的使用 左边是<a>链接 右边是对应网页嵌套的显示网页链接内容 和toggle的收放用法
1.ifram的使用 左边是<a>链接 右边是对应网页嵌套的显示网页链接内容 <div class="container"> <div class= ...
- Js 中的false,零值,null,undefined和空字符串对象
转自 http://www.imkevinyang.com/2009/07/javascript-中的false零值nullundefined和空字符串对象.html 在Javascript中,我们 ...
- orcale 之sql/plus set 命令
set 命令用于设置系统变量的值.通过set 命令设置的系统变量有很多,下面把最常用的罗列出来: 1. arraysize 用于从数据库中一次提取的行数,其默认为 15. SQL> show a ...