SikuliX:SQL Serverに接続する

シナリオ

  • DBサーバ:localhost
  • DB名:SikuliX
  • テーブル:車名コードの コード:194 の車名表示名と車名英文字を取得
  • JDBCドライバはMSからダウンロードしmssql-jdbc-x.x.x.jre8.jarをc:¥jdbcにコピーしておく
※SikuliXバグ情報
 sikulix1.1.4以降のloadコマンドにバグがある模様。
 https://bugs.launchpad.net/sikuli/+bug/1789569 
 2.1でFix予定らしい。2.0.4ではOK 2.0.4でもだめな場合があった。
 回避策:下記フォルダにmssql-jdbc-x.x.x.jre8.jarをコピー後IDEを起動し直すと自動でロードするようだ
 ※AppDataは隠しファイルなので表示できるように設定する(エクスプローラ>表示タブ>隠しファイル)
 C:\Users\<ユーザー名>\AppData\Roaming\Sikulix\Extensions

 2.0.1ではこの回避策ではNGだった。クラスNot Foundになる。
java.lang.ClassNotFoundException ( java.lang.ClassNotFoundException: com.microsoft.sqlserver.jdbc.SQLServerDriver ) 

サンプルコード

load("C:\\jdbc\\mssql-jdbc-9.2.0.jre8.jar") # ←ここでJDBCドライバをロードしておく
import sys
from java.lang import Class 
from java.sql import DriverManager
from java.sql import PreparedStatement

reload(sys)
sys.setdefaultencoding("utf-8")

dbuser = "ユーザーID"
dbpassword = "パスワード"
url = "jdbc:sqlserver://localhost;database=SikuliX;" + "user=" + dbuser + ";password=" + dbpassword
driver = "com.microsoft.sqlserver.jdbc.SQLServerDriver"

Class.forName(driver).newInstance()
cn = DriverManager.getConnection(url)
sql = u"SELECT * FROM 車名コード WHERE コード=?"  # ?(クエスチョン)はプレースホルダ
st = cn.prepareStatement(sql)
st.setInt(1, 194)   # 1つ目のプレースホルダに整数194を指定
try:
    rs = st.executeQuery();
    while rs.next():
        print rs.getInt(u"コード"), rs.getString(u"車名表示名"), rs.getString(u"車名英文字") 
except Exception, e:
    print e.args[0]
finally:
    rs.close()
    st.close()
    cn.close() 

結果

194 トヨタ TOYOTA