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,76 +1,75 @@
1
- package org.embulk.output.jdbc.setter;
2
-
3
- import java.io.IOException;
4
- import java.sql.SQLException;
5
- import java.math.RoundingMode;
6
- import com.google.common.math.DoubleMath;
7
- import org.embulk.spi.ColumnVisitor;
8
- import org.embulk.spi.time.Timestamp;
9
- import org.embulk.output.jdbc.JdbcColumn;
10
- import org.embulk.output.jdbc.BatchInsert;
11
-
12
- public class IntColumnSetter
13
- extends ColumnSetter
14
- {
15
- public IntColumnSetter(BatchInsert batch, JdbcColumn column,
16
- DefaultValueSetter defaultValue)
17
- {
18
- super(batch, column, defaultValue);
19
- }
20
-
21
- @Override
22
- public void nullValue() throws IOException, SQLException
23
- {
24
- defaultValue.setInt();
25
- }
26
-
27
- @Override
28
- public void booleanValue(boolean v) throws IOException, SQLException
29
- {
30
- batch.setInt(v ? 1 : 0);
31
- }
32
-
33
- @Override
34
- public void longValue(long v) throws IOException, SQLException
35
- {
36
- if (v > Integer.MAX_VALUE || v < Integer.MIN_VALUE) {
37
- defaultValue.setInt();
38
- } else {
39
- batch.setInt((int) v);
40
- }
41
- }
42
-
43
- @Override
44
- public void doubleValue(double v) throws IOException, SQLException
45
- {
46
- long lv;
47
- try {
48
- // TODO configurable rounding mode
49
- lv = DoubleMath.roundToLong(v, RoundingMode.HALF_UP);
50
- } catch (ArithmeticException ex) {
51
- // NaN / Infinite / -Infinite
52
- defaultValue.setInt();
53
- return;
54
- }
55
- longValue(lv);
56
- }
57
-
58
- @Override
59
- public void stringValue(String v) throws IOException, SQLException
60
- {
61
- int iv;
62
- try {
63
- iv = Integer.parseInt(v);
64
- } catch (NumberFormatException e) {
65
- defaultValue.setInt();
66
- return;
67
- }
68
- batch.setInt(iv);
69
- }
70
-
71
- @Override
72
- public void timestampValue(Timestamp v) throws IOException, SQLException
73
- {
74
- defaultValue.setInt();
75
- }
76
- }
1
+ package org.embulk.output.jdbc.setter;
2
+
3
+ import java.io.IOException;
4
+ import java.sql.SQLException;
5
+ import java.math.RoundingMode;
6
+ import com.google.common.math.DoubleMath;
7
+ import org.embulk.spi.time.Timestamp;
8
+ import org.embulk.output.jdbc.JdbcColumn;
9
+ import org.embulk.output.jdbc.BatchInsert;
10
+
11
+ public class IntColumnSetter
12
+ extends ColumnSetter
13
+ {
14
+ public IntColumnSetter(BatchInsert batch, JdbcColumn column,
15
+ DefaultValueSetter defaultValue)
16
+ {
17
+ super(batch, column, defaultValue);
18
+ }
19
+
20
+ @Override
21
+ public void nullValue() throws IOException, SQLException
22
+ {
23
+ defaultValue.setInt();
24
+ }
25
+
26
+ @Override
27
+ public void booleanValue(boolean v) throws IOException, SQLException
28
+ {
29
+ batch.setInt(v ? 1 : 0);
30
+ }
31
+
32
+ @Override
33
+ public void longValue(long v) throws IOException, SQLException
34
+ {
35
+ if (v > Integer.MAX_VALUE || v < Integer.MIN_VALUE) {
36
+ defaultValue.setInt();
37
+ } else {
38
+ batch.setInt((int) v);
39
+ }
40
+ }
41
+
42
+ @Override
43
+ public void doubleValue(double v) throws IOException, SQLException
44
+ {
45
+ long lv;
46
+ try {
47
+ // TODO configurable rounding mode
48
+ lv = DoubleMath.roundToLong(v, RoundingMode.HALF_UP);
49
+ } catch (ArithmeticException ex) {
50
+ // NaN / Infinite / -Infinite
51
+ defaultValue.setInt();
52
+ return;
53
+ }
54
+ longValue(lv);
55
+ }
56
+
57
+ @Override
58
+ public void stringValue(String v) throws IOException, SQLException
59
+ {
60
+ int iv;
61
+ try {
62
+ iv = Integer.parseInt(v);
63
+ } catch (NumberFormatException e) {
64
+ defaultValue.setInt();
65
+ return;
66
+ }
67
+ batch.setInt(iv);
68
+ }
69
+
70
+ @Override
71
+ public void timestampValue(Timestamp v) throws IOException, SQLException
72
+ {
73
+ defaultValue.setInt();
74
+ }
75
+ }
@@ -1,72 +1,71 @@
1
- package org.embulk.output.jdbc.setter;
2
-
3
- import java.io.IOException;
4
- import java.sql.SQLException;
5
- import java.math.RoundingMode;
6
- import com.google.common.math.DoubleMath;
7
- import org.embulk.spi.ColumnVisitor;
8
- import org.embulk.spi.time.Timestamp;
9
- import org.embulk.output.jdbc.JdbcColumn;
10
- import org.embulk.output.jdbc.BatchInsert;
11
-
12
- public class LongColumnSetter
13
- extends ColumnSetter
14
- {
15
- public LongColumnSetter(BatchInsert batch, JdbcColumn column,
16
- DefaultValueSetter defaultValue)
17
- {
18
- super(batch, column, defaultValue);
19
- }
20
-
21
- @Override
22
- public void nullValue() throws IOException, SQLException
23
- {
24
- defaultValue.setLong();
25
- }
26
-
27
- @Override
28
- public void booleanValue(boolean v) throws IOException, SQLException
29
- {
30
- batch.setLong(v ? 1L : 0L);
31
- }
32
-
33
- @Override
34
- public void longValue(long v) throws IOException, SQLException
35
- {
36
- batch.setLong(v);
37
- }
38
-
39
- @Override
40
- public void doubleValue(double v) throws IOException, SQLException
41
- {
42
- long lv;
43
- try {
44
- // TODO configurable rounding mode
45
- lv = DoubleMath.roundToLong(v, RoundingMode.HALF_UP);
46
- } catch (ArithmeticException ex) {
47
- // NaN / Infinite / -Infinite
48
- defaultValue.setLong();
49
- return;
50
- }
51
- batch.setLong(lv);
52
- }
53
-
54
- @Override
55
- public void stringValue(String v) throws IOException, SQLException
56
- {
57
- long lv;
58
- try {
59
- lv = Long.parseLong(v);
60
- } catch (NumberFormatException e) {
61
- defaultValue.setLong();
62
- return;
63
- }
64
- batch.setLong(lv);
65
- }
66
-
67
- @Override
68
- public void timestampValue(Timestamp v) throws IOException, SQLException
69
- {
70
- defaultValue.setLong();
71
- }
72
- }
1
+ package org.embulk.output.jdbc.setter;
2
+
3
+ import java.io.IOException;
4
+ import java.sql.SQLException;
5
+ import java.math.RoundingMode;
6
+ import com.google.common.math.DoubleMath;
7
+ import org.embulk.spi.time.Timestamp;
8
+ import org.embulk.output.jdbc.JdbcColumn;
9
+ import org.embulk.output.jdbc.BatchInsert;
10
+
11
+ public class LongColumnSetter
12
+ extends ColumnSetter
13
+ {
14
+ public LongColumnSetter(BatchInsert batch, JdbcColumn column,
15
+ DefaultValueSetter defaultValue)
16
+ {
17
+ super(batch, column, defaultValue);
18
+ }
19
+
20
+ @Override
21
+ public void nullValue() throws IOException, SQLException
22
+ {
23
+ defaultValue.setLong();
24
+ }
25
+
26
+ @Override
27
+ public void booleanValue(boolean v) throws IOException, SQLException
28
+ {
29
+ batch.setLong(v ? 1L : 0L);
30
+ }
31
+
32
+ @Override
33
+ public void longValue(long v) throws IOException, SQLException
34
+ {
35
+ batch.setLong(v);
36
+ }
37
+
38
+ @Override
39
+ public void doubleValue(double v) throws IOException, SQLException
40
+ {
41
+ long lv;
42
+ try {
43
+ // TODO configurable rounding mode
44
+ lv = DoubleMath.roundToLong(v, RoundingMode.HALF_UP);
45
+ } catch (ArithmeticException ex) {
46
+ // NaN / Infinite / -Infinite
47
+ defaultValue.setLong();
48
+ return;
49
+ }
50
+ batch.setLong(lv);
51
+ }
52
+
53
+ @Override
54
+ public void stringValue(String v) throws IOException, SQLException
55
+ {
56
+ long lv;
57
+ try {
58
+ lv = Long.parseLong(v);
59
+ } catch (NumberFormatException e) {
60
+ defaultValue.setLong();
61
+ return;
62
+ }
63
+ batch.setLong(lv);
64
+ }
65
+
66
+ @Override
67
+ public void timestampValue(Timestamp v) throws IOException, SQLException
68
+ {
69
+ defaultValue.setLong();
70
+ }
71
+ }
@@ -1,59 +1,58 @@
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.spi.time.TimestampFormatter;
8
- import org.embulk.output.jdbc.JdbcColumn;
9
- import org.embulk.output.jdbc.BatchInsert;
10
-
11
- public class NStringColumnSetter
12
- extends ColumnSetter
13
- {
14
- private final TimestampFormatter timestampFormatter;
15
-
16
- public NStringColumnSetter(BatchInsert batch, JdbcColumn column,
17
- DefaultValueSetter defaultValue,
18
- TimestampFormatter timestampFormatter)
19
- {
20
- super(batch, column, defaultValue);
21
- this.timestampFormatter = timestampFormatter;
22
- }
23
-
24
- @Override
25
- public void nullValue() throws IOException, SQLException
26
- {
27
- defaultValue.setNString();
28
- }
29
-
30
- @Override
31
- public void booleanValue(boolean v) throws IOException, SQLException
32
- {
33
- batch.setNString(Boolean.toString(v));
34
- }
35
-
36
- @Override
37
- public void longValue(long v) throws IOException, SQLException
38
- {
39
- batch.setNString(Long.toString(v));
40
- }
41
-
42
- @Override
43
- public void doubleValue(double v) throws IOException, SQLException
44
- {
45
- batch.setNString(Double.toString(v));
46
- }
47
-
48
- @Override
49
- public void stringValue(String v) throws IOException, SQLException
50
- {
51
- batch.setNString(v);
52
- }
53
-
54
- @Override
55
- public void timestampValue(Timestamp v) throws IOException, SQLException
56
- {
57
- batch.setNString(timestampFormatter.format(v));
58
- }
59
- }
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.spi.time.TimestampFormatter;
7
+ import org.embulk.output.jdbc.JdbcColumn;
8
+ import org.embulk.output.jdbc.BatchInsert;
9
+
10
+ public class NStringColumnSetter
11
+ extends ColumnSetter
12
+ {
13
+ private final TimestampFormatter timestampFormatter;
14
+
15
+ public NStringColumnSetter(BatchInsert batch, JdbcColumn column,
16
+ DefaultValueSetter defaultValue,
17
+ TimestampFormatter timestampFormatter)
18
+ {
19
+ super(batch, column, defaultValue);
20
+ this.timestampFormatter = timestampFormatter;
21
+ }
22
+
23
+ @Override
24
+ public void nullValue() throws IOException, SQLException
25
+ {
26
+ defaultValue.setNString();
27
+ }
28
+
29
+ @Override
30
+ public void booleanValue(boolean v) throws IOException, SQLException
31
+ {
32
+ batch.setNString(Boolean.toString(v));
33
+ }
34
+
35
+ @Override
36
+ public void longValue(long v) throws IOException, SQLException
37
+ {
38
+ batch.setNString(Long.toString(v));
39
+ }
40
+
41
+ @Override
42
+ public void doubleValue(double v) throws IOException, SQLException
43
+ {
44
+ batch.setNString(Double.toString(v));
45
+ }
46
+
47
+ @Override
48
+ public void stringValue(String v) throws IOException, SQLException
49
+ {
50
+ batch.setNString(v);
51
+ }
52
+
53
+ @Override
54
+ public void timestampValue(Timestamp v) throws IOException, SQLException
55
+ {
56
+ batch.setNString(timestampFormatter.format(v));
57
+ }
58
+ }
@@ -1,53 +1,53 @@
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 NullColumnSetter
10
- extends ColumnSetter
11
- {
12
- public NullColumnSetter(BatchInsert batch, JdbcColumn column,
13
- DefaultValueSetter defaultValue)
14
- {
15
- super(batch, column, defaultValue);
16
- }
17
-
18
- @Override
19
- public void booleanValue(boolean v) throws IOException, SQLException
20
- {
21
- defaultValue.setNull();
22
- }
23
-
24
- @Override
25
- public void longValue(long v) throws IOException, SQLException
26
- {
27
- defaultValue.setNull();
28
- }
29
-
30
- @Override
31
- public void doubleValue(double v) throws IOException, SQLException
32
- {
33
- defaultValue.setNull();
34
- }
35
-
36
- @Override
37
- public void stringValue(String v) throws IOException, SQLException
38
- {
39
- defaultValue.setNull();
40
- }
41
-
42
- @Override
43
- public void timestampValue(Timestamp v) throws IOException, SQLException
44
- {
45
- defaultValue.setNull();
46
- }
47
-
48
- @Override
49
- public void nullValue() throws IOException, SQLException
50
- {
51
- defaultValue.setNull();
52
- }
53
- }
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 NullColumnSetter
10
+ extends ColumnSetter
11
+ {
12
+ public NullColumnSetter(BatchInsert batch, JdbcColumn column,
13
+ DefaultValueSetter defaultValue)
14
+ {
15
+ super(batch, column, defaultValue);
16
+ }
17
+
18
+ @Override
19
+ public void booleanValue(boolean v) throws IOException, SQLException
20
+ {
21
+ defaultValue.setNull();
22
+ }
23
+
24
+ @Override
25
+ public void longValue(long v) throws IOException, SQLException
26
+ {
27
+ defaultValue.setNull();
28
+ }
29
+
30
+ @Override
31
+ public void doubleValue(double v) throws IOException, SQLException
32
+ {
33
+ defaultValue.setNull();
34
+ }
35
+
36
+ @Override
37
+ public void stringValue(String v) throws IOException, SQLException
38
+ {
39
+ defaultValue.setNull();
40
+ }
41
+
42
+ @Override
43
+ public void timestampValue(Timestamp v) throws IOException, SQLException
44
+ {
45
+ defaultValue.setNull();
46
+ }
47
+
48
+ @Override
49
+ public void nullValue() throws IOException, SQLException
50
+ {
51
+ defaultValue.setNull();
52
+ }
53
+ }