ノーコードでクラウド上のデータとの連携を実現。
詳細はこちら →無償トライアル:
無償トライアルへ製品の情報と無償トライアルへ:
パワフルなE メール送受信機能を統合した優れたJava アプリケーションを短時間・低コストで作成して配布できます。POP3、IMAP、SMTP によるE メールの送受信、アドレスの検証などを行うことができます。
加藤龍彦
ウェブデベロッパー
JDBC Driver
インターネット上には、多くのPostgreSQL クライアントがあります。標準のドライバーからBI、アナリティクスツールまで、PostgreSQL はデータアクセスのための一般的なインターフェースです。 JDBC ドライバーを使用することで、簡単に任意の標準クライアントから接続できるPostgreSQL エントリポイントを作成できます。
Email にPostgreSQL データベースとしてアクセスするには、CData JDBC Driver for Email とJDBC foreign data wrapper (FDW) を使用します。ここでは、FDW をコンパイルしてインストールし、PostgreSQL サーバーからEmail にクエリを実行します。
JDBC データソースとしてEmail に接続するには、以下が必要です。
Driver class:
cdata.jdbc.email.EmailDriver
Authentication セクションのUser プロパティとPassword プロパティに、有効な認証情報を設定する必要があります。 E メールを取得するには、Server を指定する必要があります。E メールを送信するにはSMTPServer を指定する必要があります。
JDBC URL の構成については、Email JDBC Driver に組み込まれている接続文字列デザイナを使用してください。JAR ファイルのダブルクリック、またはコマンドラインからJAR ファイルを実行します。
java -jar cdata.jdbc.email.jar
接続プロパティを入力し、接続文字列をクリップボードにコピーします。
以下は一般的なJDBC URL です。
jdbc:email:User=username@gmail.com;Password=password;Server=imap.gmail.com;Port=993;SMTP Server=smtp.gmail.com;SMTP Port=465;SSL Mode=EXPLICIT;Protocol=IMAP;Mailbox=Inbox;
FDW は、PostgreSQL を再コンパイルせずに、PostgreSQL の拡張機能としてインストールできます。例としてjdbc2_fdw 拡張子を使用します。
ln -s /usr/lib/jvm/java-6-openjdk/jre/lib/amd64/server/libjvm.so /usr/lib/libjvm.so
make install USE_PGXS=1
拡張機能をインストールした後、以下のステップに従ってEmail へのクエリの実行を開始します。
CREATE EXTENSION jdbc2_fdw;
CREATE SERVER Email
FOREIGN DATA WRAPPER jdbc2_fdw OPTIONS (
drivername 'cdata.jdbc.email.EmailDriver',
url 'jdbc:email:User=username@gmail.com;Password=password;Server=imap.gmail.com;Port=993;SMTP Server=smtp.gmail.com;SMTP Port=465;SSL Mode=EXPLICIT;Protocol=IMAP;Mailbox=Inbox;',
querytimeout '15',
jarfile '/home/MyUser/CData/CData\ JDBC\ Driver\ for\ Salesforce MyDriverEdition/lib/cdata.jdbc.email.jar');
CREATE USER MAPPING for postgres SERVER Email OPTIONS (
username 'admin',
password 'test');
postgres=# CREATE FOREIGN TABLE mailboxes (
mailboxes_id text,
mailboxes_Mailbox text,
mailboxes_RecentMessagesCount numeric)
SERVER Email OPTIONS (
table_name 'mailboxes');
postgres=# SELECT * FROM mailboxes;