Adminerを設置する


Adminerは、PHPで作られているデータベース管理ツールです。(Apache License or GPL 2)

  • phpMyAdminのようにWeb上でMySQLなど※のデータベースを操作できる (一通りのことはできる)
    • MySQL以外で使用したことはないですが、公式では下記の対応を謳っています。
      MySQL, PostgreSQL, SQLite, MS SQL, Oracle, Firebird, SimpleDB, Elasticsearch, MongoDB
  • 1ファイルで作成されているため設置が簡単

という特長があり、「DBの接続情報は教えてもらったけどphpMyAdminなどの管理ツールの情報はなかった」「管理ツールの情報を教えてもらったけど管理ツールが独自のものなどですごく使いづらかった」のようなときに便利です。(他人のサーバのトラブルサポートを急にしないといけなくなった場合に特に便利)

この文書では、Adminerの基本的な設置方法と簡単な使い方を説明します。

※ 以前はWordPressの公式ディレクトリにAdminerのプラグインがありましたが、今年の夏頃(?)にWordPressの公式ディレクトリから削除されてしまったようなので、無くなって困っている方にも役に立つかもしれません。基本的にはサーバに1ファイル配置するだけです。

1. 配布サイトからファイルをダウンロードする

まず、https://www.adminer.org/ からファイルをダウンロードしてください。「Downloads」の部分にリンクがいろいろありますが、「Adminer X.X.X」とあるものでよいです。
2016/11/06時点の最新は4.2.5です。

2. 設置する

1.でダウンロードしたadminer-4.2.5.phpを、そのままサーバの公開領域に配置してください。(FTPでアップロードでも、SSHでも、できる方法で)

…これで設置は完了です…!

ログイン / データを確認する

アップロード後、設置した場所のURLにブラウザでアクセスするとログイン画面が表示されます。サーバのホスト名、ユーザ名、パスワードを入力してログインしてください。(データベース名は入力してもしなくてもよいです)

ログイン後、データベース名を入力しなかった場合はデータベース一覧が表示されます。

データベース名のリンクをクリックするとテーブル一覧が表示されます。(下記の例ではWordPressのテーブルを表示しています)

テーブル名のリンクをクリックするとテーブル構造が表示されます。

データを確認したい場合は、上記の「データ」のリンクをクリックするとデータが確認できます。

画面左側の「SQLコマンド」からSQL文を実行してもよいです。

データを追加する

データを追加したい場合は、データが表示されている画面の上部にある「項目の作成」リンクから行えます。

必要な項目を入力し、「保存」ボタンでデータを追加することができます。

データを編集する

データを編集したい場合は、列の最初にある「編集」のリンクをクリックすると、クリックした行のデータを編集できます。

データを変更し、「保存」ボタンでデータを更新することができます。

データを削除する

データを削除したい場合は、各行のチェックボックスにチェック後、画面下部の「削除」ボタンで行えます。

その他の機能

Adminerには機能がたくさんあるので、どんなものがあるかわかるように公式ページのリード文と機能概要を引用しておきます… (意訳を併記していますが間違いがあれば教えてください)

リード

Adminer (formerly phpMinAdmin) is a full-featured database management tool written in PHP. Conversely to phpMyAdmin, it consist of a single file ready to deploy to the target server. Adminer is available for MySQL, PostgreSQL, SQLite, MS SQL, Oracle, Firebird, SimpleDB, Elasticsearch and MongoDB.

(Adminer (以前はphpMinAdminと呼ばれていた) はPHPで作成された多機能のデータベース管理ツールです。phpMyAdminとは違い、対象のサーバーにデプロイ(配置)しやすい単一のファイルで構成されています。AdminerはMySQL, PostgreSQL, SQLite, MS SQL, Oracle, Firebird, SimpleDB, Elasticsearch, MongoDBで利用できます。)

機能

  • Connect to a database server with username and password
    (ユーザー名とパスワードでデータベースサーバに接続)
  • Select an existing database or create a new one
    (既存のデータベースの選択、または新規のデータベース作成)
  • List fields, indexes, foreign keys and triggers of table
    (テーブル上の項目、インデックス、外部キー、トリガーの一覧)
  • Change name, engine, collation, auto_increment and comment of table
    (テーブルの名前、エンジン、照合順序、自動連番(auto_increment)、コメントの変更)
  • Alter name, type, collation, comment and default values of columns
    (列の名前、型、照合順序、コメント、初期値の変更)
  • Add and drop tables and columns
    (テーブルと列の追加や削除)
  • Create, alter, drop and search by indexes including fulltext
    (fulltextインデックスを含むインデックスの作成、変更、削除)
  • Create, alter, drop and link lists by foreign keys
    (外部キーの作成、変更、削除、一覧)
  • Create, alter, drop and select from views
    (ビューの作成、変更、削除、データ表示)
  • Create, alter, drop and call stored procedures and functions
    (ストアドプロシージャ、ストアドファンクションの作成、削除、呼び出し)
  • Create, alter and drop triggers
    (トリガーの作成、変更、削除)
  • List data in tables with search, aggregate, sort and limit results
    (テーブルデータの一覧、検索、集約、ソート、結果の行数制限)
  • Insert new records, update and delete the existing ones
    (新しい行の挿入、既存の行の更新、削除)
  • Supports all data types, blobs through file transfer
    (すべてのデータ型のサポート、ファイル転送を介したBLOB(バイナリデータ))
  • Execute any SQL command from a text field or a file
    (ファイルまたはテキストエリアからのSQL文の実行)
  • Export table structure, data, views, routines, databases to SQL or CSV
    (テーブル構造、データ、ビュー、ルーチン、データベースをSQLまたはCSV形式でエクスポート)
  • Print database schema connected by foreign keys
    (外部キーで紐付いたデータベーススキーマの出力)
  • Show processes and kill them
    (プロセスの表示と強制終了)
  • Display users and rights and change them
    (ユーザーと権限の表示、変更)
  • Display variables with links to documentation
    (変数の表示 (マニュアルへのリンク付き)) ※ MySQLのSHOW VARIABLES
  • Manage events and table partitions (MySQL 5.1)
    (イベントとパーティションの管理 (MySQL 5.1))
  • Schemas, sequences, user types (PostgreSQL)
    (スキーマ、シーケンス、ユーザー型 (PostgreSQL))
  • Extensive customization options
    (豊富なカスタマイズオプション) ※Adminerクラスを継承して各メソッドをオーバーライドする形のものです

その他

  • CSSで外観を変えたりログイン部分をカスタマイズしたりなどもできますが、使用するときにサーバーに配置して使用し終わったらサーバーから消す、という形で使うほうが楽な気がします。
  • Adminerはファイルを1つにするためにJSやCSSファイル、画像ファイルの内容をバイナリ(LZW圧縮)でPHP内に含んでいるのでAdminerのソースコードを見るとどきっとするかもしれません…
  • WordPressのwp-config.phpを読み込んで拡張、はできそうな気がしましたが、get_temp_dir() という関数がAdminer側にもWordPress側にもあり関数名が重複してエラーになるので諦めてログイン画面でユーザー名などを手入力したほうがよさそうです
  • 書いてから 「PHPでデータベース覗くならAdminerが便利」 さんを見つけました… そちらを見ていただいてもよいと思います。