はじめに
会社では、データベース接続ツールとして「A5:SQL MK-2」(以降略名:A5M2)を使用しています。
自宅のMac環境でも使用してみようとWineskinServerで作成してみました。
MacでWineを使用してA5M2を動かす記事については、作者自身も書いています。自分の環境と違ってM1 Macです。
他にも
環境
Mac Book Pro(2.3 GHz 8コアIntel Core i9) Monterey 12.0.1
WineSkinの導入と設定
WineSkinダウンロード、最新のエンジンの導入、最新のラッパーを導入までは内容がかぶるので、サクラエディタの記事を参照してください。
ラッパーを作成
Installed Engine WS11WineCX64bit21.2.0 と Wrapper Version が Winskin-2.9.1.1 になりました。
「Create New Blank Wrapper」をクリックし、好きな名前を設定( A5M2.app とか)し「OK」ボタンをクリックすればラッパーの作成が開始されます。他のWineskinServerのアプリケーションは終了しておいた方が良さそうです。
作成が終わり「view folder in Finder」をクリックすれば、設定した名前のWineSkinラッパーアプリが「/Users/ユーザー名/アプリケーション/WineSkin/」の下に生成されます。
A5:SQL MK-2を用意
現時点の最新版の64bit版 a5m2_2.17.2_x64.zip をダウンロードしました。そしてダウンロードフォルダ内にzipを展開しました。
フォントのインストール
サクラエディタでフォントが文字化けする経験があったので、先にフォントをインストールしておきます。
A5M2.appの右クリックメニューにある「パッケージ内容を表示」をクリックします。
fakejapaneseの導入
Wineは標準では普通のWindowsが標準搭載しているライブラリ、フォント類がかなり抜けています。必要に応じて「winetricks」を用いてこれらのライブラリ、フォントを導入できます。
wineskin.appをクリックすると設定画面が開きます。「Advanced」を選択すると詳細設定画面が開きます。
詳細設定画面の「Tools」タブの「winetricks」を選択します。
検索窓に「fakejapanese」を入力します。fontsの配下に「fakejapanese」が表示されてきます。これにチェックを付けて「Run」をクリックしてインストールします。
いろいろインストールされるのがパネルに表示され、終わると「Close」ボタンが有効になるので終了する。
フォントのダウンロードに少し時間がかかりますが、しばらく完了するまで待ちましょう。
これにより日本語環境に必要な、「MS (UI/P)Gothic」、「MS(P)Mincho」、MS(P)ゴシック」、「MS(P)明朝」などのフォント名が追加される。ただし、実際該当するフォントがインストールされるわけではなく、fakejapaneseという名の通りシステムにある何かの代替えとなる。
【2022/06/13追記】
「fakejapanese_ipamona」をインストールすると、依存している「fakejapanese」パッケージも同時にインストールされる。ipamonaフォントをインストールしなかった場合、適当なフォント置換を行っていないため可読性の低いフォントになる可能性がある。「fakejapanese_vlgothic」はメイリオフォントの代替フォントとなる。
「fakejapanese_ipamona」以外では「cjkfonts」もあります。
A5:SQL MK-2のインストール
設定画面で「Install Software」を選択します。
「Move a folder inside」又は「Copy a folder inside」を選択します。今回は「Copy a folder inside」を選択しました。
a5m2_2.17.2_x64フォルダを選択します。
a5m2_2.17.2_x64の実行ファイルは正しいので、そのままOKボタンをクリックします。
アイコンの変更
標準ではwineskinのアイコンになっているので、A5:SQL MK-2用のアイコンに変更します。
Automator用のアイコン画像ファイルを保存します。一応、32x32サイズ変換してます。
https://a5m2.mmatsubara.com/image/A5M2_ICON.png
設定画面で「Advanced」を選択します。
IconのBrowseボタンをクリックして、A5:SQL MK-2のアイコン「A5M2_icon.jpg」を選択します。
直ぐには変わらないかも知れない、後でA5M2.appの右クリックメニューの「情報を見る」でプレビューを見るといいかも。
A5:SQL MK-2の起動
今回はレジストリを選択しました。
PostgreSQLでデータベースmydb
にて、books
テーブルの中身を表示しています。
PostgreSQL環境作成
順番が逆になりますが、PostgreSQLインストールしデータベースmydb
とbooks
テーブルを作成しました。
PostgreSQLインストール
最新版をインストールする場合、postgresqlを指定します。
% brew install postgresql
% psql --version
psql (PostgreSQL) 14.3
PostgreSQLを起動する
% brew services start postgresql
==> Tapping homebrew/services
Cloning into '/usr/local/Homebrew/Library/Taps/homebrew/homebrew-services'...
remote: Enumerating objects: 2000, done.
remote: Counting objects: 100% (509/509), done.
remote: Compressing objects: 100% (176/176), done.
remote: Total 2000 (delta 348), reused 441 (delta 325), pack-reused 1491
Receiving objects: 100% (2000/2000), 548.53 KiB | 2.62 MiB/s, done.
Resolving deltas: 100% (903/903), done.
Tapped 1 command (45 files, 700.4KB).
==> Successfully started `postgresql` (label: homebrew.mxcl.postgresql)
データベース一覧を表示
% psql -l
List of databases
Name | Owner | Encoding | Collate | Ctype | Access privileges
-------------+-------+----------+---------+-------+-------------------
postgres | yaju | UTF8 | C | C |
template0 | yaju | UTF8 | C | C | =c/yaju +
| | | | | yaju=CTc/yaju
template1 | yaju | UTF8 | C | C | =c/yaju +
| | | | | yaju=CTc/yaju
(3 rows)
データベース作成
% psql postgres
postgres=# create database mydb;
postgres-# \q
テーブル作成
% psql mydb
psql (14.3)
Type "help" for help.
mydb=# create table books(id integer, name text);
CREATE TABLE
テーブルにデータを追加
mydb=# insert into books values (1, 'はらぺこあおむし');
INSERT 0 1
mydb=# insert into books (id, name) values (2, 'ぐりとぐら');
INSERT 0 1
mydb=# \q
role postgres does not exist
テスト接続したら「role postgres does not exist」エラーになりました。
検索したところ、解決するにはpostgres
ユーザーを作成する必要があるそうです。
postgresユーザー作成
% createuser postgres
% psql -U postgres
psql (14.3)
Type "help" for help.
postgres=> \du
List of roles
Role name | Attributes | Member of
-----------+------------------------------------------------------------+-----------
postgres | | {}
yaju | Superuser, Create role, Create DB, Replication, Bypass RLS | {}
権限追加
% psql postgres
psql (14.3)
Type "help" for help.
postgres=# alter role postgres with superuser createdb createrole;
ALTER ROLE
postgres=# \du
List of roles
Role name | Attributes | Member of
-----------+------------------------------------------------------------+-----------
postgres | Superuser, Create role, Create DB | {}
yaju | Superuser, Create role, Create DB, Replication, Bypass RLS | {}
オーナー変更
データベースmydb
のオーナーをpostgres
に変更します。
postgres=# alter database mydb owner to postgres;
ALTER DATABASE
postgres=# \l
List of databases
Name | Owner | Encoding | Collate | Ctype | Access privileges
-----------+----------+----------+---------+-------+-----------------------
mydb | postgres | UTF8 | C | C |
postgres | yaju | UTF8 | C | C |
template0 | yaju | UTF8 | C | C | =c/yaju +
| | | | | yaju=CTc/yaju
template1 | yaju | UTF8 | C | C | =c/yaju +
| | | | | yaju=CTc/yaju
(4 rows)
これでテスト接続ができるようになりました。
最後に
これでMacでも動作することが出来ました。
A5:SQL MK-2は日本人の方が作成していますし、掲示板に書けば回答して頂けるので応援したいです。
データベース接続ツールとしては、「DBeaver」もいい感じです。