📄 csvstatement.java
字号:
/**
Copyright (C) 2002-2003 Together
This library 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; either
version 2.1 of the License, or (at your option) any later version.
This library 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.
You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
package org.relique.jdbc.csv;
import java.sql.*;
import java.io.File;
import java.util.Enumeration;
import java.util.Vector;
/**
* This class implements the Statement interface for the CsvJdbc driver.
*
* @author Zoran Milakovic
*/
public class CsvStatement implements Statement
{
private CsvConnection connection;
private Vector resultSets = new Vector();
private CsvWriter writeCsv;
private String sql;
/**
*Constructor for the CsvStatement object
*
* @param connection Description of Parameter
* @since
*/
protected CsvStatement(CsvConnection connection)
{
DriverManager.println("CsvJdbc - CsvStatement() - connection=" + connection);
this.connection = connection;
try {
if(!connection.getAutoCommit())
writeCsv = new CsvWriter(
null,
connection.getSeperator(),
connection.getExtension(),
connection.getMaxFileSize()
);
}
catch(Exception ex) {
ex.printStackTrace();
}
}
/**
*Sets the maxFieldSize attribute of the CsvStatement object
*
* @param p0 The new maxFieldSize value
* @exception SQLException Description of Exception
* @since
*/
public void setMaxFieldSize(int p0) throws SQLException
{
throw new SQLException("Not Supported !");
}
/**
*Sets the maxRows attribute of the CsvStatement object
*
* @param p0 The new maxRows value
* @exception SQLException Description of Exception
* @since
*/
public void setMaxRows(int p0) throws SQLException
{
throw new SQLException("Not Supported !");
}
/**
*Sets the escapeProcessing attribute of the CsvStatement object
*
* @param p0 The new escapeProcessing value
* @exception SQLException Description of Exception
* @since
*/
public void setEscapeProcessing(boolean p0) throws SQLException
{
throw new SQLException("Not Supported !");
}
/**
*Sets the queryTimeout attribute of the CsvStatement object
*
* @param p0 The new queryTimeout value
* @exception SQLException Description of Exception
* @since
*/
public void setQueryTimeout(int p0) throws SQLException
{
throw new SQLException("Not Supported !");
}
/**
*Sets the cursorName attribute of the CsvStatement object
*
* @param p0 The new cursorName value
* @exception SQLException Description of Exception
* @since
*/
public void setCursorName(String p0) throws SQLException
{
throw new SQLException("Not Supported !");
}
/**
*Sets the fetchDirection attribute of the CsvStatement object
*
* @param p0 The new fetchDirection value
* @exception SQLException Description of Exception
* @since
*/
public void setFetchDirection(int p0) throws SQLException
{
throw new SQLException("Not Supported !");
}
/**
*Sets the fetchSize attribute of the CsvStatement object
*
* @param p0 The new fetchSize value
* @exception SQLException Description of Exception
* @since
*/
public void setFetchSize(int p0) throws SQLException
{
throw new SQLException("Not Supported !");
}
/**
*Gets the maxFieldSize attribute of the CsvStatement object
*
* @return The maxFieldSize value
* @exception SQLException Description of Exception
* @since
*/
public int getMaxFieldSize() throws SQLException
{
throw new SQLException("Not Supported !");
}
/**
*Gets the maxRows attribute of the CsvStatement object
*
* @return The maxRows value
* @exception SQLException Description of Exception
* @since
*/
public int getMaxRows() throws SQLException
{
throw new SQLException("Not Supported !");
}
/**
*Gets the queryTimeout attribute of the CsvStatement object
*
* @return The queryTimeout value
* @exception SQLException Description of Exception
* @since
*/
public int getQueryTimeout() throws SQLException
{
throw new SQLException("Not Supported !");
}
/**
*Gets the warnings attribute of the CsvStatement object
*
* @return The warnings value
* @exception SQLException Description of Exception
* @since
*/
public SQLWarning getWarnings() throws SQLException
{
throw new SQLException("Not Supported !");
}
/**
*Gets the resultSet attribute of the CsvStatement object
*
* @return The resultSet value
* @exception SQLException Description of Exception
* @since
*/
public ResultSet getResultSet() throws SQLException
{
throw new SQLException("Not Supported !");
}
/**
*Gets the updateCount attribute of the CsvStatement object
*
* @return The updateCount value
* @exception SQLException Description of Exception
* @since
*/
public int getUpdateCount() throws SQLException
{
throw new SQLException("Not Supported !");
}
/**
*Gets the moreResults attribute of the CsvStatement object
*
* @return The moreResults value
* @exception SQLException Description of Exception
* @since
*/
public boolean getMoreResults() throws SQLException
{
throw new SQLException("Not Supported !");
}
/**
*Gets the fetchDirection attribute of the CsvStatement object
*
* @return The fetchDirection value
* @exception SQLException Description of Exception
* @since
*/
public int getFetchDirection() throws SQLException
{
throw new SQLException("Not Supported !");
}
/**
*Gets the fetchSize attribute of the CsvStatement object
*
* @return The fetchSize value
* @exception SQLException Description of Exception
* @since
*/
public int getFetchSize() throws SQLException
{
throw new SQLException("Not Supported !");
}
/**
*Gets the resultSetConcurrency attribute of the CsvStatement object
*
* @return The resultSetConcurrency value
* @exception SQLException Description of Exception
* @since
*/
public int getResultSetConcurrency() throws SQLException
{
throw new SQLException("Not Supported !");
}
/**
*Gets the resultSetType attribute of the CsvStatement object
*
* @return The resultSetType value
* @exception SQLException Description of Exception
* @since
*/
public int getResultSetType() throws SQLException
{
throw new SQLException("Not Supported !");
}
/**
*Gets the connection attribute of the CsvStatement object
*
* @return The connection value
* @exception SQLException Description of Exception
* @since
*/
public Connection getConnection() throws SQLException
{
return connection;
}
/**
*Description of the Method
*
* @param sql Description of Parameter
* @return Description of the Returned Value
* @exception SQLException Description of Exception
* @since
*/
public ResultSet executeQuery(String sql) throws SQLException
{
DriverManager.println("CsvJdbc - CsvStatement:executeQuery() - sql= " + sql);
CsvSqlParser parser = new CsvSqlParser();
this.sql = sql;
try
{
parser.parse(this);
}
catch (Exception e)
{
throw new SQLException("Syntax Error. " + e.getMessage());
}
String fileName = connection.getPath() + parser.getTableName() + connection.getExtension();
File checkFile = new File(fileName);
if (!checkFile.exists())
{
throw new SQLException("Cannot open data file '" + fileName + "' !");
}
if (!checkFile.canRead())
{
throw new SQLException("Data file '" + fileName + "' not readable !");
}
CsvReader reader;
try
{
reader = new CsvReader(fileName, connection.getSeperator(),
connection.isSuppressHeaders(),
connection.getCharset(),
connection.getExtension(),
connection.getLineBreakEscape(),
// connection.getDoubleQuotesEscape(),
connection.getCarriageReturnEscape()
);
String[] xxx = parser.getColumnNames();
String[] yyy = reader.getColumnNames();
boolean isOK = true;
for(int i=0; i< xxx.length; i++) {
if(!xxx[i].endsWith("*")) {
out:
for(int j=0; j< yyy.length; j++) {
if(xxx[i].equalsIgnoreCase(yyy[j])) {
isOK=true;
break out;
}
else
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -