diff options
author | dan <dan@noemail.net> | 2014-10-28 16:50:10 +0000 |
---|---|---|
committer | dan <dan@noemail.net> | 2014-10-28 16:50:10 +0000 |
commit | dd8c460081ef024abbb925029a18adb5deea3522 (patch) | |
tree | ad91af38b0e906c325ad743d3d26f0624a1ff5ef /src | |
parent | 635e57fc4893060c6c31efa3bcd936a9720212c7 (diff) | |
download | sqlite-dd8c460081ef024abbb925029a18adb5deea3522.tar.gz sqlite-dd8c460081ef024abbb925029a18adb5deea3522.zip |
Fix a crash that could occur if the WHERE clause of an UPDATE statement on a view that does not feature a column named "rowid" contains a term such as "rowid=?".
FossilOrigin-Name: 8523670d50004f3112b7871f11c8b8b02aab96ab
Diffstat (limited to 'src')
-rw-r--r-- | src/update.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/src/update.c b/src/update.c index f781a60cc..3af4017f1 100644 --- a/src/update.c +++ b/src/update.c @@ -431,8 +431,8 @@ void sqlite3Update( /* Top of the update loop */ if( okOnePass ){ - if( aToOpen[iDataCur-iBaseCur] ){ - assert( pPk!=0 ); + if( aToOpen[iDataCur-iBaseCur] && !isView ){ + assert( pPk ); sqlite3VdbeAddOp4Int(v, OP_NotFound, iDataCur, labelBreak, regKey, nKey); VdbeCoverageNeverTaken(v); } |