2009年9月14日月曜日

groovyとSQL Serverでデータベース一覧を表示する

groovyとSQL Serverでデータベース一覧を表示するには、以下のコードを実行します。


import groovy.sql.Sql

sql = Sql.newInstance(
"jdbc:sqlserver://localhost;databaseName=master",
"sa",
"sa",
"com.microsoft.sqlserver.jdbc.SQLServerDriver")

sql.eachRow("select * from sys.databases") {
// データベース名
println "name:${it.name}"
// データベースID
println "database_id:${it.database_id}"
// 作成日
println "create_date:${it.create_date}"
// データベース状態の説明
println "state_desc:${it.state_desc}"
println "----"
}


実行結果

name:master
database_id:1
create_date:2003-04-08 09:13:36.39
state_desc:ONLINE
----
name:tempdb
database_id:2
create_date:2009-08-09 23:39:24.29
state_desc:ONLINE
----
name:model
database_id:3
create_date:2003-04-08 09:13:36.39
state_desc:ONLINE
----
name:msdb
database_id:4
create_date:2008-07-09 16:46:27.767
state_desc:ONLINE
----
name:test1
database_id:5
create_date:2009-08-09 23:10:04.197
state_desc:ONLINE
----


動作環境
Groovy 1.6.3, JDK6 Update14, SQL Server JDBC Driver 2.0,
SQL Server 2008 Express

関連情報
sys.databases
http://msdn.microsoft.com/ja-jp/library/ms178534.aspx

WSHでODBCによる同様の処理を行うには、以下のコードを実行します。

cs = "Driver={SQL Server};Server=SQLSRV\SQLEXPRESS;Uid=sa;Pwd=sa;Database=master"
set conn = CreateObject("ADODB.Connection")
on error resume next
conn.open cs
if err.number <> 0 then
WScript.StdOut.WriteLine err.description
WScript.Quit
end if
set rs = conn.execute("select * from sys.databases")
if err.number <> 0 then
WScript.StdOut.WriteLine err.description
conn.close
WScript.Quit
end if
Do While Not rs.EOF
' データベース名
WScript.StdOut.WriteLine rs.Fields("name").value
rs.Movenext
Loop
conn.close
on error goto 0

0 件のコメント:

コメントを投稿