diff options
author | James Ahlborn <jtahlborn@yahoo.com> | 2009-12-23 02:41:00 +0000 |
---|---|---|
committer | James Ahlborn <jtahlborn@yahoo.com> | 2009-12-23 02:41:00 +0000 |
commit | 350e547443e2619337e3a8339e8fbbc334ec5d81 (patch) | |
tree | 4bf22a143fbf811b8ab7bceea187966204092e61 /src/java | |
parent | d590fa696b5dd00c73d659a4b0d2c4f7a0c87886 (diff) | |
download | jackcess-350e547443e2619337e3a8339e8fbbc334ec5d81.tar.gz jackcess-350e547443e2619337e3a8339e8fbbc334ec5d81.zip |
Set overflow info in header row, not in last data row. (fixes #2919216)
git-svn-id: https://svn.code.sf.net/p/jackcess/code/jackcess/trunk@424 f203690c-595d-4dc9-a70b-905162fa7fd2
Diffstat (limited to 'src/java')
-rw-r--r-- | src/java/com/healthmarketscience/jackcess/Table.java | 41 |
1 files changed, 23 insertions, 18 deletions
diff --git a/src/java/com/healthmarketscience/jackcess/Table.java b/src/java/com/healthmarketscience/jackcess/Table.java index 0eb9f9c..02f1d49 100644 --- a/src/java/com/healthmarketscience/jackcess/Table.java +++ b/src/java/com/healthmarketscience/jackcess/Table.java @@ -1353,32 +1353,37 @@ public class Table PageChannel.INVALID_PAGE_NUMBER); pageNumber = _addRowBufferH.getPageNumber(); - ByteBuffer oldDataPage = rowState.getFinalPage(); - int oldPageNumber = rowState.getFinalRowId().getPageNumber(); - if(pageNumber == oldPageNumber) { - // new row is on the same page as current row, share page - dataPage = oldDataPage; + RowId headerRowId = rowState.getHeaderRowId(); + ByteBuffer headerPage = rowState.getHeaderPage(); + if(pageNumber == headerRowId.getPageNumber()) { + // new row is on the same page as header row, share page + dataPage = headerPage; } - // write out the new row data (set the deleted flag on the new data row) + // write out the new row data (set the deleted flag on the new data row + // so that it is ignored during normal table traversal) int rowNum = addDataPageRow(dataPage, rowSize, getFormat(), DELETED_ROW_MASK); - dataPage.put(newRowData); - - // write the overflow info into the old row and clear out the remaining - // old data + dataPage.put(newRowData); + + // write the overflow info into the header row and clear out the + // remaining header data + rowBuffer = PageChannel.narrowBuffer( + headerPage, + findRowStart(headerPage, headerRowId.getRowNumber(), getFormat()), + findRowEnd(headerPage, headerRowId.getRowNumber(), getFormat())); rowBuffer.put((byte)rowNum); ByteUtil.put3ByteInt(rowBuffer, pageNumber); ByteUtil.clearRemaining(rowBuffer); - // set the overflow flag on the old row - int oldRowNumber = rowState.getFinalRowId().getRowNumber(); - int oldRowIndex = getRowStartOffset(oldRowNumber, getFormat()); - oldDataPage.putShort(oldRowIndex, - (short)(oldDataPage.getShort(oldRowIndex) - | OVERFLOW_ROW_MASK)); - if(pageNumber != oldPageNumber) { - writeDataPage(oldDataPage, oldPageNumber); + // set the overflow flag on the header row + int headerRowIndex = getRowStartOffset(headerRowId.getRowNumber(), + getFormat()); + headerPage.putShort(headerRowIndex, + (short)(headerPage.getShort(headerRowIndex) + | OVERFLOW_ROW_MASK)); + if(pageNumber != headerRowId.getPageNumber()) { + writeDataPage(headerPage, headerRowId.getPageNumber()); } } |