前提条件:
エクスポートステートメントを実行する前に、新しいデータベースとテーブルを作成するか、既存のデータベースとテーブルを選択する必要があります。次のコマンドを実行して、 図書館 データベースと3つのテーブル 本、借り手 と book_borrow_info 。
作成 データベース 図書館;
使用する 図書館;
作成 テーブル 本((
id INT いいえ ヌル 自動増加 、
題名 varchar ((50)。 いいえ ヌル 、
著者 varchar ((50)。 いいえ ヌル 、
出版社 varchar ((50)。 いいえ ヌル 、
主キー ((id)。
)。 エンジン = INNODB ;
作成 テーブル 借り手((
id VARCHAR ((50)。 いいえ ヌル 、
名前 varchar ((50)。 いいえ ヌル 、
住所 varchar ((50)。 いいえ ヌル 、
Eメール varchar ((50)。 いいえ ヌル 、
主キー ((id)。
)。;
作成 テーブル book_borrow_info((
Borrow_id VARCHAR ((50)。、
book_id INT 、
借りる日付 日にち いいえ ヌル 、
return_date 日にち いいえ ヌル 、
状態 VARCHAR ((15)。 いいえ ヌル 、
索引 par_ind((book_id)。、
主キー ((Borrow_id、借りる日付)。、
外部キー ((book_id)。 参考文献 本((id)。
オン 消去 カスケード
オン アップデート カスケード )。;
次のSQLコマンドを実行して、いくつかのデータを3つのテーブルに挿入します。
入れる の中へ 本 値
(( ヌル 、 「モッキンバードを殺すために」、 「ハーパー・リー」、 「グランドセントラルパブリッシング」)。、
(( ヌル 、 「百年の孤独」、 「ガルシアマルケス」、 「ルトフィ・オズコック」)。、
(( ヌル 、 '透明人間'、 「ラルフ・エリソン」、 「ブリタニカ百科事典」)。;
入れる の中へ 借り手 値
((「123490」、 「パトリック・ウッド」、 '34 West Street LANCASTER LA14 9ZH '、 '[メール保護]')。、
((「157643」、 「エズラ・マーティン」、 '10 The Grove BIRMINGHAM B98 1EU '、 '[メール保護]')。、
((「146788」、 「フレデリック・ハンソン」、 '85 Highfield Road SHREWSBURY SY46 3ME '、
'[メール保護]')。;
入れる の中へ book_borrow_info 値
((「123490」、 1、 「2020-02-15」、 「2020-02-25」、 '戻ってきた')。、
((「157643」、 2、 「2020-03-31」、 「2020-03-10」、 '保留中')。、
((「146788」、 3、 「2020-04-10」、 「2020-01-20」、 '借りた')。;
エクスポートされたすべてのファイルはMySQLの特定の場所に保存され、その場所は変数に保存されます。 secure_file_priv 。次のコマンドを実行して、ファイルのパスを見つけます。これは読み取り専用の変数であり、変更することはできません。
見せる 変数 お気に入り '安全_ファイル_priv ';
ファイルの場所は ‘/ var / lib / mysql-files /’ 。 exportコマンドの実行時にこの場所を使用する必要があります。
INTO OUTFILEステートメントを使用してCSV形式でデータをエクスポートします。
を使用して、任意のデータベーステーブルをエクスポートできます。 INTO OUTFILE 声明。のデータをエクスポートしたいとします。 本 テーブル。次のコマンドを実行して、このテーブルの既存のデータを確認します。
選択する * から 本;
を含む任意のファイル名 .csv エクスポートファイル名には拡張子を設定できます。次のエクスポートコマンドを実行して作成します books.csv その場所のファイル、 / var / lib / mysql-files /。
選択する 題名、著者、出版社 から 本 の中へ アウトファイル '/var/lib/mysql-files/books.csv';エクスポート場所に移動して、ファイルが作成されていないことを確認します。ファイルをクリックすると、ファイルの内容が表示されます。テーブルのフィールド値の内容としてコンマが存在する場合、値は複数の値に分割されます。の中に 本 テーブル、 出版社 フィールドには、3番目のレコードのコンテンツとしてコンマ(、)が含まれています。 CSVファイルのコンテンツを調べると、発行元のコンテンツが適切ではない2つの値に分割されていることがわかります。
上記の問題を解決するために、エクスポートすることができます 本 SQLステートメントで必要な区切り文字を適切に指定することにより、テーブルデータをCSVファイルに変換します。次のコマンドを実行してエクスポートします 本 テーブルに books2.csv 適切にファイルします。ここでは、データを適切にエクスポートするために3つの区切り文字が使用されています。これらは によって終了するフィールド 、 で囲まれています と によって終了した回線 。
選択する 題名、著者、出版社 から 本の中へ アウトファイル '/var/lib/mysql-files/books2.csv'
田畑 終了者 '、'
で囲まれています '' '
LINES 終了者 'NS';
今、あなたが開くと books2.csv ファイルの場合、前の問題がこのファイルで解決され、データがコンマ(、)で複数の値に分割されないことがわかります。
mysqlクライアントを使用してCSV形式でデータをエクスポートします。
テーブルデータは、mysqlクライアントを使用してCSVファイルにエクスポートできます。借り手テーブルは、この記事のこの部分でエクスポートされます。次のコマンドを実行して、このテーブルの既存の内容を確認します。
選択する * から 借り手;mysql とのステートメント `しかし` ここでは、コマンドを使用してデータをエクスポートします。このステートメントの利点の1つは、前の例で使用したデフォルトの場所なしで、CSVファイルを保存するための任意の場所とファイル名を設定できることです。 rootユーザーのパスワードがない場合は -NS オプションは省略されます。エクスポートされた場所は / tmp ファイル名は output.csv ここ。
mysql-hローカルホスト-あなたは根を下ろします-NS-と'select * from library.borrowers' |sed'NS/NS/、/NS' >> /tmp/output.csv
あなたが開くと output.csv ファイルを作成すると、次の出力が表示されます。
phpmyadminを使用してCSV形式でデータをエクスポートします。
データベーステーブルは、データベース管理ツールを使用して非常に簡単にCSVファイルにエクスポートできます。エクスポートを実行する前に、ツールをインストールする必要があります。 phpmyadmin ここでは、テーブルをCSVファイルにエクスポートするために使用されます。ここで、エクスポートされるファイル名はテーブルの名前になります。任意のブラウザで次のURLを実行して、MySQLサーバーの既存のデータベースリストを表示します。
http:// localhost / phpmyadmin
エクスポートするデータベースのテーブルを選択し、をクリックします。 書き出す 右側からタブ。からCSV形式を選択します フォーマット ドロップダウンリストをクリックしてクリックします 外出 ボタン。を選択 ファイルを保存 オプションを押して OK ボタン。
ファイルはにダウンロードされます ダウンロード フォルダ。ここ、 book_borrow_info テーブルがエクスポートされます。したがって、CSVファイル名は次のようになります book_borrow_info.csv ファイルを開くと、次の内容が表示されます。
結論:
データベースサーバーのエクスポート機能を使用すると、アプリケーション間のデータ交換タスクが簡単になります。 MySQLは、テーブルデータをエクスポートするために他の多くのファイル形式をサポートしています。 SQL ファイル形式は、主に同じデータベースサーバー間でデータを転送するために使用されます。 CSV形式は、2つの異なるアプリケーション間でデータを交換する場合に非常に役立ちます。