
org.h2gis.functions.io.shp.SHPWrite Maven / Gradle / Ivy
The newest version!
/**
* H2GIS is a library that brings spatial support to the H2 Database Engine
* . H2GIS is developed by CNRS
* .
*
* This code is part of the H2GIS project. H2GIS is free software;
* you can redistribute it and/or modify it under the terms of the GNU
* Lesser General Public License as published by the Free Software Foundation;
* version 3.0 of the License.
*
* H2GIS is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License
* for more details .
*
*
* For more information, please consult:
* or contact directly: info_at_h2gis.org
*/
package org.h2gis.functions.io.shp;
import org.h2gis.api.AbstractFunction;
import org.h2gis.api.EmptyProgressVisitor;
import org.h2gis.api.ScalarFunction;
import org.h2gis.utilities.URIUtilities;
import java.io.IOException;
import java.sql.Connection;
import java.sql.SQLException;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
/**
* SQL Function to read a table and write it into a shape file.
* @author Nicolas Fortin
*/
public class SHPWrite extends AbstractFunction implements ScalarFunction {
public SHPWrite() {
addProperty(PROP_REMARKS, "Transfer the content of a table into a new shape file\nCALL SHPWRITE('FILENAME', 'TABLE'[,'ENCODING'])");
}
@Override
public String getJavaStaticMethod() {
return "exportTable"; //To change body of implemented methods use File | Settings | File Templates.
}
/**
* Read a table and write it into a shape file.
* @param connection Active connection
* @param fileName Shape file name or URI
* @param tableReference Table name
* @throws IOException
* @throws SQLException
*/
public static void exportTable(Connection connection, String fileName, String tableReference) throws IOException, SQLException {
exportTable(connection, fileName, tableReference, null);
}
/**
* Read a table and write it into a shape file.
* @param connection Active connection
* @param fileName Shape file name or URI
* @param tableReference Table name or select query
* Note : The select query must be enclosed in parenthesis
* @param encoding File encoding
* @throws IOException
* @throws SQLException
*/
public static void exportTable(Connection connection, String fileName, String tableReference, String encoding) throws IOException, SQLException {
String regex = ".*(?i)\\b(select|from)\\b.*";
Pattern pattern = Pattern.compile(regex);
Matcher matcher = pattern.matcher(tableReference);
SHPDriverFunction shpDriverFunction = new SHPDriverFunction();
if (matcher.find()) {
if (tableReference.startsWith("(") && tableReference.endsWith(")")) {
shpDriverFunction.exportResultset(connection, tableReference, URIUtilities.fileFromString(fileName), new EmptyProgressVisitor(), encoding);
} else {
throw new SQLException("The select query must be enclosed in parenthesis: '(SELECT * FROM ORDERS)'.");
}
} else {
shpDriverFunction.exportTable(connection, tableReference, URIUtilities.fileFromString(fileName), new EmptyProgressVisitor(), encoding);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy