embulk-output-jdbc 0.4.1 → 0.4.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (40) hide show
  1. checksums.yaml +4 -4
  2. data/build.gradle +2 -2
  3. data/classpath/embulk-output-jdbc-0.4.2.jar +0 -0
  4. data/lib/embulk/output/jdbc.rb +3 -3
  5. data/src/main/java/org/embulk/output/JdbcOutputPlugin.java +137 -138
  6. data/src/main/java/org/embulk/output/jdbc/AbstractJdbcOutputPlugin.java +972 -973
  7. data/src/main/java/org/embulk/output/jdbc/BatchInsert.java +52 -53
  8. data/src/main/java/org/embulk/output/jdbc/JdbcColumn.java +116 -116
  9. data/src/main/java/org/embulk/output/jdbc/JdbcColumnOption.java +34 -34
  10. data/src/main/java/org/embulk/output/jdbc/JdbcOutputConnection.java +492 -492
  11. data/src/main/java/org/embulk/output/jdbc/JdbcOutputConnector.java +8 -8
  12. data/src/main/java/org/embulk/output/jdbc/JdbcSchema.java +60 -60
  13. data/src/main/java/org/embulk/output/jdbc/JdbcUtils.java +153 -155
  14. data/src/main/java/org/embulk/output/jdbc/StandardBatchInsert.java +200 -200
  15. data/src/main/java/org/embulk/output/jdbc/ToString.java +54 -54
  16. data/src/main/java/org/embulk/output/jdbc/ToStringMap.java +34 -35
  17. data/src/main/java/org/embulk/output/jdbc/setter/BigDecimalColumnSetter.java +68 -70
  18. data/src/main/java/org/embulk/output/jdbc/setter/BooleanColumnSetter.java +53 -54
  19. data/src/main/java/org/embulk/output/jdbc/setter/ByteColumnSetter.java +75 -76
  20. data/src/main/java/org/embulk/output/jdbc/setter/ColumnSetter.java +44 -45
  21. data/src/main/java/org/embulk/output/jdbc/setter/ColumnSetterFactory.java +196 -196
  22. data/src/main/java/org/embulk/output/jdbc/setter/ColumnSetterVisitor.java +95 -96
  23. data/src/main/java/org/embulk/output/jdbc/setter/DefaultValueSetter.java +48 -48
  24. data/src/main/java/org/embulk/output/jdbc/setter/DoubleColumnSetter.java +60 -61
  25. data/src/main/java/org/embulk/output/jdbc/setter/FloatColumnSetter.java +60 -61
  26. data/src/main/java/org/embulk/output/jdbc/setter/IntColumnSetter.java +75 -76
  27. data/src/main/java/org/embulk/output/jdbc/setter/LongColumnSetter.java +71 -72
  28. data/src/main/java/org/embulk/output/jdbc/setter/NStringColumnSetter.java +58 -59
  29. data/src/main/java/org/embulk/output/jdbc/setter/NullColumnSetter.java +53 -53
  30. data/src/main/java/org/embulk/output/jdbc/setter/NullDefaultValueSetter.java +105 -105
  31. data/src/main/java/org/embulk/output/jdbc/setter/PassThroughColumnSetter.java +58 -59
  32. data/src/main/java/org/embulk/output/jdbc/setter/ShortColumnSetter.java +75 -76
  33. data/src/main/java/org/embulk/output/jdbc/setter/SkipColumnSetter.java +43 -43
  34. data/src/main/java/org/embulk/output/jdbc/setter/SqlDateColumnSetter.java +58 -59
  35. data/src/main/java/org/embulk/output/jdbc/setter/SqlTimeColumnSetter.java +58 -59
  36. data/src/main/java/org/embulk/output/jdbc/setter/SqlTimestampColumnSetter.java +58 -58
  37. data/src/main/java/org/embulk/output/jdbc/setter/StringColumnSetter.java +58 -59
  38. data/src/test/java/org/embulk/output/TestJdbcOutputPlugin.java +5 -5
  39. metadata +3 -3
  40. data/classpath/embulk-output-jdbc-0.4.1.jar +0 -0
@@ -1,96 +1,95 @@
1
- package org.embulk.output.jdbc.setter;
2
-
3
- import java.io.IOException;
4
- import java.sql.SQLException;
5
- import org.embulk.spi.Column;
6
- import org.embulk.spi.ColumnVisitor;
7
- import org.embulk.spi.PageReader;
8
- import org.embulk.spi.time.Timestamp;
9
-
10
- public class ColumnSetterVisitor
11
- implements ColumnVisitor
12
- {
13
- private final PageReader pageReader;
14
- private final ColumnSetter setter;
15
-
16
- public ColumnSetterVisitor(PageReader pageReader, ColumnSetter setter)
17
- {
18
- this.pageReader = pageReader;
19
- this.setter = setter;
20
- }
21
-
22
- @Override
23
- public void booleanColumn(Column column)
24
- {
25
- try {
26
- if (pageReader.isNull(column)) {
27
- setter.nullValue();
28
- } else {
29
- setter.booleanValue(pageReader.getBoolean(column));
30
- }
31
- } catch (IOException | SQLException ex) {
32
- // TODO exception class
33
- throw new RuntimeException(ex);
34
- }
35
- }
36
-
37
- @Override
38
- public void longColumn(Column column)
39
- {
40
- try {
41
- if (pageReader.isNull(column)) {
42
- setter.nullValue();
43
- } else {
44
- setter.longValue(pageReader.getLong(column));
45
- }
46
- } catch (IOException | SQLException ex) {
47
- // TODO exception class
48
- throw new RuntimeException(ex);
49
- }
50
- }
51
-
52
- @Override
53
- public void doubleColumn(Column column)
54
- {
55
- try {
56
- if (pageReader.isNull(column)) {
57
- setter.nullValue();
58
- } else {
59
- setter.doubleValue(pageReader.getDouble(column));
60
- }
61
- } catch (IOException | SQLException ex) {
62
- // TODO exception class
63
- throw new RuntimeException(ex);
64
- }
65
- }
66
-
67
- @Override
68
- public void stringColumn(Column column)
69
- {
70
- try {
71
- if (pageReader.isNull(column)) {
72
- setter.nullValue();
73
- } else {
74
- setter.stringValue(pageReader.getString(column));
75
- }
76
- } catch (IOException | SQLException ex) {
77
- // TODO exception class
78
- throw new RuntimeException(ex);
79
- }
80
- }
81
-
82
- @Override
83
- public void timestampColumn(Column column)
84
- {
85
- try {
86
- if (pageReader.isNull(column)) {
87
- setter.nullValue();
88
- } else {
89
- setter.timestampValue(pageReader.getTimestamp(column));
90
- }
91
- } catch (IOException | SQLException ex) {
92
- // TODO exception class
93
- throw new RuntimeException(ex);
94
- }
95
- }
96
- }
1
+ package org.embulk.output.jdbc.setter;
2
+
3
+ import java.io.IOException;
4
+ import java.sql.SQLException;
5
+ import org.embulk.spi.Column;
6
+ import org.embulk.spi.ColumnVisitor;
7
+ import org.embulk.spi.PageReader;
8
+
9
+ public class ColumnSetterVisitor
10
+ implements ColumnVisitor
11
+ {
12
+ private final PageReader pageReader;
13
+ private final ColumnSetter setter;
14
+
15
+ public ColumnSetterVisitor(PageReader pageReader, ColumnSetter setter)
16
+ {
17
+ this.pageReader = pageReader;
18
+ this.setter = setter;
19
+ }
20
+
21
+ @Override
22
+ public void booleanColumn(Column column)
23
+ {
24
+ try {
25
+ if (pageReader.isNull(column)) {
26
+ setter.nullValue();
27
+ } else {
28
+ setter.booleanValue(pageReader.getBoolean(column));
29
+ }
30
+ } catch (IOException | SQLException ex) {
31
+ // TODO exception class
32
+ throw new RuntimeException(ex);
33
+ }
34
+ }
35
+
36
+ @Override
37
+ public void longColumn(Column column)
38
+ {
39
+ try {
40
+ if (pageReader.isNull(column)) {
41
+ setter.nullValue();
42
+ } else {
43
+ setter.longValue(pageReader.getLong(column));
44
+ }
45
+ } catch (IOException | SQLException ex) {
46
+ // TODO exception class
47
+ throw new RuntimeException(ex);
48
+ }
49
+ }
50
+
51
+ @Override
52
+ public void doubleColumn(Column column)
53
+ {
54
+ try {
55
+ if (pageReader.isNull(column)) {
56
+ setter.nullValue();
57
+ } else {
58
+ setter.doubleValue(pageReader.getDouble(column));
59
+ }
60
+ } catch (IOException | SQLException ex) {
61
+ // TODO exception class
62
+ throw new RuntimeException(ex);
63
+ }
64
+ }
65
+
66
+ @Override
67
+ public void stringColumn(Column column)
68
+ {
69
+ try {
70
+ if (pageReader.isNull(column)) {
71
+ setter.nullValue();
72
+ } else {
73
+ setter.stringValue(pageReader.getString(column));
74
+ }
75
+ } catch (IOException | SQLException ex) {
76
+ // TODO exception class
77
+ throw new RuntimeException(ex);
78
+ }
79
+ }
80
+
81
+ @Override
82
+ public void timestampColumn(Column column)
83
+ {
84
+ try {
85
+ if (pageReader.isNull(column)) {
86
+ setter.nullValue();
87
+ } else {
88
+ setter.timestampValue(pageReader.getTimestamp(column));
89
+ }
90
+ } catch (IOException | SQLException ex) {
91
+ // TODO exception class
92
+ throw new RuntimeException(ex);
93
+ }
94
+ }
95
+ }
@@ -1,48 +1,48 @@
1
- package org.embulk.output.jdbc.setter;
2
-
3
- import java.io.IOException;
4
- import java.sql.SQLException;
5
- import org.embulk.output.jdbc.JdbcColumn;
6
- import org.embulk.output.jdbc.BatchInsert;
7
-
8
- public abstract class DefaultValueSetter
9
- {
10
- protected final BatchInsert batch;
11
- protected final JdbcColumn column;
12
-
13
- public DefaultValueSetter(BatchInsert batch, JdbcColumn column)
14
- {
15
- this.batch = batch;
16
- this.column = column;
17
- }
18
-
19
- public abstract void setNull() throws IOException, SQLException;
20
-
21
- public abstract void setBoolean() throws IOException, SQLException;
22
-
23
- public abstract void setByte() throws IOException, SQLException;
24
-
25
- public abstract void setShort() throws IOException, SQLException;
26
-
27
- public abstract void setInt() throws IOException, SQLException;
28
-
29
- public abstract void setLong() throws IOException, SQLException;
30
-
31
- public abstract void setFloat() throws IOException, SQLException;
32
-
33
- public abstract void setDouble() throws IOException, SQLException;
34
-
35
- public abstract void setBigDecimal() throws IOException, SQLException;
36
-
37
- public abstract void setString() throws IOException, SQLException;
38
-
39
- public abstract void setNString() throws IOException, SQLException;
40
-
41
- public abstract void setBytes() throws IOException, SQLException;
42
-
43
- public abstract void setSqlDate() throws IOException, SQLException;
44
-
45
- public abstract void setSqlTime() throws IOException, SQLException;
46
-
47
- public abstract void setSqlTimestamp() throws IOException, SQLException;
48
- }
1
+ package org.embulk.output.jdbc.setter;
2
+
3
+ import java.io.IOException;
4
+ import java.sql.SQLException;
5
+ import org.embulk.output.jdbc.JdbcColumn;
6
+ import org.embulk.output.jdbc.BatchInsert;
7
+
8
+ public abstract class DefaultValueSetter
9
+ {
10
+ protected final BatchInsert batch;
11
+ protected final JdbcColumn column;
12
+
13
+ public DefaultValueSetter(BatchInsert batch, JdbcColumn column)
14
+ {
15
+ this.batch = batch;
16
+ this.column = column;
17
+ }
18
+
19
+ public abstract void setNull() throws IOException, SQLException;
20
+
21
+ public abstract void setBoolean() throws IOException, SQLException;
22
+
23
+ public abstract void setByte() throws IOException, SQLException;
24
+
25
+ public abstract void setShort() throws IOException, SQLException;
26
+
27
+ public abstract void setInt() throws IOException, SQLException;
28
+
29
+ public abstract void setLong() throws IOException, SQLException;
30
+
31
+ public abstract void setFloat() throws IOException, SQLException;
32
+
33
+ public abstract void setDouble() throws IOException, SQLException;
34
+
35
+ public abstract void setBigDecimal() throws IOException, SQLException;
36
+
37
+ public abstract void setString() throws IOException, SQLException;
38
+
39
+ public abstract void setNString() throws IOException, SQLException;
40
+
41
+ public abstract void setBytes() throws IOException, SQLException;
42
+
43
+ public abstract void setSqlDate() throws IOException, SQLException;
44
+
45
+ public abstract void setSqlTime() throws IOException, SQLException;
46
+
47
+ public abstract void setSqlTimestamp() throws IOException, SQLException;
48
+ }
@@ -1,61 +1,60 @@
1
- package org.embulk.output.jdbc.setter;
2
-
3
- import java.io.IOException;
4
- import java.sql.SQLException;
5
- import org.embulk.spi.ColumnVisitor;
6
- import org.embulk.spi.time.Timestamp;
7
- import org.embulk.output.jdbc.JdbcColumn;
8
- import org.embulk.output.jdbc.BatchInsert;
9
-
10
- public class DoubleColumnSetter
11
- extends ColumnSetter
12
- {
13
- public DoubleColumnSetter(BatchInsert batch, JdbcColumn column,
14
- DefaultValueSetter defaultValue)
15
- {
16
- super(batch, column, defaultValue);
17
- }
18
-
19
- @Override
20
- public void nullValue() throws IOException, SQLException
21
- {
22
- defaultValue.setDouble();
23
- }
24
-
25
- @Override
26
- public void booleanValue(boolean v) throws IOException, SQLException
27
- {
28
- batch.setDouble(v ? 1.0 : 0.0);
29
- }
30
-
31
- @Override
32
- public void longValue(long v) throws IOException, SQLException
33
- {
34
- batch.setDouble((double) v);
35
- }
36
-
37
- @Override
38
- public void doubleValue(double v) throws IOException, SQLException
39
- {
40
- batch.setDouble(v);
41
- }
42
-
43
- @Override
44
- public void stringValue(String v) throws IOException, SQLException
45
- {
46
- double dv;
47
- try {
48
- dv = Double.parseDouble(v);
49
- } catch (NumberFormatException e) {
50
- defaultValue.setDouble();
51
- return;
52
- }
53
- batch.setDouble(dv);
54
- }
55
-
56
- @Override
57
- public void timestampValue(Timestamp v) throws IOException, SQLException
58
- {
59
- defaultValue.setDouble();
60
- }
61
- }
1
+ package org.embulk.output.jdbc.setter;
2
+
3
+ import java.io.IOException;
4
+ import java.sql.SQLException;
5
+ import org.embulk.spi.time.Timestamp;
6
+ import org.embulk.output.jdbc.JdbcColumn;
7
+ import org.embulk.output.jdbc.BatchInsert;
8
+
9
+ public class DoubleColumnSetter
10
+ extends ColumnSetter
11
+ {
12
+ public DoubleColumnSetter(BatchInsert batch, JdbcColumn column,
13
+ DefaultValueSetter defaultValue)
14
+ {
15
+ super(batch, column, defaultValue);
16
+ }
17
+
18
+ @Override
19
+ public void nullValue() throws IOException, SQLException
20
+ {
21
+ defaultValue.setDouble();
22
+ }
23
+
24
+ @Override
25
+ public void booleanValue(boolean v) throws IOException, SQLException
26
+ {
27
+ batch.setDouble(v ? 1.0 : 0.0);
28
+ }
29
+
30
+ @Override
31
+ public void longValue(long v) throws IOException, SQLException
32
+ {
33
+ batch.setDouble((double) v);
34
+ }
35
+
36
+ @Override
37
+ public void doubleValue(double v) throws IOException, SQLException
38
+ {
39
+ batch.setDouble(v);
40
+ }
41
+
42
+ @Override
43
+ public void stringValue(String v) throws IOException, SQLException
44
+ {
45
+ double dv;
46
+ try {
47
+ dv = Double.parseDouble(v);
48
+ } catch (NumberFormatException e) {
49
+ defaultValue.setDouble();
50
+ return;
51
+ }
52
+ batch.setDouble(dv);
53
+ }
54
+
55
+ @Override
56
+ public void timestampValue(Timestamp v) throws IOException, SQLException
57
+ {
58
+ defaultValue.setDouble();
59
+ }
60
+ }
@@ -1,61 +1,60 @@
1
- package org.embulk.output.jdbc.setter;
2
-
3
- import java.io.IOException;
4
- import java.sql.SQLException;
5
- import org.embulk.spi.ColumnVisitor;
6
- import org.embulk.spi.time.Timestamp;
7
- import org.embulk.output.jdbc.JdbcColumn;
8
- import org.embulk.output.jdbc.BatchInsert;
9
-
10
- public class FloatColumnSetter
11
- extends ColumnSetter
12
- {
13
- public FloatColumnSetter(BatchInsert batch, JdbcColumn column,
14
- DefaultValueSetter defaultValue)
15
- {
16
- super(batch, column, defaultValue);
17
- }
18
-
19
- @Override
20
- public void nullValue() throws IOException, SQLException
21
- {
22
- defaultValue.setFloat();
23
- }
24
-
25
- @Override
26
- public void booleanValue(boolean v) throws IOException, SQLException
27
- {
28
- batch.setFloat(v ? (float) 1.0 : (float) 0.0);
29
- }
30
-
31
- @Override
32
- public void longValue(long v) throws IOException, SQLException
33
- {
34
- batch.setFloat((float) v);
35
- }
36
-
37
- @Override
38
- public void doubleValue(double v) throws IOException, SQLException
39
- {
40
- batch.setFloat((float) v);
41
- }
42
-
43
- @Override
44
- public void stringValue(String v) throws IOException, SQLException
45
- {
46
- float fv;
47
- try {
48
- fv = Float.parseFloat(v);
49
- } catch (NumberFormatException e) {
50
- defaultValue.setFloat();
51
- return;
52
- }
53
- batch.setFloat(fv);
54
- }
55
-
56
- @Override
57
- public void timestampValue(Timestamp v) throws IOException, SQLException
58
- {
59
- defaultValue.setFloat();
60
- }
61
- }
1
+ package org.embulk.output.jdbc.setter;
2
+
3
+ import java.io.IOException;
4
+ import java.sql.SQLException;
5
+ import org.embulk.spi.time.Timestamp;
6
+ import org.embulk.output.jdbc.JdbcColumn;
7
+ import org.embulk.output.jdbc.BatchInsert;
8
+
9
+ public class FloatColumnSetter
10
+ extends ColumnSetter
11
+ {
12
+ public FloatColumnSetter(BatchInsert batch, JdbcColumn column,
13
+ DefaultValueSetter defaultValue)
14
+ {
15
+ super(batch, column, defaultValue);
16
+ }
17
+
18
+ @Override
19
+ public void nullValue() throws IOException, SQLException
20
+ {
21
+ defaultValue.setFloat();
22
+ }
23
+
24
+ @Override
25
+ public void booleanValue(boolean v) throws IOException, SQLException
26
+ {
27
+ batch.setFloat(v ? (float) 1.0 : (float) 0.0);
28
+ }
29
+
30
+ @Override
31
+ public void longValue(long v) throws IOException, SQLException
32
+ {
33
+ batch.setFloat((float) v);
34
+ }
35
+
36
+ @Override
37
+ public void doubleValue(double v) throws IOException, SQLException
38
+ {
39
+ batch.setFloat((float) v);
40
+ }
41
+
42
+ @Override
43
+ public void stringValue(String v) throws IOException, SQLException
44
+ {
45
+ float fv;
46
+ try {
47
+ fv = Float.parseFloat(v);
48
+ } catch (NumberFormatException e) {
49
+ defaultValue.setFloat();
50
+ return;
51
+ }
52
+ batch.setFloat(fv);
53
+ }
54
+
55
+ @Override
56
+ public void timestampValue(Timestamp v) throws IOException, SQLException
57
+ {
58
+ defaultValue.setFloat();
59
+ }
60
+ }