Module com.microsoft.sqlserver.jdbc
Package com.microsoft.sqlserver.jdbc
Class SQLServerBulkCSVFileRecord
- java.lang.Object
- 
- com.microsoft.sqlserver.jdbc.SQLServerBulkCSVFileRecord
 
- 
- All Implemented Interfaces:
- ISQLServerBulkData,- ISQLServerBulkRecord,- Serializable,- AutoCloseable
 
 public class SQLServerBulkCSVFileRecord extends Object implements AutoCloseable Provides a simple implementation of the ISQLServerBulkRecord interface that can be used to read in the basic Java data types from a delimited file where each line represents a row of data.- See Also:
- Serialized Form
 
- 
- 
Field SummaryFields Modifier and Type Field Description protected Map<Integer,com.microsoft.sqlserver.jdbc.SQLServerBulkRecord.ColumnMetadata>columnMetadataMetadata to represent the columns in the batch/file.protected String[]columnNamesContains all the column names if firstLineIsColumnNames is trueprotected DateTimeFormatterdateTimeFormatterContains the format that java.sql.Types.TIMESTAMP_WITH_TIMEZONE data should be read in as.protected DateTimeFormattertimeFormatterContains the format that java.sql.Types.TIME_WITH_TIMEZONE data should be read in as.
 - 
Constructor SummaryConstructors Constructor Description SQLServerBulkCSVFileRecord(InputStream fileToParse, String encoding, String delimiter, boolean firstLineIsColumnNames)Constructs a SQLServerBulkCSVFileRecord to parse data from a delimited file with the given encoding.SQLServerBulkCSVFileRecord(String fileToParse, boolean firstLineIsColumnNames)Constructs a SQLServerBulkCSVFileRecord to parse data from a CSV file with the default encoding.SQLServerBulkCSVFileRecord(String fileToParse, String encoding, boolean firstLineIsColumnNames)Constructs a SQLServerBulkCSVFileRecord to parse data from a CSV file with the given encoding.SQLServerBulkCSVFileRecord(String fileToParse, String encoding, String delimiter, boolean firstLineIsColumnNames)Constructs a simple reader to parse data from a delimited file with the given encoding.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaddColumnMetadata(int positionInSource, String name, int jdbcType, int precision, int scale)Adds metadata for the given column in the file.voidaddColumnMetadata(int positionInSource, String name, int jdbcType, int precision, int scale, DateTimeFormatter dateTimeFormatter)Adds metadata for the given column in the file.voidclose()Releases any resources associated with the file reader.DateTimeFormattergetColumnDateTimeFormatter(int column)Returns thedateTimeFormatterfor the given column.StringgetColumnName(int column)Returns the name of the given column.Set<Integer>getColumnOrdinals()Returns the ordinals for each of the columns represented in this data record.intgetColumnType(int column)Returns the JDBC data type of the given column.intgetPrecision(int column)Returns the precision for the given column.Object[]getRowData()Returns the data for the current row as an array of Objects.intgetScale(int column)Returns the scale for the given column.booleanisAutoIncrement(int column)Returns whether the column represents an identity column.booleanisEscapeColumnDelimitersCSV()Returns whether the rules to escape delimiters are used.booleannext()Advances to the next data row.voidsetEscapeColumnDelimitersCSV(boolean escapeDelimiters)When set to true, the following rules will be used to parse CSV files: Each field may or may not be enclosed in double quotes.voidsetTimestampWithTimezoneFormat(String dateTimeFormat)Sets the format for reading in dates from the file.voidsetTimestampWithTimezoneFormat(DateTimeFormatter dateTimeFormatter)Sets the format for reading in dates from the file.voidsetTimeWithTimezoneFormat(String timeFormat)Sets the format for reading in dates from the file.voidsetTimeWithTimezoneFormat(DateTimeFormatter dateTimeFormatter)Sets the format for reading in dates from the file.
 
- 
- 
- 
Field Detail- 
columnNamesprotected String[] columnNames Contains all the column names if firstLineIsColumnNames is true
 - 
columnMetadataprotected transient Map<Integer,com.microsoft.sqlserver.jdbc.SQLServerBulkRecord.ColumnMetadata> columnMetadata Metadata to represent the columns in the batch/file. Each column should be mapped to its corresponding position within the parameter (from position 1 and onwards)
 - 
dateTimeFormatterprotected transient DateTimeFormatter dateTimeFormatter Contains the format that java.sql.Types.TIMESTAMP_WITH_TIMEZONE data should be read in as.
 - 
timeFormatterprotected transient DateTimeFormatter timeFormatter Contains the format that java.sql.Types.TIME_WITH_TIMEZONE data should be read in as.
 
- 
 - 
Constructor Detail- 
SQLServerBulkCSVFileRecordpublic SQLServerBulkCSVFileRecord(String fileToParse, String encoding, String delimiter, boolean firstLineIsColumnNames) throws SQLServerException Constructs a simple reader to parse data from a delimited file with the given encoding.- Parameters:
- fileToParse- File to parse data from.
- encoding- Charset encoding to use for reading the file, or NULL for the default encoding.
- delimiter- Delimiter to used to separate each column. Regex characters must be escaped with double backslashes.
- firstLineIsColumnNames- True if the first line of the file should be parsed as column names; false otherwise
- Throws:
- SQLServerException- If the arguments are invalid, there are any errors in reading the file, or the file is empty
 
 - 
SQLServerBulkCSVFileRecordpublic SQLServerBulkCSVFileRecord(InputStream fileToParse, String encoding, String delimiter, boolean firstLineIsColumnNames) throws SQLServerException Constructs a SQLServerBulkCSVFileRecord to parse data from a delimited file with the given encoding.- Parameters:
- fileToParse- InputStream to parse data from
- encoding- Charset encoding to use for reading the file, or NULL for the default encoding.
- delimiter- Delimiter to used to separate each column. Regex characters must be escaped with double backslashes.
- firstLineIsColumnNames- True if the first line of the file should be parsed as column names; false otherwise
- Throws:
- SQLServerException- If the arguments are invalid, there are any errors in reading the file, or the file is empty
 
 - 
SQLServerBulkCSVFileRecordpublic SQLServerBulkCSVFileRecord(String fileToParse, String encoding, boolean firstLineIsColumnNames) throws SQLServerException Constructs a SQLServerBulkCSVFileRecord to parse data from a CSV file with the given encoding.- Parameters:
- fileToParse- File to parse data from
- encoding- Charset encoding to use for reading the file.
- firstLineIsColumnNames- True if the first line of the file should be parsed as column names; false otherwise
- Throws:
- SQLServerException- If the arguments are invalid, there are any errors in reading the file, or the file is empty
 
 - 
SQLServerBulkCSVFileRecordpublic SQLServerBulkCSVFileRecord(String fileToParse, boolean firstLineIsColumnNames) throws SQLServerException Constructs a SQLServerBulkCSVFileRecord to parse data from a CSV file with the default encoding.- Parameters:
- fileToParse- File to parse data from
- firstLineIsColumnNames- True if the first line of the file should be parsed as column names; false otherwise
- Throws:
- SQLServerException- If the arguments are invalid, there are any errors in reading the file, or the file is empty
 
 
- 
 - 
Method Detail- 
closepublic void close() throws SQLServerExceptionReleases any resources associated with the file reader.- Specified by:
- closein interface- AutoCloseable
- Throws:
- SQLServerException- when an error occurs
 
 - 
getRowDatapublic Object[] getRowData() throws SQLServerException Description copied from interface:ISQLServerBulkDataReturns the data for the current row as an array of Objects. Each Object must match the Java language Type that is used to represent the indicated JDBC data type for the given column. For more information, see 'Understanding the JDBC Driver Data Types' for the appropriate mappings.- Specified by:
- getRowDatain interface- ISQLServerBulkData
- Returns:
- The data for the row.
- Throws:
- SQLServerException- If there are any errors in obtaining the data.
 
 - 
nextpublic boolean next() throws SQLServerExceptionDescription copied from interface:ISQLServerBulkDataAdvances to the next data row.- Specified by:
- nextin interface- ISQLServerBulkData
- Returns:
- True if rows are available; false if there are no more rows
- Throws:
- SQLServerException- If there are any errors in advancing to the next row.
 
 - 
isEscapeColumnDelimitersCSVpublic boolean isEscapeColumnDelimitersCSV() Returns whether the rules to escape delimiters are used.- Returns:
- true if the rules are used, false otherwise.
 
 - 
setEscapeColumnDelimitersCSVpublic void setEscapeColumnDelimitersCSV(boolean escapeDelimiters) When set to true, the following rules will be used to parse CSV files: Each field may or may not be enclosed in double quotes. If fields are not enclosed with double quotes, then double quotes may not appear inside the fields. Fields containing double quotes, and delimiters should be enclosed in double quotes. If double-quotes are used to enclose fields, then a double-quote appearing inside a field must be escaped by preceding it with another double quote. Spaces are considered part of a field. Spaces before and after enclosing double quotes are ignored.- Parameters:
- escapeDelimiters- true if the rules above to be used.
 
 - 
addColumnMetadatapublic void addColumnMetadata(int positionInSource, String name, int jdbcType, int precision, int scale, DateTimeFormatter dateTimeFormatter) throws SQLServerExceptionDescription copied from interface:ISQLServerBulkRecordAdds metadata for the given column in the file.- Specified by:
- addColumnMetadatain interface- ISQLServerBulkRecord
- Parameters:
- positionInSource- Indicates which column the metadata is for. Columns start at 1.
- name- Name for the column (optional if only using column ordinal in a mapping for SQLServerBulkCopy operation)
- jdbcType- JDBC data type of the column
- precision- Precision for the column (ignored for the appropriate data types)
- scale- Scale for the column (ignored for the appropriate data types)
- dateTimeFormatter- format to parse data that is sent
- Throws:
- SQLServerException- when an error occurs
 
 - 
addColumnMetadatapublic void addColumnMetadata(int positionInSource, String name, int jdbcType, int precision, int scale) throws SQLServerExceptionDescription copied from interface:ISQLServerBulkRecordAdds metadata for the given column in the file.- Specified by:
- addColumnMetadatain interface- ISQLServerBulkRecord
- Parameters:
- positionInSource- Indicates which column the metadata is for. Columns start at 1.
- name- Name for the column (optional if only using column ordinal in a mapping for SQLServerBulkCopy operation)
- jdbcType- JDBC data type of the column
- precision- Precision for the column (ignored for the appropriate data types)
- scale- Scale for the column (ignored for the appropriate data types)
- Throws:
- SQLServerException- when an error occurs
 
 - 
setTimestampWithTimezoneFormatpublic void setTimestampWithTimezoneFormat(String dateTimeFormat) Description copied from interface:ISQLServerBulkRecordSets the format for reading in dates from the file.- Specified by:
- setTimestampWithTimezoneFormatin interface- ISQLServerBulkRecord
- Parameters:
- dateTimeFormat- format to parse data sent as java.sql.Types.TIMESTAMP_WITH_TIMEZONE
 
 - 
setTimestampWithTimezoneFormatpublic void setTimestampWithTimezoneFormat(DateTimeFormatter dateTimeFormatter) Description copied from interface:ISQLServerBulkRecordSets the format for reading in dates from the file.- Specified by:
- setTimestampWithTimezoneFormatin interface- ISQLServerBulkRecord
- Parameters:
- dateTimeFormatter- format to parse data sent as java.sql.Types.TIMESTAMP_WITH_TIMEZONE
 
 - 
setTimeWithTimezoneFormatpublic void setTimeWithTimezoneFormat(String timeFormat) Description copied from interface:ISQLServerBulkRecordSets the format for reading in dates from the file.- Specified by:
- setTimeWithTimezoneFormatin interface- ISQLServerBulkRecord
- Parameters:
- timeFormat- format to parse data sent as java.sql.Types.TIME_WITH_TIMEZONE
 
 - 
setTimeWithTimezoneFormatpublic void setTimeWithTimezoneFormat(DateTimeFormatter dateTimeFormatter) Description copied from interface:ISQLServerBulkRecordSets the format for reading in dates from the file.- Specified by:
- setTimeWithTimezoneFormatin interface- ISQLServerBulkRecord
- Parameters:
- dateTimeFormatter- format to parse data sent as java.sql.Types.TIME_WITH_TIMEZONE
 
 - 
getColumnDateTimeFormatterpublic DateTimeFormatter getColumnDateTimeFormatter(int column) Description copied from interface:ISQLServerBulkRecordReturns thedateTimeFormatterfor the given column.- Specified by:
- getColumnDateTimeFormatterin interface- ISQLServerBulkRecord
- Parameters:
- column- Column ordinal
- Returns:
- dateTimeFormatter
 
 - 
getColumnOrdinalspublic Set<Integer> getColumnOrdinals() Description copied from interface:ISQLServerBulkDataReturns the ordinals for each of the columns represented in this data record.- Specified by:
- getColumnOrdinalsin interface- ISQLServerBulkData
- Returns:
- Set of ordinals for the columns.
 
 - 
getColumnNamepublic String getColumnName(int column) Description copied from interface:ISQLServerBulkDataReturns the name of the given column.- Specified by:
- getColumnNamein interface- ISQLServerBulkData
- Parameters:
- column- Column ordinal
- Returns:
- Name of the column
 
 - 
getColumnTypepublic int getColumnType(int column) Description copied from interface:ISQLServerBulkDataReturns the JDBC data type of the given column.- Specified by:
- getColumnTypein interface- ISQLServerBulkData
- Parameters:
- column- Column ordinal
- Returns:
- JDBC data type of the column
 
 - 
getPrecisionpublic int getPrecision(int column) Description copied from interface:ISQLServerBulkDataReturns the precision for the given column.- Specified by:
- getPrecisionin interface- ISQLServerBulkData
- Parameters:
- column- Column ordinal
- Returns:
- Precision of the column
 
 - 
getScalepublic int getScale(int column) Description copied from interface:ISQLServerBulkDataReturns the scale for the given column.- Specified by:
- getScalein interface- ISQLServerBulkData
- Parameters:
- column- Column ordinal
- Returns:
- Scale of the column
 
 - 
isAutoIncrementpublic boolean isAutoIncrement(int column) Description copied from interface:ISQLServerBulkRecordReturns whether the column represents an identity column.- Specified by:
- isAutoIncrementin interface- ISQLServerBulkRecord
- Parameters:
- column- Column ordinal
- Returns:
- True if the column is an identity column; false otherwise.
 
 
- 
 
-