データベース -----カタログとスキーマの設計の違いと、すべてのデータベース テーブルを取得するための実際の使用法 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
1. -カタログとスキーマの設計の違い
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, "%") ;
2. データベースのメタ情報を取得するいくつかの方法
2.1. mysql のメタテーブル information_schema、mssql の SysDatabase を直接読み取る
2.2. jdbc インターフェイス
などのツール 2.3. mysql の mysql_list_dbs
など、データベースによって別途提供されるドライバー インターフェイスを使用します。 3. データベース内のすべてのデータベース リストを取得します。 mysql getCatalogs
3.1. データベース内のすべてのデータベースを走査する
[
{"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 が空です。 。
3.2. PHP バージョン mysql_list_dbs()
$dbs = mysql_list_dbs(); //mysql_list_dbs 関数を呼び出します
3.3.ネットバージョン SysDatabases
1. すべてのデータベース名を取得します: (1)、名前を FROM Master.dbo.SysDatabases または DER BY 名前
から選択します。 Net バージョン // OleDbConnection の GetOleDbSchemaTable を使用してデータベースの構造を取得します
4. データベースのすべてのテーブルを取得します getTables
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 の実装
(PHP 3, PHP 4, PHP 5)
mysql_list_tables -- MySQL データベース内のテーブルをリストします
4.2.ネットバージョン SysObjects テーブルを読み取ります
2. すべてのテーブル名を取得します: (1)、名前を FROM SysObjects Where XType='U' orDER BY 名
5. 参照
asp.net は、すべての SQL データベース名、すべてのテーブル名、すべてのフィールド名、列の説明を取得します - XMM_1030 のコラム - ブログ チャネル - データベース内のすべてのテーブル名を取得する CSDN.NET.htm
.NET メソッド (再版) ) - guoxuefeng - Blog Garden.htm
ODBC、OLEDB、ADO、ADO.Net の進化の簡単な歴史 - BobLiu - Blog Garden.htm

多くの場合、キーワードと追跡パラメーターで散らかった長いURLは、訪問者を阻止できます。 URL短縮スクリプトはソリューションを提供し、ソーシャルメディアやその他のプラットフォームに最適な簡潔なリンクを作成します。 これらのスクリプトは、個々のWebサイトにとって価値があります

2012年のFacebookによる有名な買収に続いて、Instagramはサードパーティの使用のために2セットのAPIを採用しました。これらはInstagramグラフAPIとInstagram Basic Display APIです。

Laravelは、直感的なフラッシュメソッドを使用して、一時的なセッションデータの処理を簡素化します。これは、アプリケーション内に簡単なメッセージ、アラート、または通知を表示するのに最適です。 データは、デフォルトで次の要求のためにのみ持続します。 $リクエスト -

これは、LaravelバックエンドとのReactアプリケーションの構築に関するシリーズの2番目と最終部分です。シリーズの最初の部分では、基本的な製品上場アプリケーションのためにLaravelを使用してRESTFUL APIを作成しました。このチュートリアルでは、開発者になります

Laravelは簡潔なHTTP応答シミュレーション構文を提供し、HTTP相互作用テストを簡素化します。このアプローチは、テストシミュレーションをより直感的にしながら、コード冗長性を大幅に削減します。 基本的な実装は、さまざまな応答タイプのショートカットを提供します。 Illuminate \ support \ facades \ httpを使用します。 http :: fake([[ 'google.com' => 'hello world'、 'github.com' => ['foo' => 'bar']、 'forge.laravel.com' =>

PHPクライアントURL(CURL)拡張機能は、開発者にとって強力なツールであり、リモートサーバーやREST APIとのシームレスな対話を可能にします。尊敬されるマルチプロトコルファイル転送ライブラリであるLibcurlを活用することにより、PHP Curlは効率的なexecuを促進します

顧客の最も差し迫った問題にリアルタイムでインスタントソリューションを提供したいですか? ライブチャットを使用すると、顧客とのリアルタイムな会話を行い、すぐに問題を解決できます。それはあなたがあなたのカスタムにより速いサービスを提供することを可能にします

2025 PHP Landscape Surveyは、現在のPHP開発動向を調査しています。 開発者や企業に洞察を提供することを目的とした、フレームワークの使用、展開方法、および課題を調査します。 この調査では、現代のPHP Versioの成長が予想されています


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

mPDF
mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

SublimeText3 Linux 新バージョン
SublimeText3 Linux 最新バージョン

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

DVWA
Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

PhpStorm Mac バージョン
最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール
