1 package jp.co.areaweb.tools.database;
\r
5 import jp.co.areaweb.tools.core.JapaneseString;
\r
9 * SQL文が記述されたファイルを読み込んで実行する。
\r
11 * ・SELECTコマンドは実行できない。
\r
15 /** コマンドラインラインからdoSQLを実行する。
\r
16 * java DoSQL [SQLファイル名]
\r
17 * exp) java dbtool.DoSQL sqlfile.sql
\r
20 static public void main(String[] args) {
\r
21 if (args.length < 2) {
\r
22 System.out.println("exp: java dbtool.DoSQL [propertieFile] [sqlfile]");
\r
25 DoSQL.doSQL(args[0], args[1]);
\r
30 * sqlfileの中のSQL文を1行づつ実行する。
\r
32 * ・一つのSQL文は1行で記述すること。(途中改行はだめ)
\r
33 * @param sqlfile SQL文が記述されたファイル。
\r
35 public static void doSQL(String propertieFile, String sqlfile) {
\r
36 Connection conn = null;
\r
38 conn = DatabaseTool.openDb(propertieFile);
\r
40 BufferedReader ds = new BufferedReader(new InputStreamReader(new FileInputStream(sqlfile)));
\r
42 while ((sqlStr = ds.readLine()) != null) {
\r
43 sqlStr = JapaneseString.trim(sqlStr);
\r
44 if (sqlStr.endsWith(";")) {
\r
45 sqlStr = sqlStr.substring(0, sqlStr.length() - 1);
\r
47 System.out.println(sqlStr);
\r
48 sqlExecute(conn, sqlStr);
\r
52 System.out.println("SQL Finished");
\r
54 catch(Exception e) {
\r
55 // Print out the error message
\r
56 System.out.println(e);
\r
57 e.printStackTrace();
\r
61 DatabaseTool.closeDb(conn);
\r
68 * @param conn データベースコネクション
\r
69 * @param sqlStr 実行するSQL文
\r
70 * @throws SQLException SQL実行エラー
\r
72 static void sqlExecute(Connection conn, String sqlStr) throws SQLException {
\r
73 // Create a statement object
\r
74 Statement stat = conn.createStatement();
\r
76 // For compatibility to other database, use varchar(255)
\r
77 // In Hypersonic SQL, length is unlimited, like Java Strings
\r
78 stat.execute(sqlStr);
\r
80 // Close the Statement object, it is no longer used
\r