Newer
Older
osmCoverage / src / osm / jp / postgis / Do_sqlfiles.java
@yuu yuu on 20 Mar 2017 3 KB Nagoya busstop to OSM file.
package osm.jp.postgis;
import java.io.*;
import java.sql.Connection;
import java.sql.SQLException;
import java.sql.Statement;

import jp.co.areaweb.tools.database.*;

public class Do_sqlfiles {
	static String sqlFileName = "busstop.sql";
	
	/**
	 * メイン
	 *
	 *	java -cp .:SelectBusstop.jar:hayashi_0225.jar:postgresql-9.4.1212.jar osm.jp.SelectBusstop
	 *	
	 *
	 * @throws IOException
	 * @throws SQLException
	 * @throws ClassNotFoundException
	 * @throws FileNotFoundException
	 * @throws TransformerException
	 * @throws SAXException
	 * @throws ParserConfigurationException */
	public static void main(String[] args) throws FileNotFoundException, ClassNotFoundException, SQLException, IOException
	{
		for (int i=0; i < args.length; i++) {
			if (args[i].equals("-update")) {
				sqlFileName = "update.sql";
			}
		}

		Connection con = DatabaseTool.openDb("postgis");
		
		try {
			/**
			 * 都道府県ごとのGMLディレクトリの処理
			 */
			File dir = new File(".");
			File[] dirs = dir.listFiles();
			for (File iDir : dirs) {
				if (checkGMLdir(iDir)) {
					System.out.println(iDir.getName());
					
					File[] files = iDir.listFiles();
					for (File iFile : files) {
						if (checkFile(iFile)) {
							System.out.println(iFile.getAbsoluteFile());
							Do_sqlfiles.sqlExecute(con, iFile);
						}
					}
				}
			}
		}
		finally {
			DatabaseTool.closeDb(con);
		}
	}
	
    /**
     * sqlFileを実行する
     * @param conn データベースコネクション
     * @param sqlFile 実行するSQLファイル
     * @throws SQLException SQL実行エラー
     * @throws IOException 
     */
    public static void sqlExecute(Connection conn, File sqlFile) throws SQLException, IOException {
		// ローカルデータベース内の情報をPostGIS用の「busstop.sql」に出力する
		BufferedReader br  = new BufferedReader(new InputStreamReader(new FileInputStream(sqlFile), "UTF-8"));

	    // 既存のreadLine()では\rまたは\n、および\r\nにて改行とみなしている。
	    String strLine  = null;
	    while ((strLine = br.readLine()) != null) { // null=ファイルの最後
	        sqlExecute(conn, strLine);
	    }
        sqlExecute(conn, "commit;");
	    br.close();
    }
	
    /**
     * sqlStrを実行する
     * @param conn データベースコネクション
     * @param sqlStr 実行するSQL文
     * @throws SQLException SQL実行エラー
     */
    public static void sqlExecute(Connection conn, String sqlStr) throws SQLException {
    	if ((sqlStr != null) && (!sqlStr.trim().equals(""))) {
	    	System.out.println(sqlStr);
            Statement stat = conn.createStatement();
            stat.execute(sqlStr);
            stat.close();
    	}
    }
	
	/**
	 * 数値地図情報のデータファイルかどうかを見極める
	 * @param f
	 * @return
	 */
	static boolean checkGMLdir(File f) {
		if (!f.isDirectory()) {
			return false;
		}
		String name = f.getName();
		if (!name.startsWith(GML_DIR_PREFIX)) {
			return false;
		}
		if (!name.toUpperCase().endsWith(GML_DIR_PRIFIX)) {
			return false;
		}
		return true;
	}

	public static final String GML_DIR_PREFIX = "P11-10_";
	public static final String GML_DIR_PRIFIX = "_GML";

	/**
	 * SQLファイルかどうかを見極める
	 * @param f
	 * @return
	 */
	static boolean checkFile(File f) {
		String name = f.getName();
		if (name.equals(sqlFileName)) {
			return true;
		}
		return false;
	}

}