amalgalite 1.7.0-x86-mingw32 → 1.8.0-x86-mingw32
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/HISTORY.md +13 -0
- data/LICENSE +1 -1
- data/README.md +3 -2
- data/Rakefile +9 -8
- data/ext/amalgalite/c/sqlite3.c +25132 -13270
- data/ext/amalgalite/c/sqlite3.h +762 -105
- data/ext/amalgalite/c/sqlite3ext.h +44 -2
- data/lib/amalgalite/2.4/amalgalite.so +0 -0
- data/lib/amalgalite/2.5/amalgalite.so +0 -0
- data/lib/amalgalite/2.6/amalgalite.so +0 -0
- data/lib/amalgalite/2.7/amalgalite.so +0 -0
- data/lib/amalgalite/3.0/amalgalite.so +0 -0
- data/lib/amalgalite/3.1/amalgalite.so +0 -0
- data/lib/amalgalite/csv_table_importer.rb +3 -2
- data/lib/amalgalite/version.rb +1 -1
- data/spec/sqlite3/version_spec.rb +7 -7
- data/tasks/custom.rake +7 -8
- data/tasks/default.rake +13 -9
- data/tasks/extension.rake +12 -22
- data/tasks/this.rb +5 -5
- metadata +39 -32
- data/lib/amalgalite/2.2/amalgalite.so +0 -0
- data/lib/amalgalite/2.3/amalgalite.so +0 -0
data/ext/amalgalite/c/sqlite3.h
CHANGED
@@ -43,7 +43,30 @@ extern "C" {
|
|
43
43
|
|
44
44
|
|
45
45
|
/*
|
46
|
-
**
|
46
|
+
** Facilitate override of interface linkage and calling conventions.
|
47
|
+
** Be aware that these macros may not be used within this particular
|
48
|
+
** translation of the amalgamation and its associated header file.
|
49
|
+
**
|
50
|
+
** The SQLITE_EXTERN and SQLITE_API macros are used to instruct the
|
51
|
+
** compiler that the target identifier should have external linkage.
|
52
|
+
**
|
53
|
+
** The SQLITE_CDECL macro is used to set the calling convention for
|
54
|
+
** public functions that accept a variable number of arguments.
|
55
|
+
**
|
56
|
+
** The SQLITE_APICALL macro is used to set the calling convention for
|
57
|
+
** public functions that accept a fixed number of arguments.
|
58
|
+
**
|
59
|
+
** The SQLITE_STDCALL macro is no longer used and is now deprecated.
|
60
|
+
**
|
61
|
+
** The SQLITE_CALLBACK macro is used to set the calling convention for
|
62
|
+
** function pointers.
|
63
|
+
**
|
64
|
+
** The SQLITE_SYSAPI macro is used to set the calling convention for
|
65
|
+
** functions provided by the operating system.
|
66
|
+
**
|
67
|
+
** Currently, the SQLITE_CDECL, SQLITE_APICALL, SQLITE_CALLBACK, and
|
68
|
+
** SQLITE_SYSAPI macros are used only when building for environments
|
69
|
+
** that require non-default calling conventions.
|
47
70
|
*/
|
48
71
|
#ifndef SQLITE_EXTERN
|
49
72
|
# define SQLITE_EXTERN extern
|
@@ -123,9 +146,9 @@ extern "C" {
|
|
123
146
|
** [sqlite3_libversion_number()], [sqlite3_sourceid()],
|
124
147
|
** [sqlite_version()] and [sqlite_source_id()].
|
125
148
|
*/
|
126
|
-
#define SQLITE_VERSION "3.
|
127
|
-
#define SQLITE_VERSION_NUMBER
|
128
|
-
#define SQLITE_SOURCE_ID "
|
149
|
+
#define SQLITE_VERSION "3.40.1"
|
150
|
+
#define SQLITE_VERSION_NUMBER 3040001
|
151
|
+
#define SQLITE_SOURCE_ID "2022-12-28 14:03:47 df5c253c0b3dd24916e4ec7cf77d3db5294cc9fd45ae7b9c5e82ad8197f38a24"
|
129
152
|
|
130
153
|
/*
|
131
154
|
** CAPI3REF: Run-Time Library Version Numbers
|
@@ -537,12 +560,13 @@ SQLITE_API int sqlite3_exec(
|
|
537
560
|
#define SQLITE_CONSTRAINT_VTAB (SQLITE_CONSTRAINT | (9<<8))
|
538
561
|
#define SQLITE_CONSTRAINT_ROWID (SQLITE_CONSTRAINT |(10<<8))
|
539
562
|
#define SQLITE_CONSTRAINT_PINNED (SQLITE_CONSTRAINT |(11<<8))
|
563
|
+
#define SQLITE_CONSTRAINT_DATATYPE (SQLITE_CONSTRAINT |(12<<8))
|
540
564
|
#define SQLITE_NOTICE_RECOVER_WAL (SQLITE_NOTICE | (1<<8))
|
541
565
|
#define SQLITE_NOTICE_RECOVER_ROLLBACK (SQLITE_NOTICE | (2<<8))
|
542
566
|
#define SQLITE_WARNING_AUTOINDEX (SQLITE_WARNING | (1<<8))
|
543
567
|
#define SQLITE_AUTH_USER (SQLITE_AUTH | (1<<8))
|
544
568
|
#define SQLITE_OK_LOAD_PERMANENTLY (SQLITE_OK | (1<<8))
|
545
|
-
#define SQLITE_OK_SYMLINK (SQLITE_OK | (2<<8))
|
569
|
+
#define SQLITE_OK_SYMLINK (SQLITE_OK | (2<<8)) /* internal use only */
|
546
570
|
|
547
571
|
/*
|
548
572
|
** CAPI3REF: Flags For File Open Operations
|
@@ -550,6 +574,19 @@ SQLITE_API int sqlite3_exec(
|
|
550
574
|
** These bit values are intended for use in the
|
551
575
|
** 3rd parameter to the [sqlite3_open_v2()] interface and
|
552
576
|
** in the 4th parameter to the [sqlite3_vfs.xOpen] method.
|
577
|
+
**
|
578
|
+
** Only those flags marked as "Ok for sqlite3_open_v2()" may be
|
579
|
+
** used as the third argument to the [sqlite3_open_v2()] interface.
|
580
|
+
** The other flags have historically been ignored by sqlite3_open_v2(),
|
581
|
+
** though future versions of SQLite might change so that an error is
|
582
|
+
** raised if any of the disallowed bits are passed into sqlite3_open_v2().
|
583
|
+
** Applications should not depend on the historical behavior.
|
584
|
+
**
|
585
|
+
** Note in particular that passing the SQLITE_OPEN_EXCLUSIVE flag into
|
586
|
+
** [sqlite3_open_v2()] does *not* cause the underlying database file
|
587
|
+
** to be opened using O_EXCL. Passing SQLITE_OPEN_EXCLUSIVE into
|
588
|
+
** [sqlite3_open_v2()] has historically be a no-op and might become an
|
589
|
+
** error in future versions of SQLite.
|
553
590
|
*/
|
554
591
|
#define SQLITE_OPEN_READONLY 0x00000001 /* Ok for sqlite3_open_v2() */
|
555
592
|
#define SQLITE_OPEN_READWRITE 0x00000002 /* Ok for sqlite3_open_v2() */
|
@@ -572,6 +609,7 @@ SQLITE_API int sqlite3_exec(
|
|
572
609
|
#define SQLITE_OPEN_PRIVATECACHE 0x00040000 /* Ok for sqlite3_open_v2() */
|
573
610
|
#define SQLITE_OPEN_WAL 0x00080000 /* VFS only */
|
574
611
|
#define SQLITE_OPEN_NOFOLLOW 0x01000000 /* Ok for sqlite3_open_v2() */
|
612
|
+
#define SQLITE_OPEN_EXRESCODE 0x02000000 /* Extended result codes */
|
575
613
|
|
576
614
|
/* Reserved: 0x00F00000 */
|
577
615
|
/* Legacy compatibility: */
|
@@ -632,13 +670,17 @@ SQLITE_API int sqlite3_exec(
|
|
632
670
|
**
|
633
671
|
** SQLite uses one of these integer values as the second
|
634
672
|
** argument to calls it makes to the xLock() and xUnlock() methods
|
635
|
-
** of an [sqlite3_io_methods] object.
|
673
|
+
** of an [sqlite3_io_methods] object. These values are ordered from
|
674
|
+
** lest restrictive to most restrictive.
|
675
|
+
**
|
676
|
+
** The argument to xLock() is always SHARED or higher. The argument to
|
677
|
+
** xUnlock is either SHARED or NONE.
|
636
678
|
*/
|
637
|
-
#define SQLITE_LOCK_NONE 0
|
638
|
-
#define SQLITE_LOCK_SHARED 1
|
639
|
-
#define SQLITE_LOCK_RESERVED 2
|
640
|
-
#define SQLITE_LOCK_PENDING 3
|
641
|
-
#define SQLITE_LOCK_EXCLUSIVE 4
|
679
|
+
#define SQLITE_LOCK_NONE 0 /* xUnlock() only */
|
680
|
+
#define SQLITE_LOCK_SHARED 1 /* xLock() or xUnlock() */
|
681
|
+
#define SQLITE_LOCK_RESERVED 2 /* xLock() only */
|
682
|
+
#define SQLITE_LOCK_PENDING 3 /* xLock() only */
|
683
|
+
#define SQLITE_LOCK_EXCLUSIVE 4 /* xLock() only */
|
642
684
|
|
643
685
|
/*
|
644
686
|
** CAPI3REF: Synchronization Type Flags
|
@@ -716,7 +758,14 @@ struct sqlite3_file {
|
|
716
758
|
** <li> [SQLITE_LOCK_PENDING], or
|
717
759
|
** <li> [SQLITE_LOCK_EXCLUSIVE].
|
718
760
|
** </ul>
|
719
|
-
** xLock()
|
761
|
+
** xLock() upgrades the database file lock. In other words, xLock() moves the
|
762
|
+
** database file lock in the direction NONE toward EXCLUSIVE. The argument to
|
763
|
+
** xLock() is always on of SHARED, RESERVED, PENDING, or EXCLUSIVE, never
|
764
|
+
** SQLITE_LOCK_NONE. If the database file lock is already at or above the
|
765
|
+
** requested lock, then the call to xLock() is a no-op.
|
766
|
+
** xUnlock() downgrades the database file lock to either SHARED or NONE.
|
767
|
+
* If the lock is already at or below the requested lock state, then the call
|
768
|
+
** to xUnlock() is a no-op.
|
720
769
|
** The xCheckReservedLock() method checks whether any database connection,
|
721
770
|
** either in this process or in some other process, is holding a RESERVED,
|
722
771
|
** PENDING, or EXCLUSIVE lock on the file. It returns true
|
@@ -821,9 +870,8 @@ struct sqlite3_io_methods {
|
|
821
870
|
** opcode causes the xFileControl method to write the current state of
|
822
871
|
** the lock (one of [SQLITE_LOCK_NONE], [SQLITE_LOCK_SHARED],
|
823
872
|
** [SQLITE_LOCK_RESERVED], [SQLITE_LOCK_PENDING], or [SQLITE_LOCK_EXCLUSIVE])
|
824
|
-
** into an integer that the pArg argument points to.
|
825
|
-
** is
|
826
|
-
** compile-time option is used.
|
873
|
+
** into an integer that the pArg argument points to.
|
874
|
+
** This capability is only available if SQLite is compiled with [SQLITE_DEBUG].
|
827
875
|
**
|
828
876
|
** <li>[[SQLITE_FCNTL_SIZE_HINT]]
|
829
877
|
** The [SQLITE_FCNTL_SIZE_HINT] opcode is used by SQLite to give the VFS
|
@@ -1128,6 +1176,29 @@ struct sqlite3_io_methods {
|
|
1128
1176
|
** file to the database file, but before the *-shm file is updated to
|
1129
1177
|
** record the fact that the pages have been checkpointed.
|
1130
1178
|
** </ul>
|
1179
|
+
**
|
1180
|
+
** <li>[[SQLITE_FCNTL_EXTERNAL_READER]]
|
1181
|
+
** The EXPERIMENTAL [SQLITE_FCNTL_EXTERNAL_READER] opcode is used to detect
|
1182
|
+
** whether or not there is a database client in another process with a wal-mode
|
1183
|
+
** transaction open on the database or not. It is only available on unix.The
|
1184
|
+
** (void*) argument passed with this file-control should be a pointer to a
|
1185
|
+
** value of type (int). The integer value is set to 1 if the database is a wal
|
1186
|
+
** mode database and there exists at least one client in another process that
|
1187
|
+
** currently has an SQL transaction open on the database. It is set to 0 if
|
1188
|
+
** the database is not a wal-mode db, or if there is no such connection in any
|
1189
|
+
** other process. This opcode cannot be used to detect transactions opened
|
1190
|
+
** by clients within the current process, only within other processes.
|
1191
|
+
** </ul>
|
1192
|
+
**
|
1193
|
+
** <li>[[SQLITE_FCNTL_CKSM_FILE]]
|
1194
|
+
** Used by the cksmvfs VFS module only.
|
1195
|
+
**
|
1196
|
+
** <li>[[SQLITE_FCNTL_RESET_CACHE]]
|
1197
|
+
** If there is currently no transaction open on the database, and the
|
1198
|
+
** database is not a temp db, then this file-control purges the contents
|
1199
|
+
** of the in-memory page cache. If there is an open transaction, or if
|
1200
|
+
** the db is a temp-db, it is a no-op, not an error.
|
1201
|
+
** </ul>
|
1131
1202
|
*/
|
1132
1203
|
#define SQLITE_FCNTL_LOCKSTATE 1
|
1133
1204
|
#define SQLITE_FCNTL_GET_LOCKPROXYFILE 2
|
@@ -1167,6 +1238,9 @@ struct sqlite3_io_methods {
|
|
1167
1238
|
#define SQLITE_FCNTL_CKPT_DONE 37
|
1168
1239
|
#define SQLITE_FCNTL_RESERVE_BYTES 38
|
1169
1240
|
#define SQLITE_FCNTL_CKPT_START 39
|
1241
|
+
#define SQLITE_FCNTL_EXTERNAL_READER 40
|
1242
|
+
#define SQLITE_FCNTL_CKSM_FILE 41
|
1243
|
+
#define SQLITE_FCNTL_RESET_CACHE 42
|
1170
1244
|
|
1171
1245
|
/* deprecated names */
|
1172
1246
|
#define SQLITE_GET_LOCKPROXYFILE SQLITE_FCNTL_GET_LOCKPROXYFILE
|
@@ -1196,6 +1270,26 @@ typedef struct sqlite3_mutex sqlite3_mutex;
|
|
1196
1270
|
*/
|
1197
1271
|
typedef struct sqlite3_api_routines sqlite3_api_routines;
|
1198
1272
|
|
1273
|
+
/*
|
1274
|
+
** CAPI3REF: File Name
|
1275
|
+
**
|
1276
|
+
** Type [sqlite3_filename] is used by SQLite to pass filenames to the
|
1277
|
+
** xOpen method of a [VFS]. It may be cast to (const char*) and treated
|
1278
|
+
** as a normal, nul-terminated, UTF-8 buffer containing the filename, but
|
1279
|
+
** may also be passed to special APIs such as:
|
1280
|
+
**
|
1281
|
+
** <ul>
|
1282
|
+
** <li> sqlite3_filename_database()
|
1283
|
+
** <li> sqlite3_filename_journal()
|
1284
|
+
** <li> sqlite3_filename_wal()
|
1285
|
+
** <li> sqlite3_uri_parameter()
|
1286
|
+
** <li> sqlite3_uri_boolean()
|
1287
|
+
** <li> sqlite3_uri_int64()
|
1288
|
+
** <li> sqlite3_uri_key()
|
1289
|
+
** </ul>
|
1290
|
+
*/
|
1291
|
+
typedef const char *sqlite3_filename;
|
1292
|
+
|
1199
1293
|
/*
|
1200
1294
|
** CAPI3REF: OS Interface Object
|
1201
1295
|
**
|
@@ -1374,7 +1468,7 @@ struct sqlite3_vfs {
|
|
1374
1468
|
sqlite3_vfs *pNext; /* Next registered VFS */
|
1375
1469
|
const char *zName; /* Name of this virtual file system */
|
1376
1470
|
void *pAppData; /* Pointer to application-specific data */
|
1377
|
-
int (*xOpen)(sqlite3_vfs*,
|
1471
|
+
int (*xOpen)(sqlite3_vfs*, sqlite3_filename zName, sqlite3_file*,
|
1378
1472
|
int flags, int *pOutFlags);
|
1379
1473
|
int (*xDelete)(sqlite3_vfs*, const char *zName, int syncDir);
|
1380
1474
|
int (*xAccess)(sqlite3_vfs*, const char *zName, int flags, int *pResOut);
|
@@ -2115,7 +2209,13 @@ struct sqlite3_mem_methods {
|
|
2115
2209
|
** The second parameter is a pointer to an integer into which
|
2116
2210
|
** is written 0 or 1 to indicate whether triggers are disabled or enabled
|
2117
2211
|
** following this call. The second parameter may be a NULL pointer, in
|
2118
|
-
** which case the trigger setting is not reported back.
|
2212
|
+
** which case the trigger setting is not reported back.
|
2213
|
+
**
|
2214
|
+
** <p>Originally this option disabled all triggers. ^(However, since
|
2215
|
+
** SQLite version 3.35.0, TEMP triggers are still allowed even if
|
2216
|
+
** this option is off. So, in other words, this option now only disables
|
2217
|
+
** triggers in the main database schema or in the schemas of ATTACH-ed
|
2218
|
+
** databases.)^ </dd>
|
2119
2219
|
**
|
2120
2220
|
** [[SQLITE_DBCONFIG_ENABLE_VIEW]]
|
2121
2221
|
** <dt>SQLITE_DBCONFIG_ENABLE_VIEW</dt>
|
@@ -2126,7 +2226,13 @@ struct sqlite3_mem_methods {
|
|
2126
2226
|
** The second parameter is a pointer to an integer into which
|
2127
2227
|
** is written 0 or 1 to indicate whether views are disabled or enabled
|
2128
2228
|
** following this call. The second parameter may be a NULL pointer, in
|
2129
|
-
** which case the view setting is not reported back.
|
2229
|
+
** which case the view setting is not reported back.
|
2230
|
+
**
|
2231
|
+
** <p>Originally this option disabled all views. ^(However, since
|
2232
|
+
** SQLite version 3.35.0, TEMP views are still allowed even if
|
2233
|
+
** this option is off. So, in other words, this option now only disables
|
2234
|
+
** views in the main database schema or in the schemas of ATTACH-ed
|
2235
|
+
** databases.)^ </dd>
|
2130
2236
|
**
|
2131
2237
|
** [[SQLITE_DBCONFIG_ENABLE_FTS3_TOKENIZER]]
|
2132
2238
|
** <dt>SQLITE_DBCONFIG_ENABLE_FTS3_TOKENIZER</dt>
|
@@ -2240,6 +2346,7 @@ struct sqlite3_mem_methods {
|
|
2240
2346
|
** <ul>
|
2241
2347
|
** <li> The [PRAGMA writable_schema=ON] statement.
|
2242
2348
|
** <li> The [PRAGMA journal_mode=OFF] statement.
|
2349
|
+
** <li> The [PRAGMA schema_version=N] statement.
|
2243
2350
|
** <li> Writes to the [sqlite_dbpage] virtual table.
|
2244
2351
|
** <li> Direct writes to [shadow tables].
|
2245
2352
|
** </ul>
|
@@ -2433,11 +2540,14 @@ SQLITE_API void sqlite3_set_last_insert_rowid(sqlite3*,sqlite3_int64);
|
|
2433
2540
|
** CAPI3REF: Count The Number Of Rows Modified
|
2434
2541
|
** METHOD: sqlite3
|
2435
2542
|
**
|
2436
|
-
** ^
|
2543
|
+
** ^These functions return the number of rows modified, inserted or
|
2437
2544
|
** deleted by the most recently completed INSERT, UPDATE or DELETE
|
2438
2545
|
** statement on the database connection specified by the only parameter.
|
2439
|
-
**
|
2440
|
-
**
|
2546
|
+
** The two functions are identical except for the type of the return value
|
2547
|
+
** and that if the number of rows modified by the most recent INSERT, UPDATE
|
2548
|
+
** or DELETE is greater than the maximum value supported by type "int", then
|
2549
|
+
** the return value of sqlite3_changes() is undefined. ^Executing any other
|
2550
|
+
** type of SQL statement does not modify the value returned by these functions.
|
2441
2551
|
**
|
2442
2552
|
** ^Only changes made directly by the INSERT, UPDATE or DELETE statement are
|
2443
2553
|
** considered - auxiliary changes caused by [CREATE TRIGGER | triggers],
|
@@ -2486,16 +2596,21 @@ SQLITE_API void sqlite3_set_last_insert_rowid(sqlite3*,sqlite3_int64);
|
|
2486
2596
|
** </ul>
|
2487
2597
|
*/
|
2488
2598
|
SQLITE_API int sqlite3_changes(sqlite3*);
|
2599
|
+
SQLITE_API sqlite3_int64 sqlite3_changes64(sqlite3*);
|
2489
2600
|
|
2490
2601
|
/*
|
2491
2602
|
** CAPI3REF: Total Number Of Rows Modified
|
2492
2603
|
** METHOD: sqlite3
|
2493
2604
|
**
|
2494
|
-
** ^
|
2605
|
+
** ^These functions return the total number of rows inserted, modified or
|
2495
2606
|
** deleted by all [INSERT], [UPDATE] or [DELETE] statements completed
|
2496
2607
|
** since the database connection was opened, including those executed as
|
2497
|
-
** part of trigger programs.
|
2498
|
-
**
|
2608
|
+
** part of trigger programs. The two functions are identical except for the
|
2609
|
+
** type of the return value and that if the number of rows modified by the
|
2610
|
+
** connection exceeds the maximum value supported by type "int", then
|
2611
|
+
** the return value of sqlite3_total_changes() is undefined. ^Executing
|
2612
|
+
** any other type of SQL statement does not affect the value returned by
|
2613
|
+
** sqlite3_total_changes().
|
2499
2614
|
**
|
2500
2615
|
** ^Changes made as part of [foreign key actions] are included in the
|
2501
2616
|
** count, but those made as part of REPLACE constraint resolution are
|
@@ -2523,6 +2638,7 @@ SQLITE_API int sqlite3_changes(sqlite3*);
|
|
2523
2638
|
** </ul>
|
2524
2639
|
*/
|
2525
2640
|
SQLITE_API int sqlite3_total_changes(sqlite3*);
|
2641
|
+
SQLITE_API sqlite3_int64 sqlite3_total_changes64(sqlite3*);
|
2526
2642
|
|
2527
2643
|
/*
|
2528
2644
|
** CAPI3REF: Interrupt A Long-Running Query
|
@@ -3346,20 +3462,39 @@ SQLITE_API void sqlite3_progress_handler(sqlite3*, int, int(*)(void*), void*);
|
|
3346
3462
|
** <dd>The database is opened [shared cache] enabled, overriding
|
3347
3463
|
** the default shared cache setting provided by
|
3348
3464
|
** [sqlite3_enable_shared_cache()].)^
|
3465
|
+
** The [use of shared cache mode is discouraged] and hence shared cache
|
3466
|
+
** capabilities may be omitted from many builds of SQLite. In such cases,
|
3467
|
+
** this option is a no-op.
|
3349
3468
|
**
|
3350
3469
|
** ^(<dt>[SQLITE_OPEN_PRIVATECACHE]</dt>
|
3351
3470
|
** <dd>The database is opened [shared cache] disabled, overriding
|
3352
3471
|
** the default shared cache setting provided by
|
3353
3472
|
** [sqlite3_enable_shared_cache()].)^
|
3354
3473
|
**
|
3474
|
+
** [[OPEN_EXRESCODE]] ^(<dt>[SQLITE_OPEN_EXRESCODE]</dt>
|
3475
|
+
** <dd>The database connection comes up in "extended result code mode".
|
3476
|
+
** In other words, the database behaves has if
|
3477
|
+
** [sqlite3_extended_result_codes(db,1)] where called on the database
|
3478
|
+
** connection as soon as the connection is created. In addition to setting
|
3479
|
+
** the extended result code mode, this flag also causes [sqlite3_open_v2()]
|
3480
|
+
** to return an extended result code.</dd>
|
3481
|
+
**
|
3355
3482
|
** [[OPEN_NOFOLLOW]] ^(<dt>[SQLITE_OPEN_NOFOLLOW]</dt>
|
3356
|
-
** <dd>The database filename is not allowed to
|
3483
|
+
** <dd>The database filename is not allowed to contain a symbolic link</dd>
|
3357
3484
|
** </dl>)^
|
3358
3485
|
**
|
3359
3486
|
** If the 3rd parameter to sqlite3_open_v2() is not one of the
|
3360
3487
|
** required combinations shown above optionally combined with other
|
3361
3488
|
** [SQLITE_OPEN_READONLY | SQLITE_OPEN_* bits]
|
3362
|
-
** then the behavior is undefined.
|
3489
|
+
** then the behavior is undefined. Historic versions of SQLite
|
3490
|
+
** have silently ignored surplus bits in the flags parameter to
|
3491
|
+
** sqlite3_open_v2(), however that behavior might not be carried through
|
3492
|
+
** into future versions of SQLite and so applications should not rely
|
3493
|
+
** upon it. Note in particular that the SQLITE_OPEN_EXCLUSIVE flag is a no-op
|
3494
|
+
** for sqlite3_open_v2(). The SQLITE_OPEN_EXCLUSIVE does *not* cause
|
3495
|
+
** the open to fail if the database already exists. The SQLITE_OPEN_EXCLUSIVE
|
3496
|
+
** flag is intended for use by the [sqlite3_vfs|VFS interface] only, and not
|
3497
|
+
** by sqlite3_open_v2().
|
3363
3498
|
**
|
3364
3499
|
** ^The fourth parameter to sqlite3_open_v2() is the name of the
|
3365
3500
|
** [sqlite3_vfs] object that defines the operating system interface that
|
@@ -3499,6 +3634,7 @@ SQLITE_API void sqlite3_progress_handler(sqlite3*, int, int(*)(void*), void*);
|
|
3499
3634
|
** that uses dot-files in place of posix advisory locking.
|
3500
3635
|
** <tr><td> file:data.db?mode=readonly <td>
|
3501
3636
|
** An error. "readonly" is not a valid option for the "mode" parameter.
|
3637
|
+
** Use "ro" instead: "file:data.db?mode=ro".
|
3502
3638
|
** </table>
|
3503
3639
|
**
|
3504
3640
|
** ^URI hexadecimal escape sequences (%HH) are supported within the path and
|
@@ -3603,10 +3739,10 @@ SQLITE_API int sqlite3_open_v2(
|
|
3603
3739
|
**
|
3604
3740
|
** See the [URI filename] documentation for additional information.
|
3605
3741
|
*/
|
3606
|
-
SQLITE_API const char *sqlite3_uri_parameter(
|
3607
|
-
SQLITE_API int sqlite3_uri_boolean(
|
3608
|
-
SQLITE_API sqlite3_int64 sqlite3_uri_int64(
|
3609
|
-
SQLITE_API const char *sqlite3_uri_key(
|
3742
|
+
SQLITE_API const char *sqlite3_uri_parameter(sqlite3_filename z, const char *zParam);
|
3743
|
+
SQLITE_API int sqlite3_uri_boolean(sqlite3_filename z, const char *zParam, int bDefault);
|
3744
|
+
SQLITE_API sqlite3_int64 sqlite3_uri_int64(sqlite3_filename, const char*, sqlite3_int64);
|
3745
|
+
SQLITE_API const char *sqlite3_uri_key(sqlite3_filename z, int N);
|
3610
3746
|
|
3611
3747
|
/*
|
3612
3748
|
** CAPI3REF: Translate filenames
|
@@ -3635,9 +3771,9 @@ SQLITE_API const char *sqlite3_uri_key(const char *zFilename, int N);
|
|
3635
3771
|
** return value from [sqlite3_db_filename()], then the result is
|
3636
3772
|
** undefined and is likely a memory access violation.
|
3637
3773
|
*/
|
3638
|
-
SQLITE_API const char *sqlite3_filename_database(
|
3639
|
-
SQLITE_API const char *sqlite3_filename_journal(
|
3640
|
-
SQLITE_API const char *sqlite3_filename_wal(
|
3774
|
+
SQLITE_API const char *sqlite3_filename_database(sqlite3_filename);
|
3775
|
+
SQLITE_API const char *sqlite3_filename_journal(sqlite3_filename);
|
3776
|
+
SQLITE_API const char *sqlite3_filename_wal(sqlite3_filename);
|
3641
3777
|
|
3642
3778
|
/*
|
3643
3779
|
** CAPI3REF: Database File Corresponding To A Journal
|
@@ -3697,20 +3833,20 @@ SQLITE_API sqlite3_file *sqlite3_database_file_object(const char*);
|
|
3697
3833
|
** If the Y parameter to sqlite3_free_filename(Y) is anything other
|
3698
3834
|
** than a NULL pointer or a pointer previously acquired from
|
3699
3835
|
** sqlite3_create_filename(), then bad things such as heap
|
3700
|
-
** corruption or segfaults may occur. The value Y should be
|
3836
|
+
** corruption or segfaults may occur. The value Y should not be
|
3701
3837
|
** used again after sqlite3_free_filename(Y) has been called. This means
|
3702
3838
|
** that if the [sqlite3_vfs.xOpen()] method of a VFS has been called using Y,
|
3703
3839
|
** then the corresponding [sqlite3_module.xClose() method should also be
|
3704
3840
|
** invoked prior to calling sqlite3_free_filename(Y).
|
3705
3841
|
*/
|
3706
|
-
SQLITE_API
|
3842
|
+
SQLITE_API sqlite3_filename sqlite3_create_filename(
|
3707
3843
|
const char *zDatabase,
|
3708
3844
|
const char *zJournal,
|
3709
3845
|
const char *zWal,
|
3710
3846
|
int nParam,
|
3711
3847
|
const char **azParam
|
3712
3848
|
);
|
3713
|
-
SQLITE_API void sqlite3_free_filename(
|
3849
|
+
SQLITE_API void sqlite3_free_filename(sqlite3_filename);
|
3714
3850
|
|
3715
3851
|
/*
|
3716
3852
|
** CAPI3REF: Error Codes And Messages
|
@@ -3729,13 +3865,14 @@ SQLITE_API void sqlite3_free_filename(char*);
|
|
3729
3865
|
** sqlite3_extended_errcode() might change with each API call.
|
3730
3866
|
** Except, there are some interfaces that are guaranteed to never
|
3731
3867
|
** change the value of the error code. The error-code preserving
|
3732
|
-
** interfaces
|
3868
|
+
** interfaces include the following:
|
3733
3869
|
**
|
3734
3870
|
** <ul>
|
3735
3871
|
** <li> sqlite3_errcode()
|
3736
3872
|
** <li> sqlite3_extended_errcode()
|
3737
3873
|
** <li> sqlite3_errmsg()
|
3738
3874
|
** <li> sqlite3_errmsg16()
|
3875
|
+
** <li> sqlite3_error_offset()
|
3739
3876
|
** </ul>
|
3740
3877
|
**
|
3741
3878
|
** ^The sqlite3_errmsg() and sqlite3_errmsg16() return English-language
|
@@ -3750,6 +3887,13 @@ SQLITE_API void sqlite3_free_filename(char*);
|
|
3750
3887
|
** ^(Memory to hold the error message string is managed internally
|
3751
3888
|
** and must not be freed by the application)^.
|
3752
3889
|
**
|
3890
|
+
** ^If the most recent error references a specific token in the input
|
3891
|
+
** SQL, the sqlite3_error_offset() interface returns the byte offset
|
3892
|
+
** of the start of that token. ^The byte offset returned by
|
3893
|
+
** sqlite3_error_offset() assumes that the input SQL is UTF8.
|
3894
|
+
** ^If the most recent error does not reference a specific token in the input
|
3895
|
+
** SQL, then the sqlite3_error_offset() function returns -1.
|
3896
|
+
**
|
3753
3897
|
** When the serialized [threading mode] is in use, it might be the
|
3754
3898
|
** case that a second error occurs on a separate thread in between
|
3755
3899
|
** the time of the first error and the call to these interfaces.
|
@@ -3769,6 +3913,7 @@ SQLITE_API int sqlite3_extended_errcode(sqlite3 *db);
|
|
3769
3913
|
SQLITE_API const char *sqlite3_errmsg(sqlite3*);
|
3770
3914
|
SQLITE_API const void *sqlite3_errmsg16(sqlite3*);
|
3771
3915
|
SQLITE_API const char *sqlite3_errstr(int);
|
3916
|
+
SQLITE_API int sqlite3_error_offset(sqlite3 *db);
|
3772
3917
|
|
3773
3918
|
/*
|
3774
3919
|
** CAPI3REF: Prepared Statement Object
|
@@ -4126,12 +4271,17 @@ SQLITE_API int sqlite3_prepare16_v3(
|
|
4126
4271
|
** are managed by SQLite and are automatically freed when the prepared
|
4127
4272
|
** statement is finalized.
|
4128
4273
|
** ^The string returned by sqlite3_expanded_sql(P), on the other hand,
|
4129
|
-
** is obtained from [sqlite3_malloc()] and must be
|
4274
|
+
** is obtained from [sqlite3_malloc()] and must be freed by the application
|
4130
4275
|
** by passing it to [sqlite3_free()].
|
4276
|
+
**
|
4277
|
+
** ^The sqlite3_normalized_sql() interface is only available if
|
4278
|
+
** the [SQLITE_ENABLE_NORMALIZE] compile-time option is defined.
|
4131
4279
|
*/
|
4132
4280
|
SQLITE_API const char *sqlite3_sql(sqlite3_stmt *pStmt);
|
4133
4281
|
SQLITE_API char *sqlite3_expanded_sql(sqlite3_stmt *pStmt);
|
4282
|
+
#ifdef SQLITE_ENABLE_NORMALIZE
|
4134
4283
|
SQLITE_API const char *sqlite3_normalized_sql(sqlite3_stmt *pStmt);
|
4284
|
+
#endif
|
4135
4285
|
|
4136
4286
|
/*
|
4137
4287
|
** CAPI3REF: Determine If An SQL Statement Writes The Database
|
@@ -4166,6 +4316,19 @@ SQLITE_API const char *sqlite3_normalized_sql(sqlite3_stmt *pStmt);
|
|
4166
4316
|
** [BEGIN] merely sets internal flags, but the [BEGIN|BEGIN IMMEDIATE] and
|
4167
4317
|
** [BEGIN|BEGIN EXCLUSIVE] commands do touch the database and so
|
4168
4318
|
** sqlite3_stmt_readonly() returns false for those commands.
|
4319
|
+
**
|
4320
|
+
** ^This routine returns false if there is any possibility that the
|
4321
|
+
** statement might change the database file. ^A false return does
|
4322
|
+
** not guarantee that the statement will change the database file.
|
4323
|
+
** ^For example, an UPDATE statement might have a WHERE clause that
|
4324
|
+
** makes it a no-op, but the sqlite3_stmt_readonly() result would still
|
4325
|
+
** be false. ^Similarly, a CREATE TABLE IF NOT EXISTS statement is a
|
4326
|
+
** read-only no-op if the table already exists, but
|
4327
|
+
** sqlite3_stmt_readonly() still returns false for such a statement.
|
4328
|
+
**
|
4329
|
+
** ^If prepared statement X is an [EXPLAIN] or [EXPLAIN QUERY PLAN]
|
4330
|
+
** statement, then sqlite3_stmt_readonly(X) returns the same value as
|
4331
|
+
** if the EXPLAIN or EXPLAIN QUERY PLAN prefix were omitted.
|
4169
4332
|
*/
|
4170
4333
|
SQLITE_API int sqlite3_stmt_readonly(sqlite3_stmt *pStmt);
|
4171
4334
|
|
@@ -4234,6 +4397,8 @@ SQLITE_API int sqlite3_stmt_busy(sqlite3_stmt*);
|
|
4234
4397
|
**
|
4235
4398
|
** ^The sqlite3_value objects that are passed as parameters into the
|
4236
4399
|
** implementation of [application-defined SQL functions] are protected.
|
4400
|
+
** ^The sqlite3_value objects returned by [sqlite3_vtab_rhs_value()]
|
4401
|
+
** are protected.
|
4237
4402
|
** ^The sqlite3_value object returned by
|
4238
4403
|
** [sqlite3_column_value()] is unprotected.
|
4239
4404
|
** Unprotected sqlite3_value objects may only be used as arguments
|
@@ -4335,18 +4500,22 @@ typedef struct sqlite3_context sqlite3_context;
|
|
4335
4500
|
** contain embedded NULs. The result of expressions involving strings
|
4336
4501
|
** with embedded NULs is undefined.
|
4337
4502
|
**
|
4338
|
-
** ^The fifth argument to the BLOB and string binding interfaces
|
4339
|
-
**
|
4340
|
-
**
|
4341
|
-
** to dispose of the BLOB or string
|
4342
|
-
**
|
4343
|
-
**
|
4344
|
-
**
|
4345
|
-
**
|
4346
|
-
**
|
4347
|
-
**
|
4348
|
-
**
|
4349
|
-
**
|
4503
|
+
** ^The fifth argument to the BLOB and string binding interfaces controls
|
4504
|
+
** or indicates the lifetime of the object referenced by the third parameter.
|
4505
|
+
** These three options exist:
|
4506
|
+
** ^ (1) A destructor to dispose of the BLOB or string after SQLite has finished
|
4507
|
+
** with it may be passed. ^It is called to dispose of the BLOB or string even
|
4508
|
+
** if the call to the bind API fails, except the destructor is not called if
|
4509
|
+
** the third parameter is a NULL pointer or the fourth parameter is negative.
|
4510
|
+
** ^ (2) The special constant, [SQLITE_STATIC], may be passsed to indicate that
|
4511
|
+
** the application remains responsible for disposing of the object. ^In this
|
4512
|
+
** case, the object and the provided pointer to it must remain valid until
|
4513
|
+
** either the prepared statement is finalized or the same SQL parameter is
|
4514
|
+
** bound to something else, whichever occurs sooner.
|
4515
|
+
** ^ (3) The constant, [SQLITE_TRANSIENT], may be passed to indicate that the
|
4516
|
+
** object is to be copied prior to the return from sqlite3_bind_*(). ^The
|
4517
|
+
** object and pointer to it must remain valid until then. ^SQLite will then
|
4518
|
+
** manage the lifetime of its private copy.
|
4350
4519
|
**
|
4351
4520
|
** ^The sixth argument to sqlite3_bind_text64() must be one of
|
4352
4521
|
** [SQLITE_UTF8], [SQLITE_UTF16], [SQLITE_UTF16BE], or [SQLITE_UTF16LE]
|
@@ -4851,6 +5020,10 @@ SQLITE_API int sqlite3_data_count(sqlite3_stmt *pStmt);
|
|
4851
5020
|
** even empty strings, are always zero-terminated. ^The return
|
4852
5021
|
** value from sqlite3_column_blob() for a zero-length BLOB is a NULL pointer.
|
4853
5022
|
**
|
5023
|
+
** ^Strings returned by sqlite3_column_text16() always have the endianness
|
5024
|
+
** which is native to the platform, regardless of the text encoding set
|
5025
|
+
** for the database.
|
5026
|
+
**
|
4854
5027
|
** <b>Warning:</b> ^The object returned by [sqlite3_column_value()] is an
|
4855
5028
|
** [unprotected sqlite3_value] object. In a multithreaded environment,
|
4856
5029
|
** an unprotected sqlite3_value object may only be used safely with
|
@@ -4864,7 +5037,7 @@ SQLITE_API int sqlite3_data_count(sqlite3_stmt *pStmt);
|
|
4864
5037
|
** [application-defined SQL functions] or [virtual tables], not within
|
4865
5038
|
** top-level application code.
|
4866
5039
|
**
|
4867
|
-
**
|
5040
|
+
** These routines may attempt to convert the datatype of the result.
|
4868
5041
|
** ^For example, if the internal representation is FLOAT and a text result
|
4869
5042
|
** is requested, [sqlite3_snprintf()] is used internally to perform the
|
4870
5043
|
** conversion automatically. ^(The following table details the conversions
|
@@ -4889,7 +5062,7 @@ SQLITE_API int sqlite3_data_count(sqlite3_stmt *pStmt);
|
|
4889
5062
|
** <tr><td> TEXT <td> BLOB <td> No change
|
4890
5063
|
** <tr><td> BLOB <td> INTEGER <td> [CAST] to INTEGER
|
4891
5064
|
** <tr><td> BLOB <td> FLOAT <td> [CAST] to REAL
|
4892
|
-
** <tr><td> BLOB <td> TEXT <td>
|
5065
|
+
** <tr><td> BLOB <td> TEXT <td> [CAST] to TEXT, ensure zero terminator
|
4893
5066
|
** </table>
|
4894
5067
|
** </blockquote>)^
|
4895
5068
|
**
|
@@ -5088,7 +5261,6 @@ SQLITE_API int sqlite3_reset(sqlite3_stmt *pStmt);
|
|
5088
5261
|
** within VIEWs, TRIGGERs, CHECK constraints, generated column expressions,
|
5089
5262
|
** index expressions, or the WHERE clause of partial indexes.
|
5090
5263
|
**
|
5091
|
-
** <span style="background-color:#ffff90;">
|
5092
5264
|
** For best security, the [SQLITE_DIRECTONLY] flag is recommended for
|
5093
5265
|
** all application-defined SQL functions that do not need to be
|
5094
5266
|
** used inside of triggers, view, CHECK constraints, or other elements of
|
@@ -5098,7 +5270,6 @@ SQLITE_API int sqlite3_reset(sqlite3_stmt *pStmt);
|
|
5098
5270
|
** a database file to include invocations of the function with parameters
|
5099
5271
|
** chosen by the attacker, which the application will then execute when
|
5100
5272
|
** the database file is opened and read.
|
5101
|
-
** </span>
|
5102
5273
|
**
|
5103
5274
|
** ^(The fifth parameter is an arbitrary pointer. The implementation of the
|
5104
5275
|
** function can gain access to this pointer using [sqlite3_user_data()].)^
|
@@ -5378,6 +5549,16 @@ SQLITE_API SQLITE_DEPRECATED int sqlite3_memory_alarm(void(*)(void*,sqlite3_int6
|
|
5378
5549
|
** then the conversion is performed. Otherwise no conversion occurs.
|
5379
5550
|
** The [SQLITE_INTEGER | datatype] after conversion is returned.)^
|
5380
5551
|
**
|
5552
|
+
** ^(The sqlite3_value_encoding(X) interface returns one of [SQLITE_UTF8],
|
5553
|
+
** [SQLITE_UTF16BE], or [SQLITE_UTF16LE] according to the current encoding
|
5554
|
+
** of the value X, assuming that X has type TEXT.)^ If sqlite3_value_type(X)
|
5555
|
+
** returns something other than SQLITE_TEXT, then the return value from
|
5556
|
+
** sqlite3_value_encoding(X) is meaningless. ^Calls to
|
5557
|
+
** sqlite3_value_text(X), sqlite3_value_text16(X), sqlite3_value_text16be(X),
|
5558
|
+
** sqlite3_value_text16le(X), sqlite3_value_bytes(X), or
|
5559
|
+
** sqlite3_value_bytes16(X) might change the encoding of the value X and
|
5560
|
+
** thus change the return from subsequent calls to sqlite3_value_encoding(X).
|
5561
|
+
**
|
5381
5562
|
** ^Within the [xUpdate] method of a [virtual table], the
|
5382
5563
|
** sqlite3_value_nochange(X) interface returns true if and only if
|
5383
5564
|
** the column corresponding to X is unchanged by the UPDATE operation
|
@@ -5442,6 +5623,7 @@ SQLITE_API int sqlite3_value_type(sqlite3_value*);
|
|
5442
5623
|
SQLITE_API int sqlite3_value_numeric_type(sqlite3_value*);
|
5443
5624
|
SQLITE_API int sqlite3_value_nochange(sqlite3_value*);
|
5444
5625
|
SQLITE_API int sqlite3_value_frombind(sqlite3_value*);
|
5626
|
+
SQLITE_API int sqlite3_value_encoding(sqlite3_value*);
|
5445
5627
|
|
5446
5628
|
/*
|
5447
5629
|
** CAPI3REF: Finding The Subtype Of SQL Values
|
@@ -5463,7 +5645,8 @@ SQLITE_API unsigned int sqlite3_value_subtype(sqlite3_value*);
|
|
5463
5645
|
** object D and returns a pointer to that copy. ^The [sqlite3_value] returned
|
5464
5646
|
** is a [protected sqlite3_value] object even if the input is not.
|
5465
5647
|
** ^The sqlite3_value_dup(V) interface returns NULL if V is NULL or if a
|
5466
|
-
** memory allocation fails.
|
5648
|
+
** memory allocation fails. ^If V is a [pointer value], then the result
|
5649
|
+
** of sqlite3_value_dup(V) is a NULL value.
|
5467
5650
|
**
|
5468
5651
|
** ^The sqlite3_value_free(V) interface frees an [sqlite3_value] object
|
5469
5652
|
** previously obtained from [sqlite3_value_dup()]. ^If V is a NULL pointer
|
@@ -5494,7 +5677,7 @@ SQLITE_API void sqlite3_value_free(sqlite3_value*);
|
|
5494
5677
|
**
|
5495
5678
|
** ^The sqlite3_aggregate_context(C,N) routine returns a NULL pointer
|
5496
5679
|
** when first called if N is less than or equal to zero or if a memory
|
5497
|
-
**
|
5680
|
+
** allocation error occurs.
|
5498
5681
|
**
|
5499
5682
|
** ^(The amount of space allocated by sqlite3_aggregate_context(C,N) is
|
5500
5683
|
** determined by the N parameter on first successful call. Changing the
|
@@ -5699,9 +5882,10 @@ typedef void (*sqlite3_destructor_type)(void*);
|
|
5699
5882
|
** of [SQLITE_UTF8], [SQLITE_UTF16], [SQLITE_UTF16BE], or [SQLITE_UTF16LE].
|
5700
5883
|
** ^SQLite takes the text result from the application from
|
5701
5884
|
** the 2nd parameter of the sqlite3_result_text* interfaces.
|
5702
|
-
** ^If the 3rd parameter to the sqlite3_result_text* interfaces
|
5703
|
-
** is negative, then SQLite
|
5704
|
-
**
|
5885
|
+
** ^If the 3rd parameter to any of the sqlite3_result_text* interfaces
|
5886
|
+
** other than sqlite3_result_text64() is negative, then SQLite computes
|
5887
|
+
** the string length itself by searching the 2nd parameter for the first
|
5888
|
+
** zero character.
|
5705
5889
|
** ^If the 3rd parameter to the sqlite3_result_text* interfaces
|
5706
5890
|
** is non-negative, then as many bytes (not characters) of the text
|
5707
5891
|
** pointed to by the 2nd parameter are taken as the application-defined
|
@@ -6145,6 +6329,28 @@ SQLITE_API int sqlite3_get_autocommit(sqlite3*);
|
|
6145
6329
|
*/
|
6146
6330
|
SQLITE_API sqlite3 *sqlite3_db_handle(sqlite3_stmt*);
|
6147
6331
|
|
6332
|
+
/*
|
6333
|
+
** CAPI3REF: Return The Schema Name For A Database Connection
|
6334
|
+
** METHOD: sqlite3
|
6335
|
+
**
|
6336
|
+
** ^The sqlite3_db_name(D,N) interface returns a pointer to the schema name
|
6337
|
+
** for the N-th database on database connection D, or a NULL pointer of N is
|
6338
|
+
** out of range. An N value of 0 means the main database file. An N of 1 is
|
6339
|
+
** the "temp" schema. Larger values of N correspond to various ATTACH-ed
|
6340
|
+
** databases.
|
6341
|
+
**
|
6342
|
+
** Space to hold the string that is returned by sqlite3_db_name() is managed
|
6343
|
+
** by SQLite itself. The string might be deallocated by any operation that
|
6344
|
+
** changes the schema, including [ATTACH] or [DETACH] or calls to
|
6345
|
+
** [sqlite3_serialize()] or [sqlite3_deserialize()], even operations that
|
6346
|
+
** occur on a different thread. Applications that need to
|
6347
|
+
** remember the string long-term should make their own copy. Applications that
|
6348
|
+
** are accessing the same database connection simultaneously on multiple
|
6349
|
+
** threads should mutex-protect calls to this API and should make their own
|
6350
|
+
** private copy of the result prior to releasing the mutex.
|
6351
|
+
*/
|
6352
|
+
SQLITE_API const char *sqlite3_db_name(sqlite3 *db, int N);
|
6353
|
+
|
6148
6354
|
/*
|
6149
6355
|
** CAPI3REF: Return The Filename For A Database Connection
|
6150
6356
|
** METHOD: sqlite3
|
@@ -6175,7 +6381,7 @@ SQLITE_API sqlite3 *sqlite3_db_handle(sqlite3_stmt*);
|
|
6175
6381
|
** <li> [sqlite3_filename_wal()]
|
6176
6382
|
** </ul>
|
6177
6383
|
*/
|
6178
|
-
SQLITE_API
|
6384
|
+
SQLITE_API sqlite3_filename sqlite3_db_filename(sqlite3 *db, const char *zDbName);
|
6179
6385
|
|
6180
6386
|
/*
|
6181
6387
|
** CAPI3REF: Determine if a database is read-only
|
@@ -6304,6 +6510,72 @@ SQLITE_API sqlite3_stmt *sqlite3_next_stmt(sqlite3 *pDb, sqlite3_stmt *pStmt);
|
|
6304
6510
|
SQLITE_API void *sqlite3_commit_hook(sqlite3*, int(*)(void*), void*);
|
6305
6511
|
SQLITE_API void *sqlite3_rollback_hook(sqlite3*, void(*)(void *), void*);
|
6306
6512
|
|
6513
|
+
/*
|
6514
|
+
** CAPI3REF: Autovacuum Compaction Amount Callback
|
6515
|
+
** METHOD: sqlite3
|
6516
|
+
**
|
6517
|
+
** ^The sqlite3_autovacuum_pages(D,C,P,X) interface registers a callback
|
6518
|
+
** function C that is invoked prior to each autovacuum of the database
|
6519
|
+
** file. ^The callback is passed a copy of the generic data pointer (P),
|
6520
|
+
** the schema-name of the attached database that is being autovacuumed,
|
6521
|
+
** the size of the database file in pages, the number of free pages,
|
6522
|
+
** and the number of bytes per page, respectively. The callback should
|
6523
|
+
** return the number of free pages that should be removed by the
|
6524
|
+
** autovacuum. ^If the callback returns zero, then no autovacuum happens.
|
6525
|
+
** ^If the value returned is greater than or equal to the number of
|
6526
|
+
** free pages, then a complete autovacuum happens.
|
6527
|
+
**
|
6528
|
+
** <p>^If there are multiple ATTACH-ed database files that are being
|
6529
|
+
** modified as part of a transaction commit, then the autovacuum pages
|
6530
|
+
** callback is invoked separately for each file.
|
6531
|
+
**
|
6532
|
+
** <p><b>The callback is not reentrant.</b> The callback function should
|
6533
|
+
** not attempt to invoke any other SQLite interface. If it does, bad
|
6534
|
+
** things may happen, including segmentation faults and corrupt database
|
6535
|
+
** files. The callback function should be a simple function that
|
6536
|
+
** does some arithmetic on its input parameters and returns a result.
|
6537
|
+
**
|
6538
|
+
** ^The X parameter to sqlite3_autovacuum_pages(D,C,P,X) is an optional
|
6539
|
+
** destructor for the P parameter. ^If X is not NULL, then X(P) is
|
6540
|
+
** invoked whenever the database connection closes or when the callback
|
6541
|
+
** is overwritten by another invocation of sqlite3_autovacuum_pages().
|
6542
|
+
**
|
6543
|
+
** <p>^There is only one autovacuum pages callback per database connection.
|
6544
|
+
** ^Each call to the sqlite3_autovacuum_pages() interface overrides all
|
6545
|
+
** previous invocations for that database connection. ^If the callback
|
6546
|
+
** argument (C) to sqlite3_autovacuum_pages(D,C,P,X) is a NULL pointer,
|
6547
|
+
** then the autovacuum steps callback is cancelled. The return value
|
6548
|
+
** from sqlite3_autovacuum_pages() is normally SQLITE_OK, but might
|
6549
|
+
** be some other error code if something goes wrong. The current
|
6550
|
+
** implementation will only return SQLITE_OK or SQLITE_MISUSE, but other
|
6551
|
+
** return codes might be added in future releases.
|
6552
|
+
**
|
6553
|
+
** <p>If no autovacuum pages callback is specified (the usual case) or
|
6554
|
+
** a NULL pointer is provided for the callback,
|
6555
|
+
** then the default behavior is to vacuum all free pages. So, in other
|
6556
|
+
** words, the default behavior is the same as if the callback function
|
6557
|
+
** were something like this:
|
6558
|
+
**
|
6559
|
+
** <blockquote><pre>
|
6560
|
+
** unsigned int demonstration_autovac_pages_callback(
|
6561
|
+
** void *pClientData,
|
6562
|
+
** const char *zSchema,
|
6563
|
+
** unsigned int nDbPage,
|
6564
|
+
** unsigned int nFreePage,
|
6565
|
+
** unsigned int nBytePerPage
|
6566
|
+
** ){
|
6567
|
+
** return nFreePage;
|
6568
|
+
** }
|
6569
|
+
** </pre></blockquote>
|
6570
|
+
*/
|
6571
|
+
SQLITE_API int sqlite3_autovacuum_pages(
|
6572
|
+
sqlite3 *db,
|
6573
|
+
unsigned int(*)(void*,const char*,unsigned int,unsigned int,unsigned int),
|
6574
|
+
void*,
|
6575
|
+
void(*)(void*)
|
6576
|
+
);
|
6577
|
+
|
6578
|
+
|
6307
6579
|
/*
|
6308
6580
|
** CAPI3REF: Data Change Notification Callbacks
|
6309
6581
|
** METHOD: sqlite3
|
@@ -6367,6 +6639,11 @@ SQLITE_API void *sqlite3_update_hook(
|
|
6367
6639
|
** to the same database. Sharing is enabled if the argument is true
|
6368
6640
|
** and disabled if the argument is false.)^
|
6369
6641
|
**
|
6642
|
+
** This interface is omitted if SQLite is compiled with
|
6643
|
+
** [-DSQLITE_OMIT_SHARED_CACHE]. The [-DSQLITE_OMIT_SHARED_CACHE]
|
6644
|
+
** compile-time option is recommended because the
|
6645
|
+
** [use of shared cache mode is discouraged].
|
6646
|
+
**
|
6370
6647
|
** ^Cache sharing is enabled and disabled for an entire process.
|
6371
6648
|
** This is a change as of SQLite [version 3.5.0] ([dateof:3.5.0]).
|
6372
6649
|
** In prior versions of SQLite,
|
@@ -6465,7 +6742,7 @@ SQLITE_API int sqlite3_db_release_memory(sqlite3*);
|
|
6465
6742
|
** ^The soft heap limit may not be greater than the hard heap limit.
|
6466
6743
|
** ^If the hard heap limit is enabled and if sqlite3_soft_heap_limit(N)
|
6467
6744
|
** is invoked with a value of N that is greater than the hard heap limit,
|
6468
|
-
** the
|
6745
|
+
** the soft heap limit is set to the value of the hard heap limit.
|
6469
6746
|
** ^The soft heap limit is automatically enabled whenever the hard heap
|
6470
6747
|
** limit is enabled. ^When sqlite3_hard_heap_limit64(N) is invoked and
|
6471
6748
|
** the soft heap limit is outside the range of 1..N, then the soft heap
|
@@ -6945,24 +7222,56 @@ struct sqlite3_index_info {
|
|
6945
7222
|
**
|
6946
7223
|
** These macros define the allowed values for the
|
6947
7224
|
** [sqlite3_index_info].aConstraint[].op field. Each value represents
|
6948
|
-
** an operator that is part of a constraint term in the
|
7225
|
+
** an operator that is part of a constraint term in the WHERE clause of
|
6949
7226
|
** a query that uses a [virtual table].
|
6950
|
-
|
6951
|
-
|
6952
|
-
|
6953
|
-
|
6954
|
-
|
6955
|
-
|
6956
|
-
|
6957
|
-
|
6958
|
-
|
6959
|
-
|
6960
|
-
|
6961
|
-
|
6962
|
-
|
6963
|
-
|
6964
|
-
|
6965
|
-
|
7227
|
+
**
|
7228
|
+
** ^The left-hand operand of the operator is given by the corresponding
|
7229
|
+
** aConstraint[].iColumn field. ^An iColumn of -1 indicates the left-hand
|
7230
|
+
** operand is the rowid.
|
7231
|
+
** The SQLITE_INDEX_CONSTRAINT_LIMIT and SQLITE_INDEX_CONSTRAINT_OFFSET
|
7232
|
+
** operators have no left-hand operand, and so for those operators the
|
7233
|
+
** corresponding aConstraint[].iColumn is meaningless and should not be
|
7234
|
+
** used.
|
7235
|
+
**
|
7236
|
+
** All operator values from SQLITE_INDEX_CONSTRAINT_FUNCTION through
|
7237
|
+
** value 255 are reserved to represent functions that are overloaded
|
7238
|
+
** by the [xFindFunction|xFindFunction method] of the virtual table
|
7239
|
+
** implementation.
|
7240
|
+
**
|
7241
|
+
** The right-hand operands for each constraint might be accessible using
|
7242
|
+
** the [sqlite3_vtab_rhs_value()] interface. Usually the right-hand
|
7243
|
+
** operand is only available if it appears as a single constant literal
|
7244
|
+
** in the input SQL. If the right-hand operand is another column or an
|
7245
|
+
** expression (even a constant expression) or a parameter, then the
|
7246
|
+
** sqlite3_vtab_rhs_value() probably will not be able to extract it.
|
7247
|
+
** ^The SQLITE_INDEX_CONSTRAINT_ISNULL and
|
7248
|
+
** SQLITE_INDEX_CONSTRAINT_ISNOTNULL operators have no right-hand operand
|
7249
|
+
** and hence calls to sqlite3_vtab_rhs_value() for those operators will
|
7250
|
+
** always return SQLITE_NOTFOUND.
|
7251
|
+
**
|
7252
|
+
** The collating sequence to be used for comparison can be found using
|
7253
|
+
** the [sqlite3_vtab_collation()] interface. For most real-world virtual
|
7254
|
+
** tables, the collating sequence of constraints does not matter (for example
|
7255
|
+
** because the constraints are numeric) and so the sqlite3_vtab_collation()
|
7256
|
+
** interface is no commonly needed.
|
7257
|
+
*/
|
7258
|
+
#define SQLITE_INDEX_CONSTRAINT_EQ 2
|
7259
|
+
#define SQLITE_INDEX_CONSTRAINT_GT 4
|
7260
|
+
#define SQLITE_INDEX_CONSTRAINT_LE 8
|
7261
|
+
#define SQLITE_INDEX_CONSTRAINT_LT 16
|
7262
|
+
#define SQLITE_INDEX_CONSTRAINT_GE 32
|
7263
|
+
#define SQLITE_INDEX_CONSTRAINT_MATCH 64
|
7264
|
+
#define SQLITE_INDEX_CONSTRAINT_LIKE 65
|
7265
|
+
#define SQLITE_INDEX_CONSTRAINT_GLOB 66
|
7266
|
+
#define SQLITE_INDEX_CONSTRAINT_REGEXP 67
|
7267
|
+
#define SQLITE_INDEX_CONSTRAINT_NE 68
|
7268
|
+
#define SQLITE_INDEX_CONSTRAINT_ISNOT 69
|
7269
|
+
#define SQLITE_INDEX_CONSTRAINT_ISNOTNULL 70
|
7270
|
+
#define SQLITE_INDEX_CONSTRAINT_ISNULL 71
|
7271
|
+
#define SQLITE_INDEX_CONSTRAINT_IS 72
|
7272
|
+
#define SQLITE_INDEX_CONSTRAINT_LIMIT 73
|
7273
|
+
#define SQLITE_INDEX_CONSTRAINT_OFFSET 74
|
7274
|
+
#define SQLITE_INDEX_CONSTRAINT_FUNCTION 150
|
6966
7275
|
|
6967
7276
|
/*
|
6968
7277
|
** CAPI3REF: Register A Virtual Table Implementation
|
@@ -6991,7 +7300,7 @@ struct sqlite3_index_info {
|
|
6991
7300
|
** destructor.
|
6992
7301
|
**
|
6993
7302
|
** ^If the third parameter (the pointer to the sqlite3_module object) is
|
6994
|
-
** NULL then no new module is
|
7303
|
+
** NULL then no new module is created and any existing modules with the
|
6995
7304
|
** same name are dropped.
|
6996
7305
|
**
|
6997
7306
|
** See also: [sqlite3_drop_modules()]
|
@@ -7765,7 +8074,10 @@ SQLITE_API int sqlite3_test_control(int op, ...);
|
|
7765
8074
|
#define SQLITE_TESTCTRL_PRNG_SEED 28
|
7766
8075
|
#define SQLITE_TESTCTRL_EXTRA_SCHEMA_CHECKS 29
|
7767
8076
|
#define SQLITE_TESTCTRL_SEEK_COUNT 30
|
7768
|
-
#define
|
8077
|
+
#define SQLITE_TESTCTRL_TRACEFLAGS 31
|
8078
|
+
#define SQLITE_TESTCTRL_TUNE 32
|
8079
|
+
#define SQLITE_TESTCTRL_LOGEST 33
|
8080
|
+
#define SQLITE_TESTCTRL_LAST 33 /* Largest TESTCTRL */
|
7769
8081
|
|
7770
8082
|
/*
|
7771
8083
|
** CAPI3REF: SQL Keyword Checking
|
@@ -8288,6 +8600,16 @@ SQLITE_API int sqlite3_stmt_status(sqlite3_stmt*, int op,int resetFlg);
|
|
8288
8600
|
** The counter is incremented on the first [sqlite3_step()] call of each
|
8289
8601
|
** cycle.
|
8290
8602
|
**
|
8603
|
+
** [[SQLITE_STMTSTATUS_FILTER_MISS]]
|
8604
|
+
** [[SQLITE_STMTSTATUS_FILTER HIT]]
|
8605
|
+
** <dt>SQLITE_STMTSTATUS_FILTER_HIT<br>
|
8606
|
+
** SQLITE_STMTSTATUS_FILTER_MISS</dt>
|
8607
|
+
** <dd>^SQLITE_STMTSTATUS_FILTER_HIT is the number of times that a join
|
8608
|
+
** step was bypassed because a Bloom filter returned not-found. The
|
8609
|
+
** corresponding SQLITE_STMTSTATUS_FILTER_MISS value is the number of
|
8610
|
+
** times that the Bloom filter returned a find, and thus the join step
|
8611
|
+
** had to be processed as normal.
|
8612
|
+
**
|
8291
8613
|
** [[SQLITE_STMTSTATUS_MEMUSED]] <dt>SQLITE_STMTSTATUS_MEMUSED</dt>
|
8292
8614
|
** <dd>^This is the approximate number of bytes of heap memory
|
8293
8615
|
** used to store the prepared statement. ^This value is not actually
|
@@ -8302,6 +8624,8 @@ SQLITE_API int sqlite3_stmt_status(sqlite3_stmt*, int op,int resetFlg);
|
|
8302
8624
|
#define SQLITE_STMTSTATUS_VM_STEP 4
|
8303
8625
|
#define SQLITE_STMTSTATUS_REPREPARE 5
|
8304
8626
|
#define SQLITE_STMTSTATUS_RUN 6
|
8627
|
+
#define SQLITE_STMTSTATUS_FILTER_MISS 7
|
8628
|
+
#define SQLITE_STMTSTATUS_FILTER_HIT 8
|
8305
8629
|
#define SQLITE_STMTSTATUS_MEMUSED 99
|
8306
8630
|
|
8307
8631
|
/*
|
@@ -8713,7 +9037,7 @@ typedef struct sqlite3_backup sqlite3_backup;
|
|
8713
9037
|
** if the application incorrectly accesses the destination [database connection]
|
8714
9038
|
** and so no error code is reported, but the operations may malfunction
|
8715
9039
|
** nevertheless. Use of the destination database connection while a
|
8716
|
-
** backup is in progress might also
|
9040
|
+
** backup is in progress might also cause a mutex deadlock.
|
8717
9041
|
**
|
8718
9042
|
** If running in [shared cache mode], the application must
|
8719
9043
|
** guarantee that the shared cache used by the destination database
|
@@ -8965,8 +9289,9 @@ SQLITE_API void sqlite3_log(int iErrCode, const char *zFormat, ...);
|
|
8965
9289
|
**
|
8966
9290
|
** A single database handle may have at most a single write-ahead log callback
|
8967
9291
|
** registered at one time. ^Calling [sqlite3_wal_hook()] replaces any
|
8968
|
-
** previously registered write-ahead log callback. ^
|
8969
|
-
**
|
9292
|
+
** previously registered write-ahead log callback. ^The return value is
|
9293
|
+
** a copy of the third parameter from the previous call, if any, or 0.
|
9294
|
+
** ^Note that the [sqlite3_wal_autocheckpoint()] interface and the
|
8970
9295
|
** [wal_autocheckpoint pragma] both invoke [sqlite3_wal_hook()] and will
|
8971
9296
|
** overwrite any prior [sqlite3_wal_hook()] settings.
|
8972
9297
|
*/
|
@@ -9140,7 +9465,7 @@ SQLITE_API int sqlite3_wal_checkpoint_v2(
|
|
9140
9465
|
*/
|
9141
9466
|
#define SQLITE_CHECKPOINT_PASSIVE 0 /* Do as much as possible w/o blocking */
|
9142
9467
|
#define SQLITE_CHECKPOINT_FULL 1 /* Wait for writers, then checkpoint */
|
9143
|
-
#define SQLITE_CHECKPOINT_RESTART 2 /* Like FULL but wait for
|
9468
|
+
#define SQLITE_CHECKPOINT_RESTART 2 /* Like FULL but wait for readers */
|
9144
9469
|
#define SQLITE_CHECKPOINT_TRUNCATE 3 /* Like RESTART but also truncate WAL */
|
9145
9470
|
|
9146
9471
|
/*
|
@@ -9269,19 +9594,276 @@ SQLITE_API int sqlite3_vtab_nochange(sqlite3_context*);
|
|
9269
9594
|
|
9270
9595
|
/*
|
9271
9596
|
** CAPI3REF: Determine The Collation For a Virtual Table Constraint
|
9597
|
+
** METHOD: sqlite3_index_info
|
9272
9598
|
**
|
9273
9599
|
** This function may only be called from within a call to the [xBestIndex]
|
9274
|
-
** method of a [virtual table].
|
9600
|
+
** method of a [virtual table]. This function returns a pointer to a string
|
9601
|
+
** that is the name of the appropriate collation sequence to use for text
|
9602
|
+
** comparisons on the constraint identified by its arguments.
|
9603
|
+
**
|
9604
|
+
** The first argument must be the pointer to the [sqlite3_index_info] object
|
9605
|
+
** that is the first parameter to the xBestIndex() method. The second argument
|
9606
|
+
** must be an index into the aConstraint[] array belonging to the
|
9607
|
+
** sqlite3_index_info structure passed to xBestIndex.
|
9275
9608
|
**
|
9276
|
-
**
|
9277
|
-
** first parameter
|
9278
|
-
**
|
9279
|
-
**
|
9280
|
-
**
|
9281
|
-
**
|
9609
|
+
** Important:
|
9610
|
+
** The first parameter must be the same pointer that is passed into the
|
9611
|
+
** xBestMethod() method. The first parameter may not be a pointer to a
|
9612
|
+
** different [sqlite3_index_info] object, even an exact copy.
|
9613
|
+
**
|
9614
|
+
** The return value is computed as follows:
|
9615
|
+
**
|
9616
|
+
** <ol>
|
9617
|
+
** <li><p> If the constraint comes from a WHERE clause expression that contains
|
9618
|
+
** a [COLLATE operator], then the name of the collation specified by
|
9619
|
+
** that COLLATE operator is returned.
|
9620
|
+
** <li><p> If there is no COLLATE operator, but the column that is the subject
|
9621
|
+
** of the constraint specifies an alternative collating sequence via
|
9622
|
+
** a [COLLATE clause] on the column definition within the CREATE TABLE
|
9623
|
+
** statement that was passed into [sqlite3_declare_vtab()], then the
|
9624
|
+
** name of that alternative collating sequence is returned.
|
9625
|
+
** <li><p> Otherwise, "BINARY" is returned.
|
9626
|
+
** </ol>
|
9282
9627
|
*/
|
9283
9628
|
SQLITE_API SQLITE_EXPERIMENTAL const char *sqlite3_vtab_collation(sqlite3_index_info*,int);
|
9284
9629
|
|
9630
|
+
/*
|
9631
|
+
** CAPI3REF: Determine if a virtual table query is DISTINCT
|
9632
|
+
** METHOD: sqlite3_index_info
|
9633
|
+
**
|
9634
|
+
** This API may only be used from within an [xBestIndex|xBestIndex method]
|
9635
|
+
** of a [virtual table] implementation. The result of calling this
|
9636
|
+
** interface from outside of xBestIndex() is undefined and probably harmful.
|
9637
|
+
**
|
9638
|
+
** ^The sqlite3_vtab_distinct() interface returns an integer between 0 and
|
9639
|
+
** 3. The integer returned by sqlite3_vtab_distinct()
|
9640
|
+
** gives the virtual table additional information about how the query
|
9641
|
+
** planner wants the output to be ordered. As long as the virtual table
|
9642
|
+
** can meet the ordering requirements of the query planner, it may set
|
9643
|
+
** the "orderByConsumed" flag.
|
9644
|
+
**
|
9645
|
+
** <ol><li value="0"><p>
|
9646
|
+
** ^If the sqlite3_vtab_distinct() interface returns 0, that means
|
9647
|
+
** that the query planner needs the virtual table to return all rows in the
|
9648
|
+
** sort order defined by the "nOrderBy" and "aOrderBy" fields of the
|
9649
|
+
** [sqlite3_index_info] object. This is the default expectation. If the
|
9650
|
+
** virtual table outputs all rows in sorted order, then it is always safe for
|
9651
|
+
** the xBestIndex method to set the "orderByConsumed" flag, regardless of
|
9652
|
+
** the return value from sqlite3_vtab_distinct().
|
9653
|
+
** <li value="1"><p>
|
9654
|
+
** ^(If the sqlite3_vtab_distinct() interface returns 1, that means
|
9655
|
+
** that the query planner does not need the rows to be returned in sorted order
|
9656
|
+
** as long as all rows with the same values in all columns identified by the
|
9657
|
+
** "aOrderBy" field are adjacent.)^ This mode is used when the query planner
|
9658
|
+
** is doing a GROUP BY.
|
9659
|
+
** <li value="2"><p>
|
9660
|
+
** ^(If the sqlite3_vtab_distinct() interface returns 2, that means
|
9661
|
+
** that the query planner does not need the rows returned in any particular
|
9662
|
+
** order, as long as rows with the same values in all "aOrderBy" columns
|
9663
|
+
** are adjacent.)^ ^(Furthermore, only a single row for each particular
|
9664
|
+
** combination of values in the columns identified by the "aOrderBy" field
|
9665
|
+
** needs to be returned.)^ ^It is always ok for two or more rows with the same
|
9666
|
+
** values in all "aOrderBy" columns to be returned, as long as all such rows
|
9667
|
+
** are adjacent. ^The virtual table may, if it chooses, omit extra rows
|
9668
|
+
** that have the same value for all columns identified by "aOrderBy".
|
9669
|
+
** ^However omitting the extra rows is optional.
|
9670
|
+
** This mode is used for a DISTINCT query.
|
9671
|
+
** <li value="3"><p>
|
9672
|
+
** ^(If the sqlite3_vtab_distinct() interface returns 3, that means
|
9673
|
+
** that the query planner needs only distinct rows but it does need the
|
9674
|
+
** rows to be sorted.)^ ^The virtual table implementation is free to omit
|
9675
|
+
** rows that are identical in all aOrderBy columns, if it wants to, but
|
9676
|
+
** it is not required to omit any rows. This mode is used for queries
|
9677
|
+
** that have both DISTINCT and ORDER BY clauses.
|
9678
|
+
** </ol>
|
9679
|
+
**
|
9680
|
+
** ^For the purposes of comparing virtual table output values to see if the
|
9681
|
+
** values are same value for sorting purposes, two NULL values are considered
|
9682
|
+
** to be the same. In other words, the comparison operator is "IS"
|
9683
|
+
** (or "IS NOT DISTINCT FROM") and not "==".
|
9684
|
+
**
|
9685
|
+
** If a virtual table implementation is unable to meet the requirements
|
9686
|
+
** specified above, then it must not set the "orderByConsumed" flag in the
|
9687
|
+
** [sqlite3_index_info] object or an incorrect answer may result.
|
9688
|
+
**
|
9689
|
+
** ^A virtual table implementation is always free to return rows in any order
|
9690
|
+
** it wants, as long as the "orderByConsumed" flag is not set. ^When the
|
9691
|
+
** the "orderByConsumed" flag is unset, the query planner will add extra
|
9692
|
+
** [bytecode] to ensure that the final results returned by the SQL query are
|
9693
|
+
** ordered correctly. The use of the "orderByConsumed" flag and the
|
9694
|
+
** sqlite3_vtab_distinct() interface is merely an optimization. ^Careful
|
9695
|
+
** use of the sqlite3_vtab_distinct() interface and the "orderByConsumed"
|
9696
|
+
** flag might help queries against a virtual table to run faster. Being
|
9697
|
+
** overly aggressive and setting the "orderByConsumed" flag when it is not
|
9698
|
+
** valid to do so, on the other hand, might cause SQLite to return incorrect
|
9699
|
+
** results.
|
9700
|
+
*/
|
9701
|
+
SQLITE_API int sqlite3_vtab_distinct(sqlite3_index_info*);
|
9702
|
+
|
9703
|
+
/*
|
9704
|
+
** CAPI3REF: Identify and handle IN constraints in xBestIndex
|
9705
|
+
**
|
9706
|
+
** This interface may only be used from within an
|
9707
|
+
** [xBestIndex|xBestIndex() method] of a [virtual table] implementation.
|
9708
|
+
** The result of invoking this interface from any other context is
|
9709
|
+
** undefined and probably harmful.
|
9710
|
+
**
|
9711
|
+
** ^(A constraint on a virtual table of the form
|
9712
|
+
** "[IN operator|column IN (...)]" is
|
9713
|
+
** communicated to the xBestIndex method as a
|
9714
|
+
** [SQLITE_INDEX_CONSTRAINT_EQ] constraint.)^ If xBestIndex wants to use
|
9715
|
+
** this constraint, it must set the corresponding
|
9716
|
+
** aConstraintUsage[].argvIndex to a postive integer. ^(Then, under
|
9717
|
+
** the usual mode of handling IN operators, SQLite generates [bytecode]
|
9718
|
+
** that invokes the [xFilter|xFilter() method] once for each value
|
9719
|
+
** on the right-hand side of the IN operator.)^ Thus the virtual table
|
9720
|
+
** only sees a single value from the right-hand side of the IN operator
|
9721
|
+
** at a time.
|
9722
|
+
**
|
9723
|
+
** In some cases, however, it would be advantageous for the virtual
|
9724
|
+
** table to see all values on the right-hand of the IN operator all at
|
9725
|
+
** once. The sqlite3_vtab_in() interfaces facilitates this in two ways:
|
9726
|
+
**
|
9727
|
+
** <ol>
|
9728
|
+
** <li><p>
|
9729
|
+
** ^A call to sqlite3_vtab_in(P,N,-1) will return true (non-zero)
|
9730
|
+
** if and only if the [sqlite3_index_info|P->aConstraint][N] constraint
|
9731
|
+
** is an [IN operator] that can be processed all at once. ^In other words,
|
9732
|
+
** sqlite3_vtab_in() with -1 in the third argument is a mechanism
|
9733
|
+
** by which the virtual table can ask SQLite if all-at-once processing
|
9734
|
+
** of the IN operator is even possible.
|
9735
|
+
**
|
9736
|
+
** <li><p>
|
9737
|
+
** ^A call to sqlite3_vtab_in(P,N,F) with F==1 or F==0 indicates
|
9738
|
+
** to SQLite that the virtual table does or does not want to process
|
9739
|
+
** the IN operator all-at-once, respectively. ^Thus when the third
|
9740
|
+
** parameter (F) is non-negative, this interface is the mechanism by
|
9741
|
+
** which the virtual table tells SQLite how it wants to process the
|
9742
|
+
** IN operator.
|
9743
|
+
** </ol>
|
9744
|
+
**
|
9745
|
+
** ^The sqlite3_vtab_in(P,N,F) interface can be invoked multiple times
|
9746
|
+
** within the same xBestIndex method call. ^For any given P,N pair,
|
9747
|
+
** the return value from sqlite3_vtab_in(P,N,F) will always be the same
|
9748
|
+
** within the same xBestIndex call. ^If the interface returns true
|
9749
|
+
** (non-zero), that means that the constraint is an IN operator
|
9750
|
+
** that can be processed all-at-once. ^If the constraint is not an IN
|
9751
|
+
** operator or cannot be processed all-at-once, then the interface returns
|
9752
|
+
** false.
|
9753
|
+
**
|
9754
|
+
** ^(All-at-once processing of the IN operator is selected if both of the
|
9755
|
+
** following conditions are met:
|
9756
|
+
**
|
9757
|
+
** <ol>
|
9758
|
+
** <li><p> The P->aConstraintUsage[N].argvIndex value is set to a positive
|
9759
|
+
** integer. This is how the virtual table tells SQLite that it wants to
|
9760
|
+
** use the N-th constraint.
|
9761
|
+
**
|
9762
|
+
** <li><p> The last call to sqlite3_vtab_in(P,N,F) for which F was
|
9763
|
+
** non-negative had F>=1.
|
9764
|
+
** </ol>)^
|
9765
|
+
**
|
9766
|
+
** ^If either or both of the conditions above are false, then SQLite uses
|
9767
|
+
** the traditional one-at-a-time processing strategy for the IN constraint.
|
9768
|
+
** ^If both conditions are true, then the argvIndex-th parameter to the
|
9769
|
+
** xFilter method will be an [sqlite3_value] that appears to be NULL,
|
9770
|
+
** but which can be passed to [sqlite3_vtab_in_first()] and
|
9771
|
+
** [sqlite3_vtab_in_next()] to find all values on the right-hand side
|
9772
|
+
** of the IN constraint.
|
9773
|
+
*/
|
9774
|
+
SQLITE_API int sqlite3_vtab_in(sqlite3_index_info*, int iCons, int bHandle);
|
9775
|
+
|
9776
|
+
/*
|
9777
|
+
** CAPI3REF: Find all elements on the right-hand side of an IN constraint.
|
9778
|
+
**
|
9779
|
+
** These interfaces are only useful from within the
|
9780
|
+
** [xFilter|xFilter() method] of a [virtual table] implementation.
|
9781
|
+
** The result of invoking these interfaces from any other context
|
9782
|
+
** is undefined and probably harmful.
|
9783
|
+
**
|
9784
|
+
** The X parameter in a call to sqlite3_vtab_in_first(X,P) or
|
9785
|
+
** sqlite3_vtab_in_next(X,P) must be one of the parameters to the
|
9786
|
+
** xFilter method which invokes these routines, and specifically
|
9787
|
+
** a parameter that was previously selected for all-at-once IN constraint
|
9788
|
+
** processing use the [sqlite3_vtab_in()] interface in the
|
9789
|
+
** [xBestIndex|xBestIndex method]. ^(If the X parameter is not
|
9790
|
+
** an xFilter argument that was selected for all-at-once IN constraint
|
9791
|
+
** processing, then these routines return [SQLITE_MISUSE])^ or perhaps
|
9792
|
+
** exhibit some other undefined or harmful behavior.
|
9793
|
+
**
|
9794
|
+
** ^(Use these routines to access all values on the right-hand side
|
9795
|
+
** of the IN constraint using code like the following:
|
9796
|
+
**
|
9797
|
+
** <blockquote><pre>
|
9798
|
+
** for(rc=sqlite3_vtab_in_first(pList, &pVal);
|
9799
|
+
** rc==SQLITE_OK && pVal
|
9800
|
+
** rc=sqlite3_vtab_in_next(pList, &pVal)
|
9801
|
+
** ){
|
9802
|
+
** // do something with pVal
|
9803
|
+
** }
|
9804
|
+
** if( rc!=SQLITE_OK ){
|
9805
|
+
** // an error has occurred
|
9806
|
+
** }
|
9807
|
+
** </pre></blockquote>)^
|
9808
|
+
**
|
9809
|
+
** ^On success, the sqlite3_vtab_in_first(X,P) and sqlite3_vtab_in_next(X,P)
|
9810
|
+
** routines return SQLITE_OK and set *P to point to the first or next value
|
9811
|
+
** on the RHS of the IN constraint. ^If there are no more values on the
|
9812
|
+
** right hand side of the IN constraint, then *P is set to NULL and these
|
9813
|
+
** routines return [SQLITE_DONE]. ^The return value might be
|
9814
|
+
** some other value, such as SQLITE_NOMEM, in the event of a malfunction.
|
9815
|
+
**
|
9816
|
+
** The *ppOut values returned by these routines are only valid until the
|
9817
|
+
** next call to either of these routines or until the end of the xFilter
|
9818
|
+
** method from which these routines were called. If the virtual table
|
9819
|
+
** implementation needs to retain the *ppOut values for longer, it must make
|
9820
|
+
** copies. The *ppOut values are [protected sqlite3_value|protected].
|
9821
|
+
*/
|
9822
|
+
SQLITE_API int sqlite3_vtab_in_first(sqlite3_value *pVal, sqlite3_value **ppOut);
|
9823
|
+
SQLITE_API int sqlite3_vtab_in_next(sqlite3_value *pVal, sqlite3_value **ppOut);
|
9824
|
+
|
9825
|
+
/*
|
9826
|
+
** CAPI3REF: Constraint values in xBestIndex()
|
9827
|
+
** METHOD: sqlite3_index_info
|
9828
|
+
**
|
9829
|
+
** This API may only be used from within the [xBestIndex|xBestIndex method]
|
9830
|
+
** of a [virtual table] implementation. The result of calling this interface
|
9831
|
+
** from outside of an xBestIndex method are undefined and probably harmful.
|
9832
|
+
**
|
9833
|
+
** ^When the sqlite3_vtab_rhs_value(P,J,V) interface is invoked from within
|
9834
|
+
** the [xBestIndex] method of a [virtual table] implementation, with P being
|
9835
|
+
** a copy of the [sqlite3_index_info] object pointer passed into xBestIndex and
|
9836
|
+
** J being a 0-based index into P->aConstraint[], then this routine
|
9837
|
+
** attempts to set *V to the value of the right-hand operand of
|
9838
|
+
** that constraint if the right-hand operand is known. ^If the
|
9839
|
+
** right-hand operand is not known, then *V is set to a NULL pointer.
|
9840
|
+
** ^The sqlite3_vtab_rhs_value(P,J,V) interface returns SQLITE_OK if
|
9841
|
+
** and only if *V is set to a value. ^The sqlite3_vtab_rhs_value(P,J,V)
|
9842
|
+
** inteface returns SQLITE_NOTFOUND if the right-hand side of the J-th
|
9843
|
+
** constraint is not available. ^The sqlite3_vtab_rhs_value() interface
|
9844
|
+
** can return an result code other than SQLITE_OK or SQLITE_NOTFOUND if
|
9845
|
+
** something goes wrong.
|
9846
|
+
**
|
9847
|
+
** The sqlite3_vtab_rhs_value() interface is usually only successful if
|
9848
|
+
** the right-hand operand of a constraint is a literal value in the original
|
9849
|
+
** SQL statement. If the right-hand operand is an expression or a reference
|
9850
|
+
** to some other column or a [host parameter], then sqlite3_vtab_rhs_value()
|
9851
|
+
** will probably return [SQLITE_NOTFOUND].
|
9852
|
+
**
|
9853
|
+
** ^(Some constraints, such as [SQLITE_INDEX_CONSTRAINT_ISNULL] and
|
9854
|
+
** [SQLITE_INDEX_CONSTRAINT_ISNOTNULL], have no right-hand operand. For such
|
9855
|
+
** constraints, sqlite3_vtab_rhs_value() always returns SQLITE_NOTFOUND.)^
|
9856
|
+
**
|
9857
|
+
** ^The [sqlite3_value] object returned in *V is a protected sqlite3_value
|
9858
|
+
** and remains valid for the duration of the xBestIndex method call.
|
9859
|
+
** ^When xBestIndex returns, the sqlite3_value object returned by
|
9860
|
+
** sqlite3_vtab_rhs_value() is automatically deallocated.
|
9861
|
+
**
|
9862
|
+
** The "_rhs_" in the name of this routine is an abbreviation for
|
9863
|
+
** "Right-Hand Side".
|
9864
|
+
*/
|
9865
|
+
SQLITE_API int sqlite3_vtab_rhs_value(sqlite3_index_info*, int, sqlite3_value **ppVal);
|
9866
|
+
|
9285
9867
|
/*
|
9286
9868
|
** CAPI3REF: Conflict resolution modes
|
9287
9869
|
** KEYWORDS: {conflict resolution mode}
|
@@ -9517,6 +10099,15 @@ SQLITE_API int sqlite3_db_cacheflush(sqlite3*);
|
|
9517
10099
|
** triggers; or 2 for changes resulting from triggers called by top-level
|
9518
10100
|
** triggers; and so forth.
|
9519
10101
|
**
|
10102
|
+
** When the [sqlite3_blob_write()] API is used to update a blob column,
|
10103
|
+
** the pre-update hook is invoked with SQLITE_DELETE. This is because the
|
10104
|
+
** in this case the new values are not available. In this case, when a
|
10105
|
+
** callback made with op==SQLITE_DELETE is actuall a write using the
|
10106
|
+
** sqlite3_blob_write() API, the [sqlite3_preupdate_blobwrite()] returns
|
10107
|
+
** the index of the column being written. In other cases, where the
|
10108
|
+
** pre-update hook is being invoked for some other reason, including a
|
10109
|
+
** regular DELETE, sqlite3_preupdate_blobwrite() returns -1.
|
10110
|
+
**
|
9520
10111
|
** See also: [sqlite3_update_hook()]
|
9521
10112
|
*/
|
9522
10113
|
#if defined(SQLITE_ENABLE_PREUPDATE_HOOK)
|
@@ -9537,6 +10128,7 @@ SQLITE_API int sqlite3_preupdate_old(sqlite3 *, int, sqlite3_value **);
|
|
9537
10128
|
SQLITE_API int sqlite3_preupdate_count(sqlite3 *);
|
9538
10129
|
SQLITE_API int sqlite3_preupdate_depth(sqlite3 *);
|
9539
10130
|
SQLITE_API int sqlite3_preupdate_new(sqlite3 *, int, sqlite3_value **);
|
10131
|
+
SQLITE_API int sqlite3_preupdate_blobwrite(sqlite3 *);
|
9540
10132
|
#endif
|
9541
10133
|
|
9542
10134
|
/*
|
@@ -9775,8 +10367,8 @@ SQLITE_API SQLITE_EXPERIMENTAL int sqlite3_snapshot_recover(sqlite3 *db, const c
|
|
9775
10367
|
** SQLITE_SERIALIZE_NOCOPY bit is omitted from argument F if a memory
|
9776
10368
|
** allocation error occurs.
|
9777
10369
|
**
|
9778
|
-
** This interface is
|
9779
|
-
** [
|
10370
|
+
** This interface is omitted if SQLite is compiled with the
|
10371
|
+
** [SQLITE_OMIT_DESERIALIZE] option.
|
9780
10372
|
*/
|
9781
10373
|
SQLITE_API unsigned char *sqlite3_serialize(
|
9782
10374
|
sqlite3 *db, /* The database connection */
|
@@ -9823,12 +10415,16 @@ SQLITE_API unsigned char *sqlite3_serialize(
|
|
9823
10415
|
** database is currently in a read transaction or is involved in a backup
|
9824
10416
|
** operation.
|
9825
10417
|
**
|
10418
|
+
** It is not possible to deserialized into the TEMP database. If the
|
10419
|
+
** S argument to sqlite3_deserialize(D,S,P,N,M,F) is "temp" then the
|
10420
|
+
** function returns SQLITE_ERROR.
|
10421
|
+
**
|
9826
10422
|
** If sqlite3_deserialize(D,S,P,N,M,F) fails for any reason and if the
|
9827
10423
|
** SQLITE_DESERIALIZE_FREEONCLOSE bit is set in argument F, then
|
9828
10424
|
** [sqlite3_free()] is invoked on argument P prior to returning.
|
9829
10425
|
**
|
9830
|
-
** This interface is
|
9831
|
-
** [
|
10426
|
+
** This interface is omitted if SQLite is compiled with the
|
10427
|
+
** [SQLITE_OMIT_DESERIALIZE] option.
|
9832
10428
|
*/
|
9833
10429
|
SQLITE_API int sqlite3_deserialize(
|
9834
10430
|
sqlite3 *db, /* The database connection */
|
@@ -10077,6 +10673,38 @@ SQLITE_API int sqlite3session_create(
|
|
10077
10673
|
*/
|
10078
10674
|
SQLITE_API void sqlite3session_delete(sqlite3_session *pSession);
|
10079
10675
|
|
10676
|
+
/*
|
10677
|
+
** CAPIREF: Conigure a Session Object
|
10678
|
+
** METHOD: sqlite3_session
|
10679
|
+
**
|
10680
|
+
** This method is used to configure a session object after it has been
|
10681
|
+
** created. At present the only valid value for the second parameter is
|
10682
|
+
** [SQLITE_SESSION_OBJCONFIG_SIZE].
|
10683
|
+
**
|
10684
|
+
** Arguments for sqlite3session_object_config()
|
10685
|
+
**
|
10686
|
+
** The following values may passed as the the 4th parameter to
|
10687
|
+
** sqlite3session_object_config().
|
10688
|
+
**
|
10689
|
+
** <dt>SQLITE_SESSION_OBJCONFIG_SIZE <dd>
|
10690
|
+
** This option is used to set, clear or query the flag that enables
|
10691
|
+
** the [sqlite3session_changeset_size()] API. Because it imposes some
|
10692
|
+
** computational overhead, this API is disabled by default. Argument
|
10693
|
+
** pArg must point to a value of type (int). If the value is initially
|
10694
|
+
** 0, then the sqlite3session_changeset_size() API is disabled. If it
|
10695
|
+
** is greater than 0, then the same API is enabled. Or, if the initial
|
10696
|
+
** value is less than zero, no change is made. In all cases the (int)
|
10697
|
+
** variable is set to 1 if the sqlite3session_changeset_size() API is
|
10698
|
+
** enabled following the current call, or 0 otherwise.
|
10699
|
+
**
|
10700
|
+
** It is an error (SQLITE_MISUSE) to attempt to modify this setting after
|
10701
|
+
** the first table has been attached to the session object.
|
10702
|
+
*/
|
10703
|
+
SQLITE_API int sqlite3session_object_config(sqlite3_session*, int op, void *pArg);
|
10704
|
+
|
10705
|
+
/*
|
10706
|
+
*/
|
10707
|
+
#define SQLITE_SESSION_OBJCONFIG_SIZE 1
|
10080
10708
|
|
10081
10709
|
/*
|
10082
10710
|
** CAPI3REF: Enable Or Disable A Session Object
|
@@ -10321,6 +10949,22 @@ SQLITE_API int sqlite3session_changeset(
|
|
10321
10949
|
void **ppChangeset /* OUT: Buffer containing changeset */
|
10322
10950
|
);
|
10323
10951
|
|
10952
|
+
/*
|
10953
|
+
** CAPI3REF: Return An Upper-limit For The Size Of The Changeset
|
10954
|
+
** METHOD: sqlite3_session
|
10955
|
+
**
|
10956
|
+
** By default, this function always returns 0. For it to return
|
10957
|
+
** a useful result, the sqlite3_session object must have been configured
|
10958
|
+
** to enable this API using sqlite3session_object_config() with the
|
10959
|
+
** SQLITE_SESSION_OBJCONFIG_SIZE verb.
|
10960
|
+
**
|
10961
|
+
** When enabled, this function returns an upper limit, in bytes, for the size
|
10962
|
+
** of the changeset that might be produced if sqlite3session_changeset() were
|
10963
|
+
** called. The final changeset size might be equal to or smaller than the
|
10964
|
+
** size in bytes returned by this function.
|
10965
|
+
*/
|
10966
|
+
SQLITE_API sqlite3_int64 sqlite3session_changeset_size(sqlite3_session *pSession);
|
10967
|
+
|
10324
10968
|
/*
|
10325
10969
|
** CAPI3REF: Load The Difference Between Tables Into A Session
|
10326
10970
|
** METHOD: sqlite3_session
|
@@ -10438,6 +11082,14 @@ SQLITE_API int sqlite3session_patchset(
|
|
10438
11082
|
*/
|
10439
11083
|
SQLITE_API int sqlite3session_isempty(sqlite3_session *pSession);
|
10440
11084
|
|
11085
|
+
/*
|
11086
|
+
** CAPI3REF: Query for the amount of heap memory used by a session object.
|
11087
|
+
**
|
11088
|
+
** This API returns the total amount of heap memory in bytes currently
|
11089
|
+
** used by the session object passed as the only argument.
|
11090
|
+
*/
|
11091
|
+
SQLITE_API sqlite3_int64 sqlite3session_memory_used(sqlite3_session *pSession);
|
11092
|
+
|
10441
11093
|
/*
|
10442
11094
|
** CAPI3REF: Create An Iterator To Traverse A Changeset
|
10443
11095
|
** CONSTRUCTOR: sqlite3_changeset_iter
|
@@ -10540,18 +11192,23 @@ SQLITE_API int sqlite3changeset_next(sqlite3_changeset_iter *pIter);
|
|
10540
11192
|
** call to [sqlite3changeset_next()] must have returned [SQLITE_ROW]. If this
|
10541
11193
|
** is not the case, this function returns [SQLITE_MISUSE].
|
10542
11194
|
**
|
10543
|
-
**
|
10544
|
-
**
|
10545
|
-
**
|
10546
|
-
**
|
10547
|
-
**
|
10548
|
-
**
|
10549
|
-
**
|
11195
|
+
** Arguments pOp, pnCol and pzTab may not be NULL. Upon return, three
|
11196
|
+
** outputs are set through these pointers:
|
11197
|
+
**
|
11198
|
+
** *pOp is set to one of [SQLITE_INSERT], [SQLITE_DELETE] or [SQLITE_UPDATE],
|
11199
|
+
** depending on the type of change that the iterator currently points to;
|
11200
|
+
**
|
11201
|
+
** *pnCol is set to the number of columns in the table affected by the change; and
|
11202
|
+
**
|
11203
|
+
** *pzTab is set to point to a nul-terminated utf-8 encoded string containing
|
11204
|
+
** the name of the table affected by the current change. The buffer remains
|
11205
|
+
** valid until either sqlite3changeset_next() is called on the iterator
|
11206
|
+
** or until the conflict-handler function returns.
|
11207
|
+
**
|
11208
|
+
** If pbIndirect is not NULL, then *pbIndirect is set to true (1) if the change
|
10550
11209
|
** is an indirect change, or false (0) otherwise. See the documentation for
|
10551
11210
|
** [sqlite3session_indirect()] for a description of direct and indirect
|
10552
|
-
** changes.
|
10553
|
-
** [SQLITE_INSERT], [SQLITE_DELETE] or [SQLITE_UPDATE], depending on the
|
10554
|
-
** type of change that the iterator currently points to.
|
11211
|
+
** changes.
|
10555
11212
|
**
|
10556
11213
|
** If no error occurs, SQLITE_OK is returned. If an error does occur, an
|
10557
11214
|
** SQLite error code is returned. The values of the output variables may not
|