mirror of
https://github.com/Kingsrook/qqq.git
synced 2025-07-18 05:01:07 +00:00
Merge branch 'rel/0.22.1'
This commit is contained in:
2
pom.xml
2
pom.xml
@ -46,7 +46,7 @@
|
|||||||
</modules>
|
</modules>
|
||||||
|
|
||||||
<properties>
|
<properties>
|
||||||
<revision>0.22.0</revision>
|
<revision>0.22.1</revision>
|
||||||
|
|
||||||
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
|
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
|
||||||
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
|
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
|
||||||
|
@ -272,7 +272,7 @@ public class AuditAction extends AbstractQActionFunction<AuditInput, AuditOutput
|
|||||||
List<QRecord> auditDetailRecords = new ArrayList<>();
|
List<QRecord> auditDetailRecords = new ArrayList<>();
|
||||||
for(AuditSingleInput auditSingleInput : CollectionUtils.nonNullList(input.getAuditSingleInputList()))
|
for(AuditSingleInput auditSingleInput : CollectionUtils.nonNullList(input.getAuditSingleInputList()))
|
||||||
{
|
{
|
||||||
Integer auditId = insertOutput.getRecords().get(i++).getValueInteger("id");
|
Long auditId = insertOutput.getRecords().get(i++).getValueLong("id");
|
||||||
if(auditId == null)
|
if(auditId == null)
|
||||||
{
|
{
|
||||||
LOG.warn("Missing an id for inserted audit - so won't be able to store its child details...");
|
LOG.warn("Missing an id for inserted audit - so won't be able to store its child details...");
|
||||||
|
@ -176,7 +176,7 @@ public class AuditsMetaDataProvider
|
|||||||
.withRecordLabelFields("label")
|
.withRecordLabelFields("label")
|
||||||
.withPrimaryKeyField("id")
|
.withPrimaryKeyField("id")
|
||||||
.withUniqueKey(new UniqueKey("name"))
|
.withUniqueKey(new UniqueKey("name"))
|
||||||
.withField(new QFieldMetaData("id", QFieldType.INTEGER))
|
.withField(new QFieldMetaData("id", QFieldType.LONG))
|
||||||
.withField(new QFieldMetaData("name", QFieldType.STRING))
|
.withField(new QFieldMetaData("name", QFieldType.STRING))
|
||||||
.withField(new QFieldMetaData("label", QFieldType.STRING))
|
.withField(new QFieldMetaData("label", QFieldType.STRING))
|
||||||
.withField(new QFieldMetaData("createDate", QFieldType.DATE_TIME))
|
.withField(new QFieldMetaData("createDate", QFieldType.DATE_TIME))
|
||||||
@ -199,7 +199,7 @@ public class AuditsMetaDataProvider
|
|||||||
.withRecordLabelFields("name")
|
.withRecordLabelFields("name")
|
||||||
.withPrimaryKeyField("id")
|
.withPrimaryKeyField("id")
|
||||||
.withUniqueKey(new UniqueKey("name"))
|
.withUniqueKey(new UniqueKey("name"))
|
||||||
.withField(new QFieldMetaData("id", QFieldType.INTEGER))
|
.withField(new QFieldMetaData("id", QFieldType.LONG))
|
||||||
.withField(new QFieldMetaData("name", QFieldType.STRING))
|
.withField(new QFieldMetaData("name", QFieldType.STRING))
|
||||||
.withField(new QFieldMetaData("createDate", QFieldType.DATE_TIME))
|
.withField(new QFieldMetaData("createDate", QFieldType.DATE_TIME))
|
||||||
.withField(new QFieldMetaData("modifyDate", QFieldType.DATE_TIME))
|
.withField(new QFieldMetaData("modifyDate", QFieldType.DATE_TIME))
|
||||||
@ -220,7 +220,7 @@ public class AuditsMetaDataProvider
|
|||||||
.withRecordLabelFormat("%s %s")
|
.withRecordLabelFormat("%s %s")
|
||||||
.withRecordLabelFields("auditTableId", "recordId")
|
.withRecordLabelFields("auditTableId", "recordId")
|
||||||
.withPrimaryKeyField("id")
|
.withPrimaryKeyField("id")
|
||||||
.withField(new QFieldMetaData("id", QFieldType.INTEGER))
|
.withField(new QFieldMetaData("id", QFieldType.LONG))
|
||||||
.withField(new QFieldMetaData("auditTableId", QFieldType.INTEGER).withPossibleValueSourceName(TABLE_NAME_AUDIT_TABLE))
|
.withField(new QFieldMetaData("auditTableId", QFieldType.INTEGER).withPossibleValueSourceName(TABLE_NAME_AUDIT_TABLE))
|
||||||
.withField(new QFieldMetaData("auditUserId", QFieldType.INTEGER).withPossibleValueSourceName(TABLE_NAME_AUDIT_USER))
|
.withField(new QFieldMetaData("auditUserId", QFieldType.INTEGER).withPossibleValueSourceName(TABLE_NAME_AUDIT_USER))
|
||||||
.withField(new QFieldMetaData("recordId", QFieldType.INTEGER))
|
.withField(new QFieldMetaData("recordId", QFieldType.INTEGER))
|
||||||
@ -243,8 +243,8 @@ public class AuditsMetaDataProvider
|
|||||||
.withRecordLabelFormat("%s")
|
.withRecordLabelFormat("%s")
|
||||||
.withRecordLabelFields("id")
|
.withRecordLabelFields("id")
|
||||||
.withPrimaryKeyField("id")
|
.withPrimaryKeyField("id")
|
||||||
.withField(new QFieldMetaData("id", QFieldType.INTEGER))
|
.withField(new QFieldMetaData("id", QFieldType.LONG))
|
||||||
.withField(new QFieldMetaData("auditId", QFieldType.INTEGER).withPossibleValueSourceName(TABLE_NAME_AUDIT))
|
.withField(new QFieldMetaData("auditId", QFieldType.LONG).withPossibleValueSourceName(TABLE_NAME_AUDIT))
|
||||||
.withField(new QFieldMetaData("message", QFieldType.STRING).withMaxLength(250).withBehavior(ValueTooLongBehavior.TRUNCATE_ELLIPSIS))
|
.withField(new QFieldMetaData("message", QFieldType.STRING).withMaxLength(250).withBehavior(ValueTooLongBehavior.TRUNCATE_ELLIPSIS))
|
||||||
.withField(new QFieldMetaData("fieldName", QFieldType.STRING).withMaxLength(100).withBehavior(ValueTooLongBehavior.TRUNCATE_ELLIPSIS))
|
.withField(new QFieldMetaData("fieldName", QFieldType.STRING).withMaxLength(100).withBehavior(ValueTooLongBehavior.TRUNCATE_ELLIPSIS))
|
||||||
.withField(new QFieldMetaData("oldValue", QFieldType.STRING).withMaxLength(250).withBehavior(ValueTooLongBehavior.TRUNCATE_ELLIPSIS))
|
.withField(new QFieldMetaData("oldValue", QFieldType.STRING).withMaxLength(250).withBehavior(ValueTooLongBehavior.TRUNCATE_ELLIPSIS))
|
||||||
|
@ -374,9 +374,16 @@ public class MemoryRecordStore
|
|||||||
// set the next serial in the record if needed //
|
// set the next serial in the record if needed //
|
||||||
/////////////////////////////////////////////////
|
/////////////////////////////////////////////////
|
||||||
if(recordToInsert.getValue(primaryKeyField.getName()) == null && (primaryKeyField.getType().equals(QFieldType.INTEGER) || primaryKeyField.getType().equals(QFieldType.LONG)))
|
if(recordToInsert.getValue(primaryKeyField.getName()) == null && (primaryKeyField.getType().equals(QFieldType.INTEGER) || primaryKeyField.getType().equals(QFieldType.LONG)))
|
||||||
|
{
|
||||||
|
if(primaryKeyField.getType().equals(QFieldType.LONG))
|
||||||
|
{
|
||||||
|
recordToInsert.setValue(primaryKeyField.getName(), (nextSerial++).longValue());
|
||||||
|
}
|
||||||
|
else
|
||||||
{
|
{
|
||||||
recordToInsert.setValue(primaryKeyField.getName(), nextSerial++);
|
recordToInsert.setValue(primaryKeyField.getName(), nextSerial++);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
///////////////////////////////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
// make sure that if the user supplied a serial, greater than the one we had, that we skip ahead //
|
// make sure that if the user supplied a serial, greater than the one we had, that we skip ahead //
|
||||||
@ -385,7 +392,7 @@ public class MemoryRecordStore
|
|||||||
{
|
{
|
||||||
nextSerial = recordToInsert.getValueInteger(primaryKeyField.getName()) + 1;
|
nextSerial = recordToInsert.getValueInteger(primaryKeyField.getName()) + 1;
|
||||||
}
|
}
|
||||||
else if(primaryKeyField.getType().equals(QFieldType.LONG) && recordToInsert.getValueLong(primaryKeyField.getName()) > nextSerial)
|
else if(primaryKeyField.getType().equals(QFieldType.LONG) && recordToInsert.getValueInteger(primaryKeyField.getName()) > nextSerial)
|
||||||
{
|
{
|
||||||
//////////////////////////////////////
|
//////////////////////////////////////
|
||||||
// todo - mmm, could overflow here? //
|
// todo - mmm, could overflow here? //
|
||||||
|
@ -180,7 +180,7 @@ class AuditActionTest extends BaseTest
|
|||||||
QRecord auditRecord = GeneralProcessUtils.getRecordByFieldOrElseThrow("audit", "recordId", recordId1);
|
QRecord auditRecord = GeneralProcessUtils.getRecordByFieldOrElseThrow("audit", "recordId", recordId1);
|
||||||
assertEquals("Test Audit", auditRecord.getValueString("message"));
|
assertEquals("Test Audit", auditRecord.getValueString("message"));
|
||||||
|
|
||||||
List<QRecord> auditDetails = GeneralProcessUtils.getRecordListByField("auditDetail", "auditId", auditRecord.getValue("id"));
|
List<QRecord> auditDetails = GeneralProcessUtils.getRecordListByField("auditDetail", "auditId", auditRecord.getValueLong("id"));
|
||||||
assertEquals(2, auditDetails.size());
|
assertEquals(2, auditDetails.size());
|
||||||
assertThat(auditDetails).anyMatch(r -> r.getValueString("message").equals("Detail1"));
|
assertThat(auditDetails).anyMatch(r -> r.getValueString("message").equals("Detail1"));
|
||||||
assertThat(auditDetails).anyMatch(r -> r.getValueString("message").equals("Detail2"));
|
assertThat(auditDetails).anyMatch(r -> r.getValueString("message").equals("Detail2"));
|
||||||
@ -188,13 +188,13 @@ class AuditActionTest extends BaseTest
|
|||||||
auditRecord = GeneralProcessUtils.getRecordByFieldOrElseThrow("audit", "recordId", recordId2);
|
auditRecord = GeneralProcessUtils.getRecordByFieldOrElseThrow("audit", "recordId", recordId2);
|
||||||
assertEquals("Test Another Audit", auditRecord.getValueString("message"));
|
assertEquals("Test Another Audit", auditRecord.getValueString("message"));
|
||||||
assertEquals(47, auditRecord.getValueInteger(TestUtils.SECURITY_KEY_TYPE_STORE));
|
assertEquals(47, auditRecord.getValueInteger(TestUtils.SECURITY_KEY_TYPE_STORE));
|
||||||
auditDetails = GeneralProcessUtils.getRecordListByField("auditDetail", "auditId", auditRecord.getValue("id"));
|
auditDetails = GeneralProcessUtils.getRecordListByField("auditDetail", "auditId", auditRecord.getValueLong("id"));
|
||||||
assertEquals(0, auditDetails.size());
|
assertEquals(0, auditDetails.size());
|
||||||
|
|
||||||
auditRecord = GeneralProcessUtils.getRecordByFieldOrElseThrow("audit", "recordId", recordId3);
|
auditRecord = GeneralProcessUtils.getRecordByFieldOrElseThrow("audit", "recordId", recordId3);
|
||||||
assertEquals("Audit 3", auditRecord.getValueString("message"));
|
assertEquals("Audit 3", auditRecord.getValueString("message"));
|
||||||
assertEquals(42, auditRecord.getValueInteger(TestUtils.SECURITY_KEY_TYPE_STORE));
|
assertEquals(42, auditRecord.getValueInteger(TestUtils.SECURITY_KEY_TYPE_STORE));
|
||||||
auditDetails = GeneralProcessUtils.getRecordListByField("auditDetail", "auditId", auditRecord.getValue("id"));
|
auditDetails = GeneralProcessUtils.getRecordListByField("auditDetail", "auditId", auditRecord.getValueLong("id"));
|
||||||
assertEquals(1, auditDetails.size());
|
assertEquals(1, auditDetails.size());
|
||||||
assertThat(auditDetails).anyMatch(r -> r.getValueString("message").equals("Detail3"));
|
assertThat(auditDetails).anyMatch(r -> r.getValueString("message").equals("Detail3"));
|
||||||
}
|
}
|
||||||
|
@ -146,7 +146,7 @@ public class RDBMSInsertAction extends AbstractRDBMSAction implements InsertInte
|
|||||||
// todo sql customization - can edit sql and/or param list
|
// todo sql customization - can edit sql and/or param list
|
||||||
// todo - non-serial-id style tables
|
// todo - non-serial-id style tables
|
||||||
// todo - other generated values, e.g., createDate... maybe need to re-select?
|
// todo - other generated values, e.g., createDate... maybe need to re-select?
|
||||||
List<Integer> idList = QueryManager.executeInsertForGeneratedIds(connection, sql.toString(), params);
|
List<Serializable> idList = QueryManager.executeInsertForGeneratedIds(connection, sql.toString(), params, table.getField(table.getPrimaryKeyField()).getType());
|
||||||
int index = 0;
|
int index = 0;
|
||||||
for(QRecord record : page)
|
for(QRecord record : page)
|
||||||
{
|
{
|
||||||
@ -155,7 +155,7 @@ public class RDBMSInsertAction extends AbstractRDBMSAction implements InsertInte
|
|||||||
|
|
||||||
if(CollectionUtils.nullSafeIsEmpty(record.getErrors()))
|
if(CollectionUtils.nullSafeIsEmpty(record.getErrors()))
|
||||||
{
|
{
|
||||||
Integer id = idList.get(index++);
|
Serializable id = idList.get(index++);
|
||||||
outputRecord.setValue(table.getPrimaryKeyField(), id);
|
outputRecord.setValue(table.getPrimaryKeyField(), id);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -53,6 +53,7 @@ import java.util.List;
|
|||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import com.kingsrook.qqq.backend.core.exceptions.QException;
|
import com.kingsrook.qqq.backend.core.exceptions.QException;
|
||||||
import com.kingsrook.qqq.backend.core.logging.QLogger;
|
import com.kingsrook.qqq.backend.core.logging.QLogger;
|
||||||
|
import com.kingsrook.qqq.backend.core.model.metadata.fields.QFieldType;
|
||||||
import com.kingsrook.qqq.backend.core.model.metadata.possiblevalues.PossibleValueEnum;
|
import com.kingsrook.qqq.backend.core.model.metadata.possiblevalues.PossibleValueEnum;
|
||||||
import com.kingsrook.qqq.backend.core.utils.CollectionUtils;
|
import com.kingsrook.qqq.backend.core.utils.CollectionUtils;
|
||||||
import com.kingsrook.qqq.backend.core.utils.StringUtils;
|
import com.kingsrook.qqq.backend.core.utils.StringUtils;
|
||||||
@ -526,18 +527,45 @@ public class QueryManager
|
|||||||
/*******************************************************************************
|
/*******************************************************************************
|
||||||
** todo - needs (specific) unit test
|
** todo - needs (specific) unit test
|
||||||
*******************************************************************************/
|
*******************************************************************************/
|
||||||
public static List<Integer> executeInsertForGeneratedIds(Connection connection, String sql, List<Object> params) throws SQLException
|
public static List<Serializable> executeInsertForGeneratedIds(Connection connection, String sql, List<Object> params, QFieldType idType) throws SQLException
|
||||||
{
|
{
|
||||||
try(PreparedStatement statement = connection.prepareStatement(sql, Statement.RETURN_GENERATED_KEYS))
|
try(PreparedStatement statement = connection.prepareStatement(sql, Statement.RETURN_GENERATED_KEYS))
|
||||||
{
|
{
|
||||||
bindParams(params.toArray(), statement);
|
bindParams(params.toArray(), statement);
|
||||||
incrementStatistic(STAT_QUERIES_RAN);
|
incrementStatistic(STAT_QUERIES_RAN);
|
||||||
statement.executeUpdate();
|
statement.executeUpdate();
|
||||||
|
|
||||||
|
/////////////////////////////////////////////////////////////
|
||||||
|
// We default to idType of INTEGER if it was not passed in //
|
||||||
|
/////////////////////////////////////////////////////////////
|
||||||
|
if(idType == null)
|
||||||
|
{
|
||||||
|
idType = QFieldType.INTEGER;
|
||||||
|
}
|
||||||
|
|
||||||
ResultSet generatedKeys = statement.getGeneratedKeys();
|
ResultSet generatedKeys = statement.getGeneratedKeys();
|
||||||
List<Integer> rs = new ArrayList<>();
|
List<Serializable> rs = new ArrayList<>();
|
||||||
while(generatedKeys.next())
|
while(generatedKeys.next())
|
||||||
|
{
|
||||||
|
switch(idType)
|
||||||
|
{
|
||||||
|
case INTEGER:
|
||||||
{
|
{
|
||||||
rs.add(getInteger(generatedKeys, 1));
|
rs.add(getInteger(generatedKeys, 1));
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case LONG:
|
||||||
|
{
|
||||||
|
rs.add(getLong(generatedKeys, 1));
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
default:
|
||||||
|
{
|
||||||
|
LOG.warn("Unknown id data type, attempting to getInteger.", logPair("sql", sql));
|
||||||
|
rs.add(getInteger(generatedKeys, 1));
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return (rs);
|
return (rs);
|
||||||
}
|
}
|
||||||
|
@ -1 +1 @@
|
|||||||
0.22.0
|
0.23.0
|
||||||
|
Reference in New Issue
Block a user