diff options
author | James Moger <james.moger@gmail.com> | 2011-08-12 15:41:42 -0400 |
---|---|---|
committer | James Moger <james.moger@gmail.com> | 2011-08-12 15:41:42 -0400 |
commit | 3622ae0026718ac8466e13e8011f8db309d89106 (patch) | |
tree | 39ff193be51b2970fd2b51efcaf73c669288005b /src | |
parent | 373a5c74f4c5e8cc19812a63893f6090d8f14b95 (diff) | |
download | iciql-3622ae0026718ac8466e13e8011f8db309d89106.tar.gz iciql-3622ae0026718ac8466e13e8011f8db309d89106.zip |
Fixed bug in delete() and update() where primary key is a primitive.v0.6.5
Diffstat (limited to 'src')
-rw-r--r-- | src/com/iciql/Constants.java | 2 | ||||
-rw-r--r-- | src/com/iciql/Db.java | 8 | ||||
-rw-r--r-- | src/com/iciql/TableDefinition.java | 24 |
3 files changed, 20 insertions, 14 deletions
diff --git a/src/com/iciql/Constants.java b/src/com/iciql/Constants.java index 23f42d2..e8ac70a 100644 --- a/src/com/iciql/Constants.java +++ b/src/com/iciql/Constants.java @@ -25,7 +25,7 @@ public class Constants { // The build script extracts this exact line so be careful editing it
// and only use A-Z a-z 0-9 .-_ in the string.
- public static final String VERSION = "0.6.4";
+ public static final String VERSION = "0.6.5";
// The build script extracts this exact line so be careful editing it
// and only use A-Z a-z 0-9 .-_ in the string.
diff --git a/src/com/iciql/Db.java b/src/com/iciql/Db.java index a8c0b12..cbc1ed4 100644 --- a/src/com/iciql/Db.java +++ b/src/com/iciql/Db.java @@ -201,14 +201,14 @@ public class Db { define(clazz).createTableIfRequired(this).merge(this, t);
}
- public <T> void update(T t) {
+ public <T> int update(T t) {
Class<?> clazz = t.getClass();
- define(clazz).createTableIfRequired(this).update(this, t);
+ return define(clazz).createTableIfRequired(this).update(this, t);
}
- public <T> void delete(T t) {
+ public <T> int delete(T t) {
Class<?> clazz = t.getClass();
- define(clazz).createTableIfRequired(this).delete(this, t);
+ return define(clazz).createTableIfRequired(this).delete(this, t);
}
public <T extends Object> Query<T> from(T alias) {
diff --git a/src/com/iciql/TableDefinition.java b/src/com/iciql/TableDefinition.java index 03345d4..ec79756 100644 --- a/src/com/iciql/TableDefinition.java +++ b/src/com/iciql/TableDefinition.java @@ -468,7 +468,7 @@ public class TableDefinition<T> { stat.executeUpdate();
}
- void update(Db db, Object obj) {
+ int update(Db db, Object obj) {
if (primaryKeyColumnNames == null || primaryKeyColumnNames.size() == 0) {
throw new IllegalStateException("No primary key columns defined " + "for table " + obj.getClass()
+ " - no update possible");
@@ -492,24 +492,27 @@ public class TableDefinition<T> { boolean firstCondition = true;
for (FieldDefinition field : fields) {
if (field.isPrimaryKey) {
- Object aliasValue = field.getValue(alias);
+ Object fieldAlias = field.getValue(alias);
Object value = field.getValue(obj);
+ if (field.isPrimitive) {
+ fieldAlias = query.getPrimitiveAliasByValue(fieldAlias);
+ }
if (!firstCondition) {
query.addConditionToken(ConditionAndOr.AND);
}
firstCondition = false;
- query.addConditionToken(new Condition<Object>(aliasValue, value, CompareType.EQUAL));
+ query.addConditionToken(new Condition<Object>(fieldAlias, value, CompareType.EQUAL));
}
}
stat.setSQL(buff.toString());
query.appendWhere(stat);
StatementLogger.update(stat.getSQL());
- stat.executeUpdate();
+ return stat.executeUpdate();
}
- void delete(Db db, Object obj) {
+ int delete(Db db, Object obj) {
if (primaryKeyColumnNames == null || primaryKeyColumnNames.size() == 0) {
- throw new IllegalStateException("No primary key columns defined " + "for table " + obj.getClass()
+ throw new IllegalStateException("No primary key columns defined for table " + obj.getClass()
+ " - no update possible");
}
SQLStatement stat = new SQLStatement(db);
@@ -521,19 +524,22 @@ public class TableDefinition<T> { boolean firstCondition = true;
for (FieldDefinition field : fields) {
if (field.isPrimaryKey) {
- Object aliasValue = field.getValue(alias);
+ Object fieldAlias = field.getValue(alias);
Object value = field.getValue(obj);
+ if (field.isPrimitive) {
+ fieldAlias = query.getPrimitiveAliasByValue(fieldAlias);
+ }
if (!firstCondition) {
query.addConditionToken(ConditionAndOr.AND);
}
firstCondition = false;
- query.addConditionToken(new Condition<Object>(aliasValue, value, CompareType.EQUAL));
+ query.addConditionToken(new Condition<Object>(fieldAlias, value, CompareType.EQUAL));
}
}
stat.setSQL(buff.toString());
query.appendWhere(stat);
StatementLogger.delete(stat.getSQL());
- stat.executeUpdate();
+ return stat.executeUpdate();
}
TableDefinition<T> createTableIfRequired(Db db) {
|