mirror of
https://github.com/moparisthebest/JdbcMapper
synced 2024-12-21 14:58:51 -05:00
Support binding java.time.Instant to a PreparedStatement in jdbcmapper, handle multi-line strings, fix bind conversions if null
This commit is contained in:
parent
195a0c0484
commit
0011925d6a
@ -16,6 +16,9 @@ import java.sql.SQLException;
|
||||
import java.util.*;
|
||||
import java.util.regex.Matcher;
|
||||
import java.util.regex.Pattern;
|
||||
//IFJAVA8_START
|
||||
import java.time.*;
|
||||
//IFJAVA8_END
|
||||
|
||||
import static com.moparisthebest.jdbc.TryClose.tryClose;
|
||||
|
||||
@ -32,6 +35,9 @@ public class JdbcMapperProcessor extends AbstractProcessor {
|
||||
private Types types;
|
||||
private TypeMirror sqlExceptionType, stringType, numberType, utilDateType, readerType, clobType,
|
||||
byteArrayType, inputStreamType, fileType, blobType, sqlArrayType, collectionType, calendarType, cleanerType;
|
||||
//IFJAVA8_START
|
||||
private TypeMirror instantType;
|
||||
//IFJAVA8_END
|
||||
private TypeElement cleanerElement;
|
||||
private JdbcMapper.DatabaseType defaultDatabaseType;
|
||||
private String defaultArrayNumberTypeName, defaultArrayStringTypeName;
|
||||
@ -57,6 +63,9 @@ public class JdbcMapperProcessor extends AbstractProcessor {
|
||||
fileType = elements.getTypeElement(File.class.getCanonicalName()).asType();
|
||||
blobType = elements.getTypeElement(Blob.class.getCanonicalName()).asType();
|
||||
calendarType = elements.getTypeElement(Calendar.class.getCanonicalName()).asType();
|
||||
//IFJAVA8_START
|
||||
instantType = elements.getTypeElement(Instant.class.getCanonicalName()).asType();
|
||||
//IFJAVA8_END
|
||||
// throws NPE:
|
||||
//byteArrayType = elements.getTypeElement(byte[].class.getCanonicalName()).asType();
|
||||
//byteArrayType = this.types.getArrayType(elements.getTypeElement(byte.class.getCanonicalName()).asType());
|
||||
@ -346,7 +355,7 @@ public class JdbcMapperProcessor extends AbstractProcessor {
|
||||
w.write("conn.prepareStatement(");
|
||||
}
|
||||
w.write('"');
|
||||
w.write(sqlStatement);
|
||||
w.write(sqlStatement.replaceAll("\n", "\\n").replaceAll("\"", "\\\""));
|
||||
w.write("\");\n");
|
||||
|
||||
// now bind parameters
|
||||
@ -575,9 +584,17 @@ public class JdbcMapperProcessor extends AbstractProcessor {
|
||||
method = "Object";
|
||||
// might need to wrap with Timestamp
|
||||
if (types.isSameType(o, utilDateType))
|
||||
variableName = "new java.sql.Timestamp(" + variableName + ".getTime())";
|
||||
variableName = variableName + " == null ? null : new java.sql.Timestamp(" + variableName + ".getTime())";
|
||||
}
|
||||
//IFJAVA8_START
|
||||
// todo: other java.time types
|
||||
else if (types.isAssignable(o, instantType)) {
|
||||
method = "Object";
|
||||
variableName = variableName + " == null ? null : new java.sql.Timestamp(" + variableName + ".toEpochMilli())";
|
||||
}
|
||||
//IFJAVA8_END
|
||||
// CLOB support
|
||||
} else if (types.isAssignable(o, readerType) || types.isAssignable(o, clobType)) {
|
||||
else if (types.isAssignable(o, readerType) || types.isAssignable(o, clobType)) {
|
||||
method = "Clob";
|
||||
} else if (types.isAssignable(o, inputStreamType) || types.isAssignable(o, blobType)) {
|
||||
method = "Blob";
|
||||
@ -591,7 +608,7 @@ public class JdbcMapperProcessor extends AbstractProcessor {
|
||||
return;
|
||||
} else if (types.isAssignable(o, byteArrayType)) {
|
||||
method = "Blob";
|
||||
variableName = "new java.io.ByteArrayInputStream(" + variableName + ")";
|
||||
variableName = variableName + " == null ? null : new java.io.ByteArrayInputStream(" + variableName + ")";
|
||||
} else if (types.isAssignable(o, sqlArrayType)) {
|
||||
method = "Array";
|
||||
} else {
|
||||
|
Loading…
Reference in New Issue
Block a user