はじめに
Autonomous Databaseで、自然言語からSQLを生成するSELECT AI機能が利用可能になったので、早速試してみました。
2023年9月時点では、SELECT AI機能のAIプロバイダーとしてOpenAIおよびCohereが利用可能となっていますが、今回の検証ではCohereをAIプロバイダーとして使用しました。
SELECT AI機能でAPプロバイダーを利用する際の前提として、マニュアルに以下の記載がありましたので、Cohereの有料アカウントを作成し、APIキーを作成しました。
You have a paid API account with AI providers like, OpenAI and Cohere.
なお、こちらの検証内容は、あくまで2023年9月時点の内容です。
また、実行される環境での動作が必ずしもこの記事の内容と同一であるかは保証致しません。
AIプロバイダとしてOpenAIを使用する場合の記事はこちら。
AIプロバイダとしてAzure OpenAI Serviceを使用する場合の記事はこちら。
1.ユーザの作成とロール/権限の付与
SQL*PlusからadminユーザとしてAutonomous Databaseに接続します。
なお、こちらの環境では環境変数NLS_LANGをJapanese_Japan.AL32UTF8に設定しています。
[opc@tools ~]$ sqlplus admin/Demo#1Demo#1@adb
SQL*Plus: Release 19.0.0.0.0 - Production on 土 9月 30 21:11:58 2023
Version 19.16.0.0.0
Copyright (c) 1982, 2022, Oracle. All rights reserved.
最終正常ログイン時間: 土 9月 30 2023 13:50:55 +09:00
Oracle Database 19c Enterprise Edition Release 19.0.0.0.0 - Production
Version 19.21.0.1.0
に接続されました。
SQL>
検証に使用するユーザselect_ai_userを作成し、必要なロールを付与します。
SQL> GRANT DWROLE, UNLIMITED TABLESPACE TO select_ai_user IDENTIFIED BY Demo#1Demo#1;
権限付与が成功しました。
SQL>
select_ai_userに対して、SELECT AI機能の利用に必要なDBMS_CLOUD_AIパッケージの実行権限を付与します。
SQL> GRANT EXECUTE ON DBMS_CLOUD_AI TO select_ai_user;
権限付与が成功しました。
SQL>
select_ai_userに対して、CohereのAPIのホストapi.cohere.aiに対するHTTPアクセスを許可します。
SQL> BEGIN
2 DBMS_NETWORK_ACL_ADMIN.APPEND_HOST_ACE(
3 host => 'api.cohere.ai',
4 ace => xs$ace_type(privilege_list => xs$name_list('http'),
5 principal_name => 'SELECT_AI_USER',
6 principal_type => xs_acl.ptype_db)
7 );
8 END;
9 /
PL/SQLプロシージャが正常に完了しました。
SQL>
SQL*Plusを終了します。
SQL> exit
Oracle Database 19c Enterprise Edition Release 19.0.0.0.0 - Production
Version 19.21.0.1.0との接続が切断されました。
[opc@tools ~]$
2. SELECT AIでCohereを利用するための準備
SQL*Plusからselect_ai_userとしてAutonomous Databaseに接続します。
[opc@tools ~]$ sqlplus select_ai_user/Demo#1Demo#1@adb
SQL*Plus: Release 19.0.0.0.0 - Production on 土 9月 30 21:15:32 2023
Version 19.16.0.0.0
Copyright (c) 1982, 2022, Oracle. All rights reserved.
最終正常ログイン時間: 土 9月 30 2023 20:58:08 +09:00
Oracle Database 19c Enterprise Edition Release 19.0.0.0.0 - Production
Version 19.21.0.1.0
に接続されました。
SQL>
DBMS_CLOUD.CREATE_CREDENTIALプロシージャで、CohereのAPIに接続するためのクレデンシャルcohere_credを作成します。
passwordには、Cohereのサイトで取得したAPIキーの値を設定します。
SQL> BEGIN
2 DBMS_CLOUD.CREATE_CREDENTIAL(
3 credential_name => 'COHERE_CRED',
4 username => 'COHERE',
5 password => 'XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX'
6 );
7 END;
8 /
PL/SQLプロシージャが正常に完了しました。
SQL>
DBMS_CLOUD_AI.CREATE_PROFILEプロシージャで、SELECT AIで使用するAIプロファイルcohereaiを作成します。
・profile_nameには作成するプロファイル名を指定します。
・credential_nameには、先ほど作成したCohereのAPIに接続するためのクレデンシャルを指定します。
・attributesのobject_listには、このプロファイルで使用するスキーマ・オブジェクトの所有者とオブジェクト名を指定します。
この例では、Autonomous Databaseにデフォルトで用意されているスキーマSH内にあるcustomers、sales、produces、countriesの4つの表をこのプロファイルで使用するオブジェクトとして登録しています。
SQL> BEGIN
2 DBMS_CLOUD_AI.CREATE_PROFILE(
3 profile_name => 'COHEREAI',
4 attributes => '{"provider": "cohere",
5 "credential_name": "COHERE_CRED",
6 "object_list": [{"owner": "SH", "name": "customers"},
7 {"owner": "SH", "name": "sales"},
8 {"owner": "SH", "name": "products"},
9 {"owner": "SH", "name": "countries"}]
10 }'
11 );
12 END;
13 /
PL/SQLプロシージャが正常に完了しました。
SQL>
以上で、SELECT AI機能のAIプロバイダーとしてCohereを利用する準備が整いました。
3. SELECT AI機能を使用した自然言語によるクエリの実行
DBMS_CLOUD_AI.SET_PROFILEプロシージャで、現在のセッションで使用するAIプロファイルに先ほど作成したcohereaiを設定します。
SQL> EXEC DBMS_CLOUD_AI.SET_PROFILE('COHEREAI');
PL/SQLプロシージャが正常に完了しました。
SQL>
SELECT AIを使用して、自然言語によるクエリを実行してみます。
SQL> SELECT AI how many customers exist;
CUSTOMER_COUNT
--------------
55500
SQL>
SELECT AI SHOWSQLで生成されたSQLを確認します。
SQL> SELECT AI SHOWSQL how many customers exist;
RESPONSE
---------------------------------------------------------
SELECT COUNT(CUST_ID) AS customer_count
FROM SH.CUSTOMERS
SQL>
まとめ
SELECT AI機能のAIプロバイダーとしてCohereを使用して、自然言語によるクエリの実行ができることが確認できました。
参考情報
・Use Select AI to Generate SQL from Natural Language Prompts
・DBMS_CLOUD_AI Package
・DBMS_CLOUD.CREATE_CREDENTIALプロシージャ