【SQLServer】データのエクスポートとインポート

データのエクスポートとインポートをBCPユーティリティを利用して行います。

bcp データベース名.所有者(初期はdbo).テーブル名 in|out|queryout|format ファイル名 オプション
bcp Test_db.dbo.TestTbl out TestTbl.txt /U ユーザ名 /S サーバ名 /P パスワード /c /t , /r \r\n /q >> exec.log
/c /cを指定しない場合、列ごとにプロンプトでタブや改行を指定する必要がある。
/t /cを指定した場合、デフォルトはタブ区切りになる。変更する場合に指定。
/r /cを指定した場合、デフォルトは\nになる。変更する場合に指定。
/q 空白や単一引用符を含むデータベース名、所有者、テーブル名を指定する場合に指定。
/o bcpコマンド単位でログ出力できる。「>> ファイル名」の方が楽。
/f フォーマット個別指定。/cの方が楽。
   以下がフォーマット。
   8.0
   2
   1 SQLCHAR     0 3 "," 1 USERID Japanese_BIN
   2 SQLDATETIME 0 8 "," 2 DATE   ""

   1行目:バージョン番号
   2行目:列数
   3行目:番号、データ型、プレフィックス長、項目長、終端文字、DB内の項目番号、DB内の項目名、行の照合順序(※1)

※1
照合順序の例
 Japanese_BIN
  大文字、小文字、シングルバイト、ダブルバイト、ひらがな、カタカナを全て区別する
 Japanese_CI_AS
  大文字、小文字、シングルバイト、ダブルバイト、ひらがな、カタカナを全て区別しない

複数テーブルに対して作成する場合、
以下のようなSQL文を準備しておくと汎用性が高くなる。

SELECT 'bcp Test_db.dbo.' + name + ' out ' + name + '.txt /U ユーザ名 /S サーバ名 /P パスワード /c /t "," /r \r\n' FROM sysobjects WHERE type = 'U' ORDER BY name;

【Git】Git導入

今更ながらGitを導入。
最新版のポータブル版を利用します。(現時点では2.15)

  • Git入手
    https://github.com/git-for-windows/git/releases/latest
    PortableGit-X.XX.X-64-bit.7z.exe
  • Git導入
    ダウンロードした7-Zip の 自己解凍ウィザードを起動する。
    任意の場所(今回はD:/DownloadFiles/Git)を指定し、インストールします。
    インストール後、警告が出ましたが、無視。
    ダウンロードしたGit-X.XX.X-64-bit.exeとPortableGit-X.XX.X-64-bit.7z.exeは削除。
  • 環境変数の設定
    環境変数のPathに「D:\DownloadFiles\Git\cmd;」を追加します。
  • 日本語設定
    /// 下記は実施しませんでした。 //////////////////////////////////////

    nkf32.exeを入手します。(nkfwin32.exeは32bit版、nkf.exeは64bit版)
    nkf.exeにリネームし「D:\DownloadFiles\Git\bin」に配置します。

    「D:\DownloadFiles\Git\etc\inputrc」を以下のように編集します。

    set input-meta on
    set output-meta on
    set convert-meta off
    set kanji-code utf-8
    

    「D:\DownloadFiles\Git\etc\profile」の末尾に以下を追加します。

    export GIT_PAGER="nkf -s | LESSCHARSET=utf-8 less"
    export GIT_EDITOR="'D:\DownloadFiles\sakura\sakura.exe' -CODE=4"
    

    /// 上記は実施しませんでした。 //////////////////////////////////////

  • gitconfigの設定
    コマンドプロントを立ち上げ、以下を入力します。

    git config --global core.autocrlf false
    git config --global core.excludesfile ~/.gitignore
    git config --global user.name [ユーザー名]
    git config --global user.email [メールアドレス] 
    git config --global credential.helper wincred
    

    上から順に
    ・改行コードをエディタで明示するので変換なし
    ・全体の .gitignore ファイルの指定
    ・GitHubのユーザ名
    ・GitHubのパスワード
    ・HTTPS で クローンする際にクレデンシャル情報を記憶

    設定値は「C:/Users/XXXX/.gitconfig」に保存されます。

  • gitignoreの設定
    全体設定を「.gitignore」ファイルに行います。
    コマンドプロントに以下を入力します。

    type nul > %USERPROFILE%\.gitignore
    

    Linuxでいうところのtouchコマンドの代わりで0KBのファイルが出来ます。
    「.gitigonore」ファイルにはGitで管理しないファイルを追記します。
    以下を設定しました。(改行コードはLFにしました。)

    # Eclipse
    .metadata
    bin/
    tmp/
    *.tmp
    *.bak
    *.swp
    *~.nib
    local.properties
    .settings/
    .loadpath
    .recommenders
    # External tool builders
    .externalToolBuilders/
    # Locally stored "Eclipse launch configurations"
    *.launch
    # PyDev specific (Python IDE for Eclipse)
    *.pydevproject
    # CDT-specific (C/C++ Development Tooling)
    .cproject
    # Java annotation processor (APT)
    .factorypath
    # PDT-specific (PHP Development Tools)
    .buildpath
    # sbteclipse plugin
    .target
    # Tern plugin
    .tern-project
    # TeXlipse plugin
    .texlipse
    # STS (Spring Tool Suite)
    .springBeans
    # Code Recommenders
    .recommenders/
    # Scala IDE specific (Scala & Java development for Eclipse)
    .cache-main
    .scala_dependencies
    .worksheet
    
  • Eclipseの設定
    EclipseからGitリポジトリを見るため、環境変数に以下を追加します。
    HOME=C:/Users/XXXX

大量の特定ファイルを処理

特定ファイルを処理する場合、
lsやfindした結果をパイプで繋いで処理しますが、
特定ファイルが大量に存在する場合のメモ。

# パターンその1
# ファイルが多すぎるとエラーになる
ls *.txt | xargs rm
# パターンその2
# ファイルが多すぎるとエラーになる
find -f *.txt | xargs rm
# パターンその3
# ファイルが多すぎ手も処理できるがメモリを消費
echo *.txt | xargs rm

【Oracle】これまでに実行したSQL一覧とCPU時間

これまでに実行したSQL一覧とCPU時間を統計データが格納されたビューから取得します。

SELECT SQL_TEXT, FETCHES, EXCUTIONS, LOADS, ELAPSED_TIME, CPU_TIME FROM V$SQL_STATS WHERE SQL_ID = 'xxxxxx';

SQL_TEXT:SQL文
FETCHES:フェッチを行った回数
LOADS:オブジェクトのロード回数
ELAPSED_TIME:SQL の実行に使用した累計の時間
CPU_TIME:SQL の実行に使用した累計の CPU 時間