製品をチェック

MySQL Driver の30日間無償トライアルをダウンロード

 30日間の無償トライアルへ

製品の詳細

MySQL アイコン MySQL JDBC Driver 相談したい

MySQL 互換データベースエンジンを組み込んだパワフルなJava アプリケーションを短時間・低コストで作成して配布できます。

ColdFusion にリアルタイムMySQL データをインポートしてアプリケーションを構築

CData JDBC ドライバを使ってColdFusion にMySQL データをインポートして使用します。

古川えりか
コンテンツスペシャリスト

最終更新日:2023-02-02
mysql ロゴ

CData

jdbc ロゴ画像
ColdFusion ロゴ

こんにちは!ドライバー周りのヘルプドキュメントを担当している古川です。

Adobe ColdFusion は、Web アプリケーションおよびモバイルアプリケーション開発プラットフォームです。独自のスクリプト言語であるColdFusion Markup Language(CFML)を使用し、データドリブンなWeb サイトを作成したり、REST などのリモートサービスを生成したりすることができます。

ColdFusion とCData JDBC Driver for MySQL を組み合わせると、ColdFusion のWeb アプリケーションやモバイルアプリケーションを、運用中のMySQL データにリンクできます。 これにより、アプリケーションの堅牢性と完成度を高めることができます。この記事では、JDBC ドライバーを使ってColdFusion マークアップファイルからMySQL のデータを入力したテーブルを作成する方法について詳しく説明します。

最適化されたデータ処理が組み込まれたCData JDBC ドライバは、リアルタイムMySQL データを扱う上で高いパフォーマンスを提供します。 MySQL にSQL クエリを発行すると、CData ドライバーはフィルタや集計などのMySQL 側でサポートしているSQL 操作をMySQL に直接渡し、サポートされていない操作(主にSQL 関数とJOIN 操作)は組み込みSQL エンジンを利用してクライアント側で処理します。 組み込みの動的メタデータクエリを使用すると、ネイティブのデータ型を使ってMySQL データを操作および分析できます。

MySQL への接続を設定する

Coldfusion とMySQL の接続を確立するには、JDBC 接続文字列が必要です。

Server およびPort プロパティがMySQL への接続には必須です。IntegratedSecurity をFALSE に設定した場合、User、Password も必須になります。 オプションで、Database を設定することもできます。Database は設定がない場合すべてのデータベースを使えるようになります。

パスワード方式によるSSH 接続

パスワード方式によるSSH接続時に必要なプロパティ一覧を以下に示します。

  • User: MySQL のユーザ
  • Password: MySQL のパスワード
  • Database: MySQL の接続先データベース
  • Server: MySQL のサーバー
  • Port: MySQL のポート
  • UserSSH: "true"
  • SSHAuthMode: "Password"
  • SSHPort: SSH のポート
  • SSHServer: SSH サーバー
  • SSHUser: SSH ユーザー
  • SSHPassword: SSH パスワード

接続文字列形式では以下のようになります。

User=admin;Password=adminpassword;Database=test;Server=mysql-server;Port=3306;UseSSH=true;SSHAuthMode=Password;SSHPort=22;SSHServer=ssh-server;SSHUser=root;SSHPassword=sshpasswd;

公開鍵認証方式方式によるSSH 接続

公開鍵認証によるSSH接続時に必要なプロパティ一覧を以下に示します。

  • User: MySQL のユーザ
  • Password: MySQL のパスワード
  • Database: MySQL の接続先データベース
  • Server: MySQL のサーバー
  • Port: MySQL のポート
  • UserSSH: "true"
  • SSHAuthMode: "Public_Key"
  • SSHClientCertType: キーストアの種類
  • SSHPort: SSH のポート
  • SSHServer: SSH サーバー
  • SSHUser: SSH ユーザー
  • SSHClientCert: 秘密鍵ファイルのパス

接続文字列形式では以下のようになります。

User=admin;Password=adminpassword;Database=test;Server=mysql-server;Port=3306;UseSSH=true;SSHAuthMode=Public_Key;SSHClientCertType=PUBLIC_KEY_FILE;SSHPort=22;SSHServer=ssh-server;SSHUser=root;SSHClientCert=C:\Keys\key.pem;

組み込みの接続文字列デザイナー

JDBC URL の作成の補助として、MySQL JDBC Driver に組み込まれている接続文字列デザイナーが使用できます。JAR ファイルをダブルクリックするか、コマンドラインからjar ファイルを実行します。

java -jar cdata.jdbc.mysql.jar 組み込みの接続文字列デザイナーを使ってJDBC URL を生成(mysql の場合)

データソースを追加してテーブルを作成する

接続を設定したのち、次の手順に従ってはじめにCData JDBC ドライバをColdFusion のlib ディレクトリに追加し、続けて新しいデータソースを追加、接続をテスト、ColdFusion マークアップファイルを作成し、最後にMySQL データとリアルタイム接続してColdFusion Markup Language(CFML)で記述されるテーブルに表示します。

  1. JDBC Driver for MySQL およびlic ファイルを"C:\Program Files\CData\CData JDBC Driver for MySQL\lib" から"C:\ColdFusion2021\cfusion\wwwroot\WEB-INF\lib"にコピーします。 cdata.jdbc.mysql.jar cdata.jdbc.mysql.lic

    Note:.lic ファイルをjar ファイルとともにコピーしないと、有効なライセンスがインストールされていないことを示すライセンスエラーが表示されます。 これは評価版、製品版ともに同様です。

  2. ColdFusion Administrator インターフェースで「データとサービス」を選択します。 データとサービスを選択
  3. 「新規のデータソースの追加」を行います。データソース名は、ColdFusion の変数命名規則に従っていればどのような名前でもかまいません。 JDBC ドライバーの場合は、「その他」を選択して「追加」ボタンをクリックします。 データソース名を追加
  4. 次に、ドライバーのプロパティを入力します。
    • 「JDBC URL」は、次のような形式である必要があります: jdbc:mysql:|connectionString|
    • 典型的な接続文字列は次のようになります:

      jdbc:mysql:User=myUser;Password=myPassword;Database=NorthWind;Server=myServer;Port=3306;
    • 「ドライバクラス」は次のようになります:cdata.jdbc.mysql.MySQLDriver
    • 「ドライバ名」の入力は任意で、これは単にColdFusion Administrator コンソールでデータソースを認識するために使われます。
    ドライバーのプロパティを入力
  5. ここで、作成したCDataMySQLJDBC データソースの左側にあるチェックマークをクリックして、接続をテストしてください。 データソースのステータスが「OK」になると、使用可能な状態です。 接続をテスト
  6. 次に、ColdFusion Markup ファイル(.cfm)を新規作成し、ColdFusion のwwwroot ディレクトリ("C:\ColdFusion2021\cfusion\wwwroot")に配置します。

    次のコードは、データソースにクエリを実行します。

                
            <cfquery name="MySQLQuery" dataSource="CDataMySQLJDBC"> 
              SELECT * FROM Orders 
            </cfquery> 
        
    CFTable を使用すると、HTML で素早くテーブルを出力できます。
                
              <cftable  
              query = "MySQLQuery" 
              border = "1" 
              colHeaders 
              colSpacing = "2" 
              headerLines = "2" 
              HTMLTable 
              maxRows = "500" 
              startRow = "1"> 
    
              <cfcol header="<b>ShipName</b>" align="Left" width=2 text="ShipName"/> 
    
              <cfcol header="<b>Freight</b>" align="Left" width=15 text="Freight"/> 
    
              ...
    
            </cftable> 
        
    HTML 部分を含むコード全体を以下に掲載します。
                
            <html> 
            <head><title>CData Software | MySQL Orders Table Demo </title></head> 
            <body> 
            <cfoutput>#ucase("MySQL Orders Table Demo")#</cfoutput> 
            <cfquery name="MySQLQuery" dataSource="CDataMySQLJDBC"> 
    
              SELECT * FROM Orders 
    
            </cfquery> 
            <cftable  
              query = "MySQLQuery" 
              border = "1" 
              colHeaders 
              colSpacing = "2" 
              headerLines = "2" 
              HTMLTable 
              maxRows = "500" 
              startRow = "1"> 
              <cfcol header="<b>ShipName</b>" align="Left" width=2 text="ShipName"/> 
    
              <cfcol header="<b>Freight</b>" align="Left" width=15 text="Freight"/> 
    
              ...
    
            </cftable> 
            </body> 
    
            </html>  
        
  7. 最後に、デフォルトのポート8500のブラウザでコードをローカルに実行します。これでMySQL のデータが入力されたテーブルが作成されました! コードを実行

なお、CData JDBC ドライバはcfqueryparam 要素を使用したパラメータ化クエリもサポートしています。 次に例を示します。 SELECT * FROM Account WHERE name =

今日からはじめましょう

CData JDBC Driver for MySQL の 30日間無償トライアル をダウンロードして、Adobe ColdFusion でMySQL と連携したアプリケーションの作成をはじめましょう!ご不明な点があれば、サポートチームにお問い合わせください。

関連コンテンツ

トライアル・お問い合わせ

30日間無償トライアルで、CData のリアルタイムデータ連携をフルにお試しいただけます。記事や製品についてのご質問があればお気軽にお問い合わせください。