diff options
-rw-r--r-- | docs/01_model_classes.mkd | 5 | ||||
-rw-r--r-- | docs/05_releases.mkd | 2 | ||||
-rw-r--r-- | src/com/iciql/Db.java | 8 | ||||
-rw-r--r-- | src/com/iciql/DbVersion.java | 14 | ||||
-rw-r--r-- | src/com/iciql/Iciql.java | 4 | ||||
-rw-r--r-- | src/com/iciql/TableDefinition.java | 10 | ||||
-rw-r--r-- | src/com/iciql/TableInspector.java | 12 | ||||
-rw-r--r-- | tests/com/iciql/test/ModelsTest.java | 2 | ||||
-rw-r--r-- | tests/com/iciql/test/models/DefaultValuesModel.java | 2 |
9 files changed, 31 insertions, 28 deletions
diff --git a/docs/01_model_classes.mkd b/docs/01_model_classes.mkd index 274cb92..bdddd80 100644 --- a/docs/01_model_classes.mkd +++ b/docs/01_model_classes.mkd @@ -8,8 +8,9 @@ Alternatively, model classes can be automatically generated by iciql using the m ### Configuration Requirements and Limitations
1. Your model class **must** provide a public default constructor.
-2. Only the specified types are supported. Other types such as arrays and custom types are not supported.
-3. Triggers, views, and other advanced database features are not supported.
+2. All columns are assumed NULLABLE unless explicitly set *@IQColumn(nullable = false)*.
+3. Only the specified types are supported. Other types such as arrays and custom types are not supported.
+4. Triggers, views, and other advanced database features are not supported.
### Fully Supported Data Types
The following data types can be used for all iciql expressions.
diff --git a/docs/05_releases.mkd b/docs/05_releases.mkd index 8d1295b..e889f2f 100644 --- a/docs/05_releases.mkd +++ b/docs/05_releases.mkd @@ -7,6 +7,8 @@ **%VERSION%** ([zip](http://code.google.com/p/iciql/downloads/detail?name=%ZIP%)|[jar](http://code.google.com/p/iciql/downloads/detail?name=%JAR%)) *released %BUILDDATE%*
- api change release (API v4)
+- @IQColumn(allowNull=true) -> @IQColumn(nullable=true)
+- All columns are assumed NULLABLE unless explicitly set *@IQColumn(nullable = false)*
- allow using objects to assign default values<br/>
%BEGINCODE%
// CREATE TABLE ... myDate DATETIME DEFAULT '2000-02-01 00:00:00'
diff --git a/src/com/iciql/Db.java b/src/com/iciql/Db.java index 621e825..cae384d 100644 --- a/src/com/iciql/Db.java +++ b/src/com/iciql/Db.java @@ -236,7 +236,7 @@ public class Db { DbVersion v = new DbVersion();
DbVersion dbVersion =
// (SCHEMA="" && TABLE="") == DATABASE
- from(v).where(v.schema).is("").and(v.table).is("").selectFirst();
+ from(v).where(v.schemaName).is("").and(v.tableName).is("").selectFirst();
if (dbVersion == null) {
// database has no version registration, but model specifies
// version: insert DbVersion entry and return.
@@ -268,14 +268,14 @@ public class Db { // table is using iciql version tracking.
DbVersion v = new DbVersion();
String schema = StringUtils.isNullOrEmpty(model.schemaName) ? "" : model.schemaName;
- DbVersion dbVersion = from(v).where(v.schema).like(schema).and(v.table).like(model.tableName)
+ DbVersion dbVersion = from(v).where(v.schemaName).like(schema).and(v.tableName).like(model.tableName)
.selectFirst();
if (dbVersion == null) {
// table has no version registration, but model specifies
// version: insert DbVersion entry
DbVersion newTable = new DbVersion(model.tableVersion);
- newTable.schema = schema;
- newTable.table = model.tableName;
+ newTable.schemaName = schema;
+ newTable.tableName = model.tableName;
insert(newTable);
} else {
// table has a version registration:
diff --git a/src/com/iciql/DbVersion.java b/src/com/iciql/DbVersion.java index 2a8aa44..8ccf66f 100644 --- a/src/com/iciql/DbVersion.java +++ b/src/com/iciql/DbVersion.java @@ -26,13 +26,13 @@ import com.iciql.Iciql.IQTable; @IQTable(name = "_iq_versions", primaryKey = { "schemaName", "tableName"}, memoryTable = true) public class DbVersion { - @IQColumn(name = "schemaName", length = 255, allowNull = false) - String schema = ""; + @IQColumn(length = 255) + String schemaName = ""; - @IQColumn(name = "tableName", length = 255, allowNull = false) - String table = ""; + @IQColumn(length = 255) + String tableName = ""; - @IQColumn(name = "version") + @IQColumn Integer version; public DbVersion() { @@ -47,8 +47,8 @@ public class DbVersion { * the database version */ public DbVersion(int version) { - this.schema = ""; - this.table = ""; + this.schemaName = ""; + this.tableName = ""; this.version = version; } diff --git a/src/com/iciql/Iciql.java b/src/com/iciql/Iciql.java index 2eaf783..40c412a 100644 --- a/src/com/iciql/Iciql.java +++ b/src/com/iciql/Iciql.java @@ -408,9 +408,9 @@ public interface Iciql { /**
* If false, iciql will set the column NOT NULL during the CREATE TABLE
- * phase. Default: false.
+ * phase. Default: true.
*/
- boolean allowNull() default false;
+ boolean nullable() default true;
/**
* The default value assigned to the column during the CREATE TABLE
diff --git a/src/com/iciql/TableDefinition.java b/src/com/iciql/TableDefinition.java index 6e25c91..eb018bc 100644 --- a/src/com/iciql/TableDefinition.java +++ b/src/com/iciql/TableDefinition.java @@ -75,7 +75,7 @@ public class TableDefinition<T> { boolean isPrimaryKey;
boolean isAutoIncrement;
boolean trimString;
- boolean allowNull;
+ boolean nullable;
String defaultValue;
EnumType enumType;
@@ -275,7 +275,7 @@ public class TableDefinition<T> { boolean isPrimaryKey = false;
int maxLength = 0;
boolean trimString = false;
- boolean allowNull = true;
+ boolean nullable = true;
EnumType enumType = null;
String defaultValue = "";
// configure Java -> SQL enum mapping
@@ -303,7 +303,7 @@ public class TableDefinition<T> { isPrimaryKey = col.primaryKey();
maxLength = col.length();
trimString = col.trim();
- allowNull = col.allowNull();
+ nullable = col.nullable();
// try using default object
try {
@@ -340,7 +340,7 @@ public class TableDefinition<T> { fieldDef.isPrimaryKey = isPrimaryKey;
fieldDef.maxLength = maxLength;
fieldDef.trimString = trimString;
- fieldDef.allowNull = allowNull;
+ fieldDef.nullable = nullable;
fieldDef.defaultValue = defaultValue;
fieldDef.enumType = enumType;
fieldDef.dataType = ModelUtils.getDataType(fieldDef, strictTypeMapping);
@@ -562,7 +562,7 @@ public class TableDefinition<T> { buff.append(" AUTO_INCREMENT");
}
- if (!field.allowNull) {
+ if (!field.nullable) {
buff.append(" NOT NULL");
}
diff --git a/src/com/iciql/TableInspector.java b/src/com/iciql/TableInspector.java index 6ec848d..51b2d69 100644 --- a/src/com/iciql/TableInspector.java +++ b/src/com/iciql/TableInspector.java @@ -139,7 +139,7 @@ public class TableInspector { col.type = rs.getString("TYPE_NAME"); col.clazz = ModelUtils.getClassForSqlType(col.type, dateTimeClass); col.size = rs.getInt("COLUMN_SIZE"); - col.allowNull = rs.getInt("NULLABLE") == DatabaseMetaData.columnNullable; + col.nullable = rs.getInt("NULLABLE") == DatabaseMetaData.columnNullable; col.isAutoIncrement = rs.getBoolean("IS_AUTOINCREMENT"); if (primaryKeys.size() == 1) { if (col.name.equalsIgnoreCase(primaryKeys.get(0))) { @@ -158,7 +158,7 @@ public class TableInspector { /** * Generates a model (class definition) from this table. The model includes - * indexes, primary keys, default values, maxLengths, and allowNull + * indexes, primary keys, default values, lengths, and nullables. * information. * <p> * The caller may optionally set a destination package name, whether or not @@ -369,9 +369,9 @@ public class TableInspector { } } - // IQColumn.allowNull - if (!col.allowNull) { - ap.addParameter("allowNull=false"); + // IQColumn.nullable + if (!col.nullable) { + ap.addParameter("nullable=false"); } // IQColumn.defaultValue @@ -622,7 +622,7 @@ public class TableInspector { String name; String type; int size; - boolean allowNull; + boolean nullable; Class<?> clazz; boolean isPrimaryKey; boolean isAutoIncrement; diff --git a/tests/com/iciql/test/ModelsTest.java b/tests/com/iciql/test/ModelsTest.java index d5edcfd..652bc4f 100644 --- a/tests/com/iciql/test/ModelsTest.java +++ b/tests/com/iciql/test/ModelsTest.java @@ -115,7 +115,7 @@ public class ModelsTest { true); assertEquals(1, models.size()); // a poor test, but a start - assertEquals(1780, models.get(0).length()); + assertEquals(1456, models.get(0).length()); } @Test diff --git a/tests/com/iciql/test/models/DefaultValuesModel.java b/tests/com/iciql/test/models/DefaultValuesModel.java index 2669257..ab09186 100644 --- a/tests/com/iciql/test/models/DefaultValuesModel.java +++ b/tests/com/iciql/test/models/DefaultValuesModel.java @@ -50,7 +50,7 @@ public class DefaultValuesModel { @IQEnum(EnumType.ORDINAL)
public Tree myOrdinalTree = Tree.PINE;
- @IQColumn(allowNull = true)
+ @IQColumn(nullable = true)
public Tree myNullTree;
public DefaultValuesModel() {
|