データベース -----カタログとスキーマの設計の違いと、すべてのデータベース テーブルを取得するための実際の使用法 java jdbc php c#.Net
1. -catalog とスキーマの設計の違い 1
2. データベースのメタ情報を取得するいくつかの方法 2
2.1. mysql のメタテーブル information_schema、mssql の SysDatabases を直接読み取る 3
2.2 . jdbc などの共通インターフェイスを使用します 3
2.3. mysql の mysql_list_dbs など、データベースによって個別に提供されるドライバー インターフェイスを使用します 3
3. データベース内のすべてのデータベースを取得します mysql List getCatalogs 3
3.1. データベース内のすべてのデータベースをスキャンします 3
3.2. Php バージョン mysql_list_dbs() 4
3.3.ネットバージョン SysDatabases 4
3.4。 Net バージョン // OleDbConnection の GetOleDbSchemaTable を使用してデータベースの構造を取得します 4
4. データベースのすべてのテーブルを取得します getTables 4
4.1. Php 実装 mysql_list_tables 5
4.2.ネットバージョン SysObjects の読み取り 表 5
5. 参考資料 5
SQL 標準の解釈によると、SQL 環境におけるカタログスキーマとスキーマはどちらも抽象的な概念であり、データベース オブジェクトの名前空間のコンテナまたはレベルとして理解でき、主に名前の競合を解決するために使用されます。概念的には、データベース システムには複数のカタログが含まれ、各カタログには複数のスキーマが含まれ、各スキーマには複数のデータベース オブジェクト (テーブル、ビュー、フィールドなど) が含まれます。また、データベース オブジェクトはスキーマに属している必要があり、そのスキーマも属している必要があります。これにより、データベース オブジェクトの完全修飾名を取得して、名前の競合の問題を解決できます。たとえば、データベース オブジェクト テーブルの完全修飾名は、カタログ名.スキーマ名のように表現できます。ここでもう 1 つ注意すべき点は、SQL 標準では、ドメイン名と同様に、各データベース オブジェクトの完全修飾名が一意であることを要求していないことです。必要に応じて、各 IP アドレスに複数のドメイン名を付けることができます。
実装の観点から見ると、さまざまなデータベース システムにおけるカタログとスキーマのサポートと実装方法は大きく異なります。特定の問題については、比較的単純で一般的な実装方法を参照する必要があります。データベース名をカタログ名として使用し、ユーザー名をスキーマ名として使用します。詳細については、次の表を参照してください。
表 1 一般的に使用されるデータベース
| カタログ サポート | スキーマ サポート | ||||||||||||||||||||||||
Oracle | サポートされていません | Oracle ユーザー ID | ||||||||||||||||||||||||
サポートされていません | データベース名 | |||||||||||||||||||||||||
MS SQL Server | データベース名 | オブジェクト所有者名、バージョン 2005 以降変更されました td> | ||||||||||||||||||||||||
DB2 | データベースオブジェクトを指定する場合、カタログ部分は省略されます | カタログ所有者名 | ||||||||||||||||||||||||
Sybase | データベース名 | データベース所有者名|||||||||||||||||||||||||
Informix | サポートされていません | 不要 | ||||||||||||||||||||||||
PointBase | サポートされていません td> | データベース名 |
著者:: ニックネーム: Laowa’s Claw (フルネーム:: Attilax Akbar al Rapanui) 中国語名: Ailong、EMAIL:1466519819@qq.com
転載の際は出典を明記してください: http://www .cnblogs.com/attilax/
データベースからテーブル情報を読み取る方法は次のとおりです。
ここでは、DatabaseMetaData クラスに依存します。このオブジェクトはデータベース接続から取得できます。これですべてがうまくいきます。何か知りたいことがあれば聞いてください:
DatabaseMetaData databaseMetaData = conn.getMetaData();
//すべてのテーブルを取得します ResultSet tableSet = databaseMetaData.getTables (null, " %", "%", new String[]{"TABLE"});
//tableName テーブルの列情報を取得 ResultSet columnSet = databaseMetaData.getColumns(null, "%", tableName, "%") ;
[
{"TABLE_CAT": "information_schema"},
{"TABLE_CAT": "8kbl"},
{"TABLE_CAT": "atiposdb"},
{"TABLE_CAT": "cear"},
{"TABLE_CAT": "ecmdb"},
{"TABLE_CAT": "hxtaxi "},
{"TABLE_CAT": "iwbm2"},
{"TABLE_CAT": "iwmshop"},
{ "TABLE_CAT": "iwmshopnow"} 、
{"TABLE_CAT": "limesurvey"}、
{"TABLE_CAT": "mysql"}、
{"TABLE_CAT ": "パフォーマンススキーマ"},
{"TABLE_CAT": "shopedb"},
{"TABLE_CAT": "shopnc"},
{"TABLE_CAT": "テスト"},
{"TABLE_CAT": "timerdb"},
{"TABLE_CAT": "vod2"},
{"TABLE_CAT": "wechatdb "},
{"TABLE_CAT": "wordpress"},
{"TABLE_CAT": "wxb_site_new"},
{"TABLE_CAT": "wxmiqi"} ,
{ "TABLE_CAT": "zuche5"}
]
getSchemas が空です。 。
$dbs = mysql_list_dbs(); //mysql_list_dbs 関数を呼び出します
1. すべてのデータベース名を取得します: (1)、名前を FROM Master.dbo.SysDatabases または DER BY 名前
DatabaseMetaData dbmd = dbx .getConnection().getMetaData(); 🎜 >
//databaseMetaData.getColumns(localCatalog, localSchema,// localTableName, null);
ResultSet rs = dbmd .getTables( "atiposdb" , "%" , " % " , new String[]{ "TABLE" });
[
{
"TABLE_NAME": "アプリケーション",
"REMARKS " : "",
"TABLE_TYPE": "TABLE",
"TABLE_SCHEM": null,
"TABLE_CAT": "atiposdb"
} ,
{
"TABLE_NAME": "属性",
"REMARKS": "",
"TABLE_TYPE": "テーブル",
"TABLE_SCHEM": null,
"TABLE_CAT": "atiposdb"
},
4.1. Php mysql_list_tables の実装
mysql_list_tables -- MySQL データベース内のテーブルをリストします
2. すべてのテーブル名を取得します: (1)、名前を FROM SysObjects Where XType='U' orDER BY 名
asp.net は、すべての SQL データベース名、すべてのテーブル名、すべてのフィールド名、列の説明を取得します - XMM_1030 のコラム - ブログ チャネル - データベース内のすべてのテーブル名を取得する CSDN.NET.htm
.NET メソッド (再版) ) - guoxuefeng - Blog Garden.htm
ODBC、OLEDB、ADO、ADO.Net の進化の簡単な歴史 - BobLiu - Blog Garden.htm