内容
oracle xeのインストールとインストール後のセットアップ、外部接続設定について記載しました。
今後の自己学習用にとりあえず上記内容のみまとめました。
外部接続の設定は自己学習するだけなら多分不要な設定だと思いますが、
複数個所から接続できるならそれを活かしてなんかしたいなと思ったので設定しています。
oracle XEのインストール
- 下記サイトから自分のOSにあったファイルをダウンロードします。
oracle XE インストール - ファイルを展開し、setup.exe(windowsの場合)を実行します。
- 基本的に次へボタンを押していればOKです。
※インストール先とDBのパスワードは任意のものを設定します。
インストール後のセットアップ手順
コマンドプロンプトを開き下記でDBに接続します。
as sysdba は管理者でログインするために必要で
ほかのやり方でも管理者ログインできますが下記のほうが手順的に早いです。
sqlplus sys/パスワード as sysdba
XEPDB1 という PDB が作成されているので下記で接続先を変更します。
alter session set container = XEPDB1;
下記で表領域の作成をします。
表領域とはテーブルを格納している物理的な場所のことでファイル拡張子は.dbfです。
segment space management auto;はDB を自動で効率化してくれる設定です。
SQL> create tablespace testspace
2 datafile 'C:\app\user\product\21c\oradata\XE\test.dbf' size 100m
3 segment space management auto;表領域が作成されました。
下記で一時表領域の作成をします。(ソートを行うための領域)
autoextend on;はスペース不足になったときに自動でサイズを増加する設定です。
SQL> create temporary tablespace testtemp
2 tempfile 'C:\app\user\product\21c\oradata\XE\testtemp.dbf' size 100m
3 autoextend on;表領域が作成されました。
下記でユーザの作成をします。
SQL> create user ユーザID
2 identified by パスワード
3 default tablespace testspace
4 temporary tablespace testtemp;ユーザーが作成されました。
下記でユーザに権限を付与します。
alter session set container = XEPDB1;
grant connect to ユーザID;
grant resource to ユーザID;
grant dba to ユーザID;
下記で作成したユーザで再接続します。
sqlplus ユーザID/パスワード@//localhost:1521/xepdb1
外部接続設定
Windows Defender ファイアウォールを開き、詳細設定を押下します。
受信の規則を押下すると、新しい規則が表示されるので押下します。
新規の受信の規則ウィザードが表示されるので下記設定をします。
規則の種類:ポート
プロトコルおよびポート:TCP, 1521
操作:接続を許可する
プロファイル:すべて
名前:任意
コマンドプロンプトで下記を実行します。
DBに接続している場合はexitで切断してください。
ipconfig
実行結果のIPv4 アドレス項目にIPアドレスが表示されるのでメモします。
別PCで接続確認をします。
a5m2(DB接続できるものなら何でもいいです)で下記の接続情報を入力したら完了です。
追記
別PC(oracle xeインストール済み)でsqlplusによる接続をしようとしたらエラーになりました。
ORA-12638: 資格証明の取出しに失敗しました。
上記エラーについては下記ファイルを開きます。
C:\app\user\product\21c\homes\OraDB21Home1\network\admin\sqlnet.ora
下記行の先頭に#を付けてコメントにし、再度sqlplusを実行すると接続できました。
SQLNET.AUTHENTICATION_SERVICES= (NTS)
ついでにsqlplusで接続するときに毎回IPアドレス入力するのは大変なので
sqlnet.oraと同階層にあるtnsnames.oraに下記を追加します。
任意の名前 =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = IPアドレス)(PORT = 1521))
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = xepdb1)
)
)
上記を設定すると以降は下記で接続できるようになります。
sqlplus ユーザ名/パスワード@任意の名前