DataHelper.java 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208
  1. /*
  2. * To change this license header, choose License Headers in Project Properties.
  3. * To change this template file, choose Tools | Templates
  4. * and open the template in the editor.
  5. */
  6. package datahelper;
  7. import com.microsoft.sqlserver.jdbc.SQLServerBulkCopy;
  8. import java.lang.reflect.Method;
  9. import java.sql.Connection;
  10. import java.sql.PreparedStatement;
  11. import java.sql.ResultSet;
  12. import java.sql.ResultSetMetaData;
  13. import java.sql.Types;
  14. /**
  15. *
  16. * @author Lisewski
  17. */
  18. public class DataHelper {
  19. static Method[] colMethods;
  20. /**
  21. * @param args the command line arguments
  22. */
  23. public static void main(String[] args) throws Exception {
  24. }
  25. public static int CopyData(Connection sourceCon, Connection targetCon, String sourceSql, String targetTable, boolean dropTargetTable) throws Exception {
  26. var iRow = 0;
  27. var iBuffer = 50000;
  28. var sourceCommand = sourceCon.createStatement();
  29. var dataReader = sourceCommand.executeQuery(sourceSql);
  30. var schemaTable = dataReader.getMetaData();
  31. targetCon.setAutoCommit(false);
  32. // create the insert statement and create table if it doesn't exist
  33. CreateTable(targetCon, schemaTable, targetTable, dropTargetTable);
  34. // if target is sqlserver do a bulkcopy
  35. if (targetCon.getMetaData().getDriverName().contains("SQL Server")) {
  36. SQLServerBulkCopy bulkCopy = new SQLServerBulkCopy(targetCon);
  37. bulkCopy.setDestinationTableName(targetTable);
  38. bulkCopy.writeToServer(dataReader);
  39. targetCon.commit();
  40. var cmd = targetCon.createStatement();
  41. var rs = cmd.executeQuery(String.format("SELECT COUNT(1) FROM %s", targetTable));
  42. rs.next();
  43. iRow = rs.getInt(1);
  44. } else {
  45. var targetCommand = PrepareCommand(targetCon, schemaTable, targetTable);
  46. while (dataReader.next()) {
  47. iRow++;
  48. SetParams(dataReader, schemaTable, targetCommand);
  49. targetCommand.addBatch();
  50. if (iRow % iBuffer == 0) {
  51. targetCommand.executeBatch();
  52. targetCon.commit();
  53. }
  54. }
  55. if (iRow % iBuffer != 0) {
  56. targetCommand.executeBatch();
  57. targetCon.commit();
  58. }
  59. }
  60. return iRow;
  61. }
  62. private static void CreateTable(Connection dbConnection, ResultSetMetaData schemaTable, String tableName, boolean withDrop) throws Exception {
  63. var dbTypeName = dbConnection.getMetaData().getDriverName();
  64. System.out.println(dbTypeName);
  65. if (withDrop) {
  66. try {
  67. dbConnection.createStatement().executeUpdate(String.format("DROP TABLE IF EXISTS %s", tableName));
  68. dbConnection.commit();
  69. } catch (Exception ex) {
  70. dbConnection.createStatement().executeUpdate(String.format("DROP TABLE %s", tableName));
  71. dbConnection.commit();
  72. }
  73. }
  74. var createNotExists = (dbTypeName.contains("SQL Server"))
  75. ? String.format("IF OBJECT_ID('%s') IS NULL CREATE TABLE", tableName)
  76. : "CREATE TABLE IF NOT EXISTS";
  77. if (dbTypeName.contains("Derby")) {
  78. createNotExists = "CREATE TABLE";
  79. }
  80. var Sql = new StringBuilder(String.format("%s %s (", createNotExists, tableName));
  81. var iColumns = schemaTable.getColumnCount();
  82. colMethods = new Method[iColumns];
  83. for (var i = 1; i < iColumns + 1; i++) {
  84. if (i > 1) {
  85. Sql.append(", ");
  86. }
  87. var name = schemaTable.getColumnName(i);
  88. var dt = schemaTable.getColumnTypeName(i);
  89. var type = schemaTable.getColumnType(i);
  90. var size = schemaTable.getPrecision(i);
  91. var nullable = schemaTable.isNullable(i) == 1;
  92. colMethods[i-1] = getAccessMethod(type);
  93. Sql.append(String.format("%s %s", '"' + name + '"', dt));
  94. if (dt.toLowerCase().endsWith("char")) {
  95. Sql.append(String.format("(%d)", size));
  96. }
  97. if (!nullable) {
  98. Sql.append(" NOT NULL");
  99. }
  100. }
  101. Sql.append(")");
  102. var sqlString = Sql.toString();
  103. if (dbTypeName.contains("PostgreSQL") || dbTypeName.contains("Derby")) {
  104. sqlString = sqlString.replaceAll("datetime", "timestamp");
  105. sqlString = sqlString.replaceAll("tinyint", "int");
  106. sqlString = sqlString.replaceAll("bit", "boolean");
  107. }
  108. var createCommand = dbConnection.createStatement();
  109. System.out.println(sqlString);
  110. // Assume the table already exists and ignore the create
  111. try {
  112. createCommand.executeUpdate(sqlString);
  113. dbConnection.commit();
  114. } catch (Exception ex) {
  115. }
  116. }
  117. private static PreparedStatement PrepareCommand(Connection dbConnection, ResultSetMetaData schemaTable, String tableName) throws Exception {
  118. var sbFields = new StringBuilder();
  119. var sbFmtValues = new StringBuilder();
  120. var iColumns = schemaTable.getColumnCount();
  121. for (var i = 1; i < iColumns + 1; i++) {
  122. var columnName = schemaTable.getColumnName(i);
  123. sbFields.append(i > 1 ? ", " : "");
  124. sbFields.append('"' + columnName + '"');
  125. sbFmtValues.append(i > 1 ? ", " : "");
  126. sbFmtValues.append("?");
  127. }
  128. var insertSql = String.format("INSERT INTO %s (%s) VALUES (%s)", tableName, sbFields.toString(), sbFmtValues.toString());
  129. System.out.println(insertSql);
  130. var cmd = dbConnection.prepareStatement(insertSql);
  131. return cmd;
  132. }
  133. private static void SetParams(ResultSet dr, ResultSetMetaData schemaTable, PreparedStatement cmd) throws Exception {
  134. var iColumns = schemaTable.getColumnCount();
  135. for (var i = 1; i < iColumns + 1; i++) {
  136. // cmd.setObject(i, dr.getObject(i), dr.getType());
  137. cmd.setObject(i, colMethods[i-1].invoke(dr, i));
  138. }
  139. }
  140. private static Method getAccessMethod(int type) throws Exception {
  141. switch (type) {
  142. case Types.BIT:
  143. case Types.TINYINT:
  144. case Types.SMALLINT:
  145. case Types.INTEGER:
  146. return ResultSet.class.getMethod("getInt", int.class);
  147. case Types.BIGINT:
  148. return ResultSet.class.getMethod("getLong", int.class);
  149. case Types.FLOAT:
  150. return ResultSet.class.getMethod("getFloat", int.class);
  151. case Types.REAL:
  152. case Types.DOUBLE:
  153. case Types.NUMERIC:
  154. case Types.DECIMAL:
  155. return ResultSet.class.getMethod("getLong", int.class);
  156. case Types.CHAR:
  157. case Types.VARCHAR:
  158. case Types.LONGVARCHAR:
  159. return ResultSet.class.getMethod("getString", int.class);
  160. case Types.DATE:
  161. return ResultSet.class.getMethod("getDate", int.class);
  162. case Types.TIME:
  163. return ResultSet.class.getMethod("getTime", int.class);
  164. case Types.TIMESTAMP:
  165. return ResultSet.class.getMethod("getTimestamp", int.class);
  166. case Types.BINARY:
  167. case Types.VARBINARY:
  168. case Types.LONGVARBINARY:
  169. case Types.NULL:
  170. case Types.OTHER:
  171. case Types.JAVA_OBJECT:
  172. case Types.DISTINCT:
  173. case Types.STRUCT:
  174. case Types.ARRAY:
  175. case Types.BLOB:
  176. case Types.CLOB:
  177. case Types.NCLOB:
  178. case Types.REF:
  179. case Types.DATALINK:
  180. return ResultSet.class.getMethod("getBlob", int.class);
  181. case Types.BOOLEAN:
  182. return ResultSet.class.getMethod("getInt", int.class);
  183. case Types.ROWID:
  184. case Types.NCHAR:
  185. case Types.NVARCHAR:
  186. case Types.LONGNVARCHAR:
  187. case Types.SQLXML:
  188. return ResultSet.class.getMethod("getString", int.class);
  189. }
  190. return ResultSet.class.getMethod("getObject", int.class);
  191. }
  192. }