amalgalite 1.5.0-x86-mingw32 → 1.6.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 +2 -0
- data/README.md +1 -1
- data/Rakefile +5 -5
- data/ext/amalgalite/c/amalgalite.c +26 -0
- data/ext/amalgalite/c/amalgalite_constants.c +887 -39
- data/ext/amalgalite/c/extconf.rb +5 -1
- data/ext/amalgalite/c/gen_constants.rb +290 -153
- data/ext/amalgalite/c/sqlite3.c +39928 -18827
- data/ext/amalgalite/c/sqlite3.h +2739 -455
- data/ext/amalgalite/c/sqlite3ext.h +54 -10
- data/lib/amalgalite/2.0/amalgalite.so +0 -0
- data/lib/amalgalite/2.1/amalgalite.so +0 -0
- data/lib/amalgalite/2.2/amalgalite.so +0 -0
- data/lib/amalgalite/2.3/amalgalite.so +0 -0
- data/lib/amalgalite/2.4/amalgalite.so +0 -0
- data/lib/amalgalite/type_maps/default_map.rb +1 -1
- data/lib/amalgalite/type_maps/storage_map.rb +1 -1
- data/lib/amalgalite/version.rb +1 -1
- data/spec/default_map_spec.rb +1 -1
- data/spec/integeration_spec.rb +2 -2
- data/spec/sqlite3/version_spec.rb +15 -9
- data/spec/storage_map_spec.rb +1 -1
- data/tasks/default.rake +3 -10
- data/tasks/extension.rake +4 -4
- data/tasks/this.rb +3 -1
- metadata +19 -16
- data/lib/amalgalite/1.8/amalgalite.so +0 -0
- data/lib/amalgalite/1.9/amalgalite.so +0 -0
data/ext/amalgalite/c/sqlite3.h
CHANGED
@@ -1,5 +1,5 @@
|
|
1
1
|
/*
|
2
|
-
** 2001
|
2
|
+
** 2001-09-15
|
3
3
|
**
|
4
4
|
** The author disclaims copyright to this source code. In place of
|
5
5
|
** a legal notice, here is a blessing:
|
@@ -30,8 +30,8 @@
|
|
30
30
|
** the version number) and changes its name to "sqlite3.h" as
|
31
31
|
** part of the build process.
|
32
32
|
*/
|
33
|
-
#ifndef
|
34
|
-
#define
|
33
|
+
#ifndef SQLITE3_H
|
34
|
+
#define SQLITE3_H
|
35
35
|
#include <stdarg.h> /* Needed for the definition of va_list */
|
36
36
|
|
37
37
|
/*
|
@@ -54,8 +54,17 @@ extern "C" {
|
|
54
54
|
#ifndef SQLITE_CDECL
|
55
55
|
# define SQLITE_CDECL
|
56
56
|
#endif
|
57
|
+
#ifndef SQLITE_APICALL
|
58
|
+
# define SQLITE_APICALL
|
59
|
+
#endif
|
57
60
|
#ifndef SQLITE_STDCALL
|
58
|
-
# define SQLITE_STDCALL
|
61
|
+
# define SQLITE_STDCALL SQLITE_APICALL
|
62
|
+
#endif
|
63
|
+
#ifndef SQLITE_CALLBACK
|
64
|
+
# define SQLITE_CALLBACK
|
65
|
+
#endif
|
66
|
+
#ifndef SQLITE_SYSAPI
|
67
|
+
# define SQLITE_SYSAPI
|
59
68
|
#endif
|
60
69
|
|
61
70
|
/*
|
@@ -99,25 +108,28 @@ extern "C" {
|
|
99
108
|
** be held constant and Z will be incremented or else Y will be incremented
|
100
109
|
** and Z will be reset to zero.
|
101
110
|
**
|
102
|
-
** Since version 3.6.18,
|
111
|
+
** Since [version 3.6.18] ([dateof:3.6.18]),
|
112
|
+
** SQLite source code has been stored in the
|
103
113
|
** <a href="http://www.fossil-scm.org/">Fossil configuration management
|
104
114
|
** system</a>. ^The SQLITE_SOURCE_ID macro evaluates to
|
105
115
|
** a string which identifies a particular check-in of SQLite
|
106
116
|
** within its configuration management system. ^The SQLITE_SOURCE_ID
|
107
|
-
** string contains the date and time of the check-in (UTC) and
|
108
|
-
** hash of the entire source tree.
|
117
|
+
** string contains the date and time of the check-in (UTC) and a SHA1
|
118
|
+
** or SHA3-256 hash of the entire source tree. If the source code has
|
119
|
+
** been edited in any way since it was last checked in, then the last
|
120
|
+
** four hexadecimal digits of the hash may be modified.
|
109
121
|
**
|
110
122
|
** See also: [sqlite3_libversion()],
|
111
123
|
** [sqlite3_libversion_number()], [sqlite3_sourceid()],
|
112
124
|
** [sqlite_version()] and [sqlite_source_id()].
|
113
125
|
*/
|
114
|
-
#define SQLITE_VERSION "3.
|
115
|
-
#define SQLITE_VERSION_NUMBER
|
116
|
-
#define SQLITE_SOURCE_ID "
|
126
|
+
#define SQLITE_VERSION "3.21.0"
|
127
|
+
#define SQLITE_VERSION_NUMBER 3021000
|
128
|
+
#define SQLITE_SOURCE_ID "2017-10-24 18:55:49 1a584e499906b5c87ec7d43d4abce641fdf017c42125b083109bc77c4de48827"
|
117
129
|
|
118
130
|
/*
|
119
131
|
** CAPI3REF: Run-Time Library Version Numbers
|
120
|
-
** KEYWORDS: sqlite3_version
|
132
|
+
** KEYWORDS: sqlite3_version sqlite3_sourceid
|
121
133
|
**
|
122
134
|
** These interfaces provide the same information as the [SQLITE_VERSION],
|
123
135
|
** [SQLITE_VERSION_NUMBER], and [SQLITE_SOURCE_ID] C preprocessor macros
|
@@ -129,7 +141,7 @@ extern "C" {
|
|
129
141
|
**
|
130
142
|
** <blockquote><pre>
|
131
143
|
** assert( sqlite3_libversion_number()==SQLITE_VERSION_NUMBER );
|
132
|
-
** assert(
|
144
|
+
** assert( strncmp(sqlite3_sourceid(),SQLITE_SOURCE_ID,80)==0 );
|
133
145
|
** assert( strcmp(sqlite3_libversion(),SQLITE_VERSION)==0 );
|
134
146
|
** </pre></blockquote>)^
|
135
147
|
**
|
@@ -139,16 +151,18 @@ extern "C" {
|
|
139
151
|
** function is provided for use in DLLs since DLL users usually do not have
|
140
152
|
** direct access to string constants within the DLL. ^The
|
141
153
|
** sqlite3_libversion_number() function returns an integer equal to
|
142
|
-
** [SQLITE_VERSION_NUMBER]. ^The sqlite3_sourceid() function returns
|
154
|
+
** [SQLITE_VERSION_NUMBER]. ^(The sqlite3_sourceid() function returns
|
143
155
|
** a pointer to a string constant whose value is the same as the
|
144
|
-
** [SQLITE_SOURCE_ID] C preprocessor macro.
|
156
|
+
** [SQLITE_SOURCE_ID] C preprocessor macro. Except if SQLite is built
|
157
|
+
** using an edited copy of [the amalgamation], then the last four characters
|
158
|
+
** of the hash might be different from [SQLITE_SOURCE_ID].)^
|
145
159
|
**
|
146
160
|
** See also: [sqlite_version()] and [sqlite_source_id()].
|
147
161
|
*/
|
148
162
|
SQLITE_API SQLITE_EXTERN const char sqlite3_version[];
|
149
|
-
SQLITE_API const char *
|
150
|
-
SQLITE_API const char *
|
151
|
-
SQLITE_API int
|
163
|
+
SQLITE_API const char *sqlite3_libversion(void);
|
164
|
+
SQLITE_API const char *sqlite3_sourceid(void);
|
165
|
+
SQLITE_API int sqlite3_libversion_number(void);
|
152
166
|
|
153
167
|
/*
|
154
168
|
** CAPI3REF: Run-Time Library Compilation Options Diagnostics
|
@@ -173,8 +187,8 @@ SQLITE_API int SQLITE_STDCALL sqlite3_libversion_number(void);
|
|
173
187
|
** [sqlite_compileoption_get()] and the [compile_options pragma].
|
174
188
|
*/
|
175
189
|
#ifndef SQLITE_OMIT_COMPILEOPTION_DIAGS
|
176
|
-
SQLITE_API int
|
177
|
-
SQLITE_API const char *
|
190
|
+
SQLITE_API int sqlite3_compileoption_used(const char *zOptName);
|
191
|
+
SQLITE_API const char *sqlite3_compileoption_get(int N);
|
178
192
|
#endif
|
179
193
|
|
180
194
|
/*
|
@@ -213,7 +227,7 @@ SQLITE_API const char *SQLITE_STDCALL sqlite3_compileoption_get(int N);
|
|
213
227
|
**
|
214
228
|
** See the [threading mode] documentation for additional information.
|
215
229
|
*/
|
216
|
-
SQLITE_API int
|
230
|
+
SQLITE_API int sqlite3_threadsafe(void);
|
217
231
|
|
218
232
|
/*
|
219
233
|
** CAPI3REF: Database Connection Handle
|
@@ -249,7 +263,11 @@ typedef struct sqlite3 sqlite3;
|
|
249
263
|
*/
|
250
264
|
#ifdef SQLITE_INT64_TYPE
|
251
265
|
typedef SQLITE_INT64_TYPE sqlite_int64;
|
252
|
-
|
266
|
+
# ifdef SQLITE_UINT64_TYPE
|
267
|
+
typedef SQLITE_UINT64_TYPE sqlite_uint64;
|
268
|
+
# else
|
269
|
+
typedef unsigned SQLITE_INT64_TYPE sqlite_uint64;
|
270
|
+
# endif
|
253
271
|
#elif defined(_MSC_VER) || defined(__BORLANDC__)
|
254
272
|
typedef __int64 sqlite_int64;
|
255
273
|
typedef unsigned __int64 sqlite_uint64;
|
@@ -310,8 +328,8 @@ typedef sqlite_uint64 sqlite3_uint64;
|
|
310
328
|
** ^Calling sqlite3_close() or sqlite3_close_v2() with a NULL pointer
|
311
329
|
** argument is a harmless no-op.
|
312
330
|
*/
|
313
|
-
SQLITE_API int
|
314
|
-
SQLITE_API int
|
331
|
+
SQLITE_API int sqlite3_close(sqlite3*);
|
332
|
+
SQLITE_API int sqlite3_close_v2(sqlite3*);
|
315
333
|
|
316
334
|
/*
|
317
335
|
** The type for a callback function.
|
@@ -347,7 +365,7 @@ typedef int (*sqlite3_callback)(void*,int,char**, char**);
|
|
347
365
|
** from [sqlite3_malloc()] and passed back through the 5th parameter.
|
348
366
|
** To avoid memory leaks, the application should invoke [sqlite3_free()]
|
349
367
|
** on error message strings returned through the 5th parameter of
|
350
|
-
**
|
368
|
+
** sqlite3_exec() after the error message string is no longer needed.
|
351
369
|
** ^If the 5th parameter to sqlite3_exec() is not NULL and no errors
|
352
370
|
** occur, then sqlite3_exec() sets the pointer in its 5th parameter to
|
353
371
|
** NULL before returning.
|
@@ -382,7 +400,7 @@ typedef int (*sqlite3_callback)(void*,int,char**, char**);
|
|
382
400
|
** the 2nd parameter of sqlite3_exec() while sqlite3_exec() is running.
|
383
401
|
** </ul>
|
384
402
|
*/
|
385
|
-
SQLITE_API int
|
403
|
+
SQLITE_API int sqlite3_exec(
|
386
404
|
sqlite3*, /* An open database */
|
387
405
|
const char *sql, /* SQL to be evaluated */
|
388
406
|
int (*callback)(void*,int,char**,char**), /* Callback function */
|
@@ -403,7 +421,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_exec(
|
|
403
421
|
*/
|
404
422
|
#define SQLITE_OK 0 /* Successful result */
|
405
423
|
/* beginning-of-error-codes */
|
406
|
-
#define SQLITE_ERROR 1 /*
|
424
|
+
#define SQLITE_ERROR 1 /* Generic error */
|
407
425
|
#define SQLITE_INTERNAL 2 /* Internal logic error in SQLite */
|
408
426
|
#define SQLITE_PERM 3 /* Access permission denied */
|
409
427
|
#define SQLITE_ABORT 4 /* Callback routine requested an abort */
|
@@ -418,7 +436,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_exec(
|
|
418
436
|
#define SQLITE_FULL 13 /* Insertion failed because database is full */
|
419
437
|
#define SQLITE_CANTOPEN 14 /* Unable to open the database file */
|
420
438
|
#define SQLITE_PROTOCOL 15 /* Database lock protocol error */
|
421
|
-
#define SQLITE_EMPTY 16 /*
|
439
|
+
#define SQLITE_EMPTY 16 /* Internal use only */
|
422
440
|
#define SQLITE_SCHEMA 17 /* The database schema changed */
|
423
441
|
#define SQLITE_TOOBIG 18 /* String or BLOB exceeds size limit */
|
424
442
|
#define SQLITE_CONSTRAINT 19 /* Abort due to constraint violation */
|
@@ -426,7 +444,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_exec(
|
|
426
444
|
#define SQLITE_MISUSE 21 /* Library used incorrectly */
|
427
445
|
#define SQLITE_NOLFS 22 /* Uses OS features not supported on host */
|
428
446
|
#define SQLITE_AUTH 23 /* Authorization denied */
|
429
|
-
#define SQLITE_FORMAT 24 /*
|
447
|
+
#define SQLITE_FORMAT 24 /* Not used */
|
430
448
|
#define SQLITE_RANGE 25 /* 2nd parameter to sqlite3_bind out of range */
|
431
449
|
#define SQLITE_NOTADB 26 /* File opened that is not a database file */
|
432
450
|
#define SQLITE_NOTICE 27 /* Notifications from sqlite3_log() */
|
@@ -443,7 +461,8 @@ SQLITE_API int SQLITE_STDCALL sqlite3_exec(
|
|
443
461
|
** [result codes]. However, experience has shown that many of
|
444
462
|
** these result codes are too coarse-grained. They do not provide as
|
445
463
|
** much information about problems as programmers might like. In an effort to
|
446
|
-
** address this, newer versions of SQLite (version 3.3.8
|
464
|
+
** address this, newer versions of SQLite (version 3.3.8 [dateof:3.3.8]
|
465
|
+
** and later) include
|
447
466
|
** support for additional result codes that provide more detailed information
|
448
467
|
** about errors. These [extended result codes] are enabled or disabled
|
449
468
|
** on a per database connection basis using the
|
@@ -478,6 +497,10 @@ SQLITE_API int SQLITE_STDCALL sqlite3_exec(
|
|
478
497
|
#define SQLITE_IOERR_GETTEMPPATH (SQLITE_IOERR | (25<<8))
|
479
498
|
#define SQLITE_IOERR_CONVPATH (SQLITE_IOERR | (26<<8))
|
480
499
|
#define SQLITE_IOERR_VNODE (SQLITE_IOERR | (27<<8))
|
500
|
+
#define SQLITE_IOERR_AUTH (SQLITE_IOERR | (28<<8))
|
501
|
+
#define SQLITE_IOERR_BEGIN_ATOMIC (SQLITE_IOERR | (29<<8))
|
502
|
+
#define SQLITE_IOERR_COMMIT_ATOMIC (SQLITE_IOERR | (30<<8))
|
503
|
+
#define SQLITE_IOERR_ROLLBACK_ATOMIC (SQLITE_IOERR | (31<<8))
|
481
504
|
#define SQLITE_LOCKED_SHAREDCACHE (SQLITE_LOCKED | (1<<8))
|
482
505
|
#define SQLITE_BUSY_RECOVERY (SQLITE_BUSY | (1<<8))
|
483
506
|
#define SQLITE_BUSY_SNAPSHOT (SQLITE_BUSY | (2<<8))
|
@@ -505,6 +528,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_exec(
|
|
505
528
|
#define SQLITE_NOTICE_RECOVER_ROLLBACK (SQLITE_NOTICE | (2<<8))
|
506
529
|
#define SQLITE_WARNING_AUTOINDEX (SQLITE_WARNING | (1<<8))
|
507
530
|
#define SQLITE_AUTH_USER (SQLITE_AUTH | (1<<8))
|
531
|
+
#define SQLITE_OK_LOAD_PERMANENTLY (SQLITE_OK | (1<<8))
|
508
532
|
|
509
533
|
/*
|
510
534
|
** CAPI3REF: Flags For File Open Operations
|
@@ -559,10 +583,15 @@ SQLITE_API int SQLITE_STDCALL sqlite3_exec(
|
|
559
583
|
** file that were written at the application level might have changed
|
560
584
|
** and that adjacent bytes, even bytes within the same sector are
|
561
585
|
** guaranteed to be unchanged. The SQLITE_IOCAP_UNDELETABLE_WHEN_OPEN
|
562
|
-
** flag
|
586
|
+
** flag indicates that a file cannot be deleted when open. The
|
563
587
|
** SQLITE_IOCAP_IMMUTABLE flag indicates that the file is on
|
564
588
|
** read-only media and cannot be changed even by processes with
|
565
589
|
** elevated privileges.
|
590
|
+
**
|
591
|
+
** The SQLITE_IOCAP_BATCH_ATOMIC property means that the underlying
|
592
|
+
** filesystem supports doing multiple write operations atomically when those
|
593
|
+
** write operations are bracketed by [SQLITE_FCNTL_BEGIN_ATOMIC_WRITE] and
|
594
|
+
** [SQLITE_FCNTL_COMMIT_ATOMIC_WRITE].
|
566
595
|
*/
|
567
596
|
#define SQLITE_IOCAP_ATOMIC 0x00000001
|
568
597
|
#define SQLITE_IOCAP_ATOMIC512 0x00000002
|
@@ -578,6 +607,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_exec(
|
|
578
607
|
#define SQLITE_IOCAP_UNDELETABLE_WHEN_OPEN 0x00000800
|
579
608
|
#define SQLITE_IOCAP_POWERSAFE_OVERWRITE 0x00001000
|
580
609
|
#define SQLITE_IOCAP_IMMUTABLE 0x00002000
|
610
|
+
#define SQLITE_IOCAP_BATCH_ATOMIC 0x00004000
|
581
611
|
|
582
612
|
/*
|
583
613
|
** CAPI3REF: File Locking Levels
|
@@ -709,6 +739,10 @@ struct sqlite3_file {
|
|
709
739
|
** <li> [SQLITE_IOCAP_ATOMIC64K]
|
710
740
|
** <li> [SQLITE_IOCAP_SAFE_APPEND]
|
711
741
|
** <li> [SQLITE_IOCAP_SEQUENTIAL]
|
742
|
+
** <li> [SQLITE_IOCAP_UNDELETABLE_WHEN_OPEN]
|
743
|
+
** <li> [SQLITE_IOCAP_POWERSAFE_OVERWRITE]
|
744
|
+
** <li> [SQLITE_IOCAP_IMMUTABLE]
|
745
|
+
** <li> [SQLITE_IOCAP_BATCH_ATOMIC]
|
712
746
|
** </ul>
|
713
747
|
**
|
714
748
|
** The SQLITE_IOCAP_ATOMIC property means that all writes of
|
@@ -793,8 +827,13 @@ struct sqlite3_io_methods {
|
|
793
827
|
** <li>[[SQLITE_FCNTL_FILE_POINTER]]
|
794
828
|
** The [SQLITE_FCNTL_FILE_POINTER] opcode is used to obtain a pointer
|
795
829
|
** to the [sqlite3_file] object associated with a particular database
|
796
|
-
** connection. See
|
797
|
-
**
|
830
|
+
** connection. See also [SQLITE_FCNTL_JOURNAL_POINTER].
|
831
|
+
**
|
832
|
+
** <li>[[SQLITE_FCNTL_JOURNAL_POINTER]]
|
833
|
+
** The [SQLITE_FCNTL_JOURNAL_POINTER] opcode is used to obtain a pointer
|
834
|
+
** to the [sqlite3_file] object associated with the journal file (either
|
835
|
+
** the [rollback journal] or the [write-ahead log]) for a particular database
|
836
|
+
** connection. See also [SQLITE_FCNTL_FILE_POINTER].
|
798
837
|
**
|
799
838
|
** <li>[[SQLITE_FCNTL_SYNC_OMITTED]]
|
800
839
|
** No longer in use.
|
@@ -832,7 +871,7 @@ struct sqlite3_io_methods {
|
|
832
871
|
** opcode allows these two values (10 retries and 25 milliseconds of delay)
|
833
872
|
** to be adjusted. The values are changed for all database connections
|
834
873
|
** within the same process. The argument is a pointer to an array of two
|
835
|
-
** integers where the first integer
|
874
|
+
** integers where the first integer is the new retry count and the second
|
836
875
|
** integer is the delay. If either integer is negative, then the setting
|
837
876
|
** is not changed but instead the prior value of that setting is written
|
838
877
|
** into the array entry, allowing the current retry settings to be
|
@@ -881,6 +920,15 @@ struct sqlite3_io_methods {
|
|
881
920
|
** pointer in case this file-control is not implemented. This file-control
|
882
921
|
** is intended for diagnostic use only.
|
883
922
|
**
|
923
|
+
** <li>[[SQLITE_FCNTL_VFS_POINTER]]
|
924
|
+
** ^The [SQLITE_FCNTL_VFS_POINTER] opcode finds a pointer to the top-level
|
925
|
+
** [VFSes] currently in use. ^(The argument X in
|
926
|
+
** sqlite3_file_control(db,SQLITE_FCNTL_VFS_POINTER,X) must be
|
927
|
+
** of type "[sqlite3_vfs] **". This opcodes will set *X
|
928
|
+
** to a pointer to the top-level VFS.)^
|
929
|
+
** ^When there are multiple VFS shims in the stack, this opcode finds the
|
930
|
+
** upper-most shim only.
|
931
|
+
**
|
884
932
|
** <li>[[SQLITE_FCNTL_PRAGMA]]
|
885
933
|
** ^Whenever a [PRAGMA] statement is parsed, an [SQLITE_FCNTL_PRAGMA]
|
886
934
|
** file control is sent to the open [sqlite3_file] object corresponding
|
@@ -951,6 +999,12 @@ struct sqlite3_io_methods {
|
|
951
999
|
** on whether or not the file has been renamed, moved, or deleted since it
|
952
1000
|
** was first opened.
|
953
1001
|
**
|
1002
|
+
** <li>[[SQLITE_FCNTL_WIN32_GET_HANDLE]]
|
1003
|
+
** The [SQLITE_FCNTL_WIN32_GET_HANDLE] opcode can be used to obtain the
|
1004
|
+
** underlying native file handle associated with a file handle. This file
|
1005
|
+
** control interprets its argument as a pointer to a native file handle and
|
1006
|
+
** writes the resulting value there.
|
1007
|
+
**
|
954
1008
|
** <li>[[SQLITE_FCNTL_WIN32_SET_HANDLE]]
|
955
1009
|
** The [SQLITE_FCNTL_WIN32_SET_HANDLE] opcode is used for debugging. This
|
956
1010
|
** opcode causes the xFileControl method to swap the file handle with the one
|
@@ -972,6 +1026,40 @@ struct sqlite3_io_methods {
|
|
972
1026
|
** The [SQLITE_FCNTL_RBU] opcode is implemented by the special VFS used by
|
973
1027
|
** the RBU extension only. All other VFS should return SQLITE_NOTFOUND for
|
974
1028
|
** this opcode.
|
1029
|
+
**
|
1030
|
+
** <li>[[SQLITE_FCNTL_BEGIN_ATOMIC_WRITE]]
|
1031
|
+
** If the [SQLITE_FCNTL_BEGIN_ATOMIC_WRITE] opcode returns SQLITE_OK, then
|
1032
|
+
** the file descriptor is placed in "batch write mode", which
|
1033
|
+
** means all subsequent write operations will be deferred and done
|
1034
|
+
** atomically at the next [SQLITE_FCNTL_COMMIT_ATOMIC_WRITE]. Systems
|
1035
|
+
** that do not support batch atomic writes will return SQLITE_NOTFOUND.
|
1036
|
+
** ^Following a successful SQLITE_FCNTL_BEGIN_ATOMIC_WRITE and prior to
|
1037
|
+
** the closing [SQLITE_FCNTL_COMMIT_ATOMIC_WRITE] or
|
1038
|
+
** [SQLITE_FCNTL_ROLLBACK_ATOMIC_WRITE], SQLite will make
|
1039
|
+
** no VFS interface calls on the same [sqlite3_file] file descriptor
|
1040
|
+
** except for calls to the xWrite method and the xFileControl method
|
1041
|
+
** with [SQLITE_FCNTL_SIZE_HINT].
|
1042
|
+
**
|
1043
|
+
** <li>[[SQLITE_FCNTL_COMMIT_ATOMIC_WRITE]]
|
1044
|
+
** The [SQLITE_FCNTL_COMMIT_ATOMIC_WRITE] opcode causes all write
|
1045
|
+
** operations since the previous successful call to
|
1046
|
+
** [SQLITE_FCNTL_BEGIN_ATOMIC_WRITE] to be performed atomically.
|
1047
|
+
** This file control returns [SQLITE_OK] if and only if the writes were
|
1048
|
+
** all performed successfully and have been committed to persistent storage.
|
1049
|
+
** ^Regardless of whether or not it is successful, this file control takes
|
1050
|
+
** the file descriptor out of batch write mode so that all subsequent
|
1051
|
+
** write operations are independent.
|
1052
|
+
** ^SQLite will never invoke SQLITE_FCNTL_COMMIT_ATOMIC_WRITE without
|
1053
|
+
** a prior successful call to [SQLITE_FCNTL_BEGIN_ATOMIC_WRITE].
|
1054
|
+
**
|
1055
|
+
** <li>[[SQLITE_FCNTL_ROLLBACK_ATOMIC_WRITE]]
|
1056
|
+
** The [SQLITE_FCNTL_ROLLBACK_ATOMIC_WRITE] opcode causes all write
|
1057
|
+
** operations since the previous successful call to
|
1058
|
+
** [SQLITE_FCNTL_BEGIN_ATOMIC_WRITE] to be rolled back.
|
1059
|
+
** ^This file control takes the file descriptor out of batch write mode
|
1060
|
+
** so that all subsequent write operations are independent.
|
1061
|
+
** ^SQLite will never invoke SQLITE_FCNTL_ROLLBACK_ATOMIC_WRITE without
|
1062
|
+
** a prior successful call to [SQLITE_FCNTL_BEGIN_ATOMIC_WRITE].
|
975
1063
|
** </ul>
|
976
1064
|
*/
|
977
1065
|
#define SQLITE_FCNTL_LOCKSTATE 1
|
@@ -999,6 +1087,13 @@ struct sqlite3_io_methods {
|
|
999
1087
|
#define SQLITE_FCNTL_WAL_BLOCK 24
|
1000
1088
|
#define SQLITE_FCNTL_ZIPVFS 25
|
1001
1089
|
#define SQLITE_FCNTL_RBU 26
|
1090
|
+
#define SQLITE_FCNTL_VFS_POINTER 27
|
1091
|
+
#define SQLITE_FCNTL_JOURNAL_POINTER 28
|
1092
|
+
#define SQLITE_FCNTL_WIN32_GET_HANDLE 29
|
1093
|
+
#define SQLITE_FCNTL_PDB 30
|
1094
|
+
#define SQLITE_FCNTL_BEGIN_ATOMIC_WRITE 31
|
1095
|
+
#define SQLITE_FCNTL_COMMIT_ATOMIC_WRITE 32
|
1096
|
+
#define SQLITE_FCNTL_ROLLBACK_ATOMIC_WRITE 33
|
1002
1097
|
|
1003
1098
|
/* deprecated names */
|
1004
1099
|
#define SQLITE_GET_LOCKPROXYFILE SQLITE_FCNTL_GET_LOCKPROXYFILE
|
@@ -1018,6 +1113,16 @@ struct sqlite3_io_methods {
|
|
1018
1113
|
*/
|
1019
1114
|
typedef struct sqlite3_mutex sqlite3_mutex;
|
1020
1115
|
|
1116
|
+
/*
|
1117
|
+
** CAPI3REF: Loadable Extension Thunk
|
1118
|
+
**
|
1119
|
+
** A pointer to the opaque sqlite3_api_routines structure is passed as
|
1120
|
+
** the third parameter to entry points of [loadable extensions]. This
|
1121
|
+
** structure must be typedefed in order to work around compiler warnings
|
1122
|
+
** on some platforms.
|
1123
|
+
*/
|
1124
|
+
typedef struct sqlite3_api_routines sqlite3_api_routines;
|
1125
|
+
|
1021
1126
|
/*
|
1022
1127
|
** CAPI3REF: OS Interface Object
|
1023
1128
|
**
|
@@ -1211,7 +1316,7 @@ struct sqlite3_vfs {
|
|
1211
1316
|
const char *(*xNextSystemCall)(sqlite3_vfs*, const char *zName);
|
1212
1317
|
/*
|
1213
1318
|
** The methods above are in versions 1 through 3 of the sqlite_vfs object.
|
1214
|
-
** New fields may be appended in
|
1319
|
+
** New fields may be appended in future versions. The iVersion
|
1215
1320
|
** value will increment whenever this happens.
|
1216
1321
|
*/
|
1217
1322
|
};
|
@@ -1353,10 +1458,10 @@ struct sqlite3_vfs {
|
|
1353
1458
|
** must return [SQLITE_OK] on success and some other [error code] upon
|
1354
1459
|
** failure.
|
1355
1460
|
*/
|
1356
|
-
SQLITE_API int
|
1357
|
-
SQLITE_API int
|
1358
|
-
SQLITE_API int
|
1359
|
-
SQLITE_API int
|
1461
|
+
SQLITE_API int sqlite3_initialize(void);
|
1462
|
+
SQLITE_API int sqlite3_shutdown(void);
|
1463
|
+
SQLITE_API int sqlite3_os_init(void);
|
1464
|
+
SQLITE_API int sqlite3_os_end(void);
|
1360
1465
|
|
1361
1466
|
/*
|
1362
1467
|
** CAPI3REF: Configuring The SQLite Library
|
@@ -1389,7 +1494,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_os_end(void);
|
|
1389
1494
|
** ^If the option is unknown or SQLite is unable to set the option
|
1390
1495
|
** then this routine returns a non-zero [error code].
|
1391
1496
|
*/
|
1392
|
-
SQLITE_API int
|
1497
|
+
SQLITE_API int sqlite3_config(int, ...);
|
1393
1498
|
|
1394
1499
|
/*
|
1395
1500
|
** CAPI3REF: Configure database connections
|
@@ -1408,7 +1513,7 @@ SQLITE_API int SQLITE_CDECL sqlite3_config(int, ...);
|
|
1408
1513
|
** ^Calls to sqlite3_db_config() return SQLITE_OK if and only if
|
1409
1514
|
** the call is considered successful.
|
1410
1515
|
*/
|
1411
|
-
SQLITE_API int
|
1516
|
+
SQLITE_API int sqlite3_db_config(sqlite3*, int op, ...);
|
1412
1517
|
|
1413
1518
|
/*
|
1414
1519
|
** CAPI3REF: Memory Allocation Routines
|
@@ -1559,6 +1664,16 @@ struct sqlite3_mem_methods {
|
|
1559
1664
|
** routines with a wrapper that simulations memory allocation failure or
|
1560
1665
|
** tracks memory usage, for example. </dd>
|
1561
1666
|
**
|
1667
|
+
** [[SQLITE_CONFIG_SMALL_MALLOC]] <dt>SQLITE_CONFIG_SMALL_MALLOC</dt>
|
1668
|
+
** <dd> ^The SQLITE_CONFIG_SMALL_MALLOC option takes single argument of
|
1669
|
+
** type int, interpreted as a boolean, which if true provides a hint to
|
1670
|
+
** SQLite that it should avoid large memory allocations if possible.
|
1671
|
+
** SQLite will run faster if it is free to make large memory allocations,
|
1672
|
+
** but some application might prefer to run slower in exchange for
|
1673
|
+
** guarantees about memory fragmentation that are possible if large
|
1674
|
+
** allocations are avoided. This hint is normally off.
|
1675
|
+
** </dd>
|
1676
|
+
**
|
1562
1677
|
** [[SQLITE_CONFIG_MEMSTATUS]] <dt>SQLITE_CONFIG_MEMSTATUS</dt>
|
1563
1678
|
** <dd> ^The SQLITE_CONFIG_MEMSTATUS option takes single argument of type int,
|
1564
1679
|
** interpreted as a boolean, which enables or disables the collection of
|
@@ -1576,57 +1691,43 @@ struct sqlite3_mem_methods {
|
|
1576
1691
|
** </dd>
|
1577
1692
|
**
|
1578
1693
|
** [[SQLITE_CONFIG_SCRATCH]] <dt>SQLITE_CONFIG_SCRATCH</dt>
|
1579
|
-
** <dd>
|
1580
|
-
** that SQLite can use for scratch memory. ^(There are three arguments
|
1581
|
-
** to SQLITE_CONFIG_SCRATCH: A pointer an 8-byte
|
1582
|
-
** aligned memory buffer from which the scratch allocations will be
|
1583
|
-
** drawn, the size of each scratch allocation (sz),
|
1584
|
-
** and the maximum number of scratch allocations (N).)^
|
1585
|
-
** The first argument must be a pointer to an 8-byte aligned buffer
|
1586
|
-
** of at least sz*N bytes of memory.
|
1587
|
-
** ^SQLite will not use more than one scratch buffers per thread.
|
1588
|
-
** ^SQLite will never request a scratch buffer that is more than 6
|
1589
|
-
** times the database page size.
|
1590
|
-
** ^If SQLite needs needs additional
|
1591
|
-
** scratch memory beyond what is provided by this configuration option, then
|
1592
|
-
** [sqlite3_malloc()] will be used to obtain the memory needed.<p>
|
1593
|
-
** ^When the application provides any amount of scratch memory using
|
1594
|
-
** SQLITE_CONFIG_SCRATCH, SQLite avoids unnecessary large
|
1595
|
-
** [sqlite3_malloc|heap allocations].
|
1596
|
-
** This can help [Robson proof|prevent memory allocation failures] due to heap
|
1597
|
-
** fragmentation in low-memory embedded systems.
|
1694
|
+
** <dd> The SQLITE_CONFIG_SCRATCH option is no longer used.
|
1598
1695
|
** </dd>
|
1599
1696
|
**
|
1600
1697
|
** [[SQLITE_CONFIG_PAGECACHE]] <dt>SQLITE_CONFIG_PAGECACHE</dt>
|
1601
|
-
** <dd> ^The SQLITE_CONFIG_PAGECACHE option specifies a
|
1698
|
+
** <dd> ^The SQLITE_CONFIG_PAGECACHE option specifies a memory pool
|
1602
1699
|
** that SQLite can use for the database page cache with the default page
|
1603
1700
|
** cache implementation.
|
1604
|
-
** This configuration
|
1605
|
-
** cache implementation is loaded using the [SQLITE_CONFIG_PCACHE2]
|
1606
|
-
** configuration option.
|
1701
|
+
** This configuration option is a no-op if an application-define page
|
1702
|
+
** cache implementation is loaded using the [SQLITE_CONFIG_PCACHE2].
|
1607
1703
|
** ^There are three arguments to SQLITE_CONFIG_PAGECACHE: A pointer to
|
1608
|
-
** 8-byte aligned
|
1609
|
-
**
|
1704
|
+
** 8-byte aligned memory (pMem), the size of each page cache line (sz),
|
1705
|
+
** and the number of cache lines (N).
|
1610
1706
|
** The sz argument should be the size of the largest database page
|
1611
1707
|
** (a power of two between 512 and 65536) plus some extra bytes for each
|
1612
1708
|
** page header. ^The number of extra bytes needed by the page header
|
1613
|
-
** can be determined using
|
1614
|
-
** to [sqlite3_config()].
|
1709
|
+
** can be determined using [SQLITE_CONFIG_PCACHE_HDRSZ].
|
1615
1710
|
** ^It is harmless, apart from the wasted memory,
|
1616
|
-
** for the sz parameter to be larger than necessary. The
|
1617
|
-
** argument
|
1618
|
-
**
|
1619
|
-
** undefined.
|
1620
|
-
** ^
|
1621
|
-
**
|
1622
|
-
** page cache
|
1623
|
-
**
|
1711
|
+
** for the sz parameter to be larger than necessary. The pMem
|
1712
|
+
** argument must be either a NULL pointer or a pointer to an 8-byte
|
1713
|
+
** aligned block of memory of at least sz*N bytes, otherwise
|
1714
|
+
** subsequent behavior is undefined.
|
1715
|
+
** ^When pMem is not NULL, SQLite will strive to use the memory provided
|
1716
|
+
** to satisfy page cache needs, falling back to [sqlite3_malloc()] if
|
1717
|
+
** a page cache line is larger than sz bytes or if all of the pMem buffer
|
1718
|
+
** is exhausted.
|
1719
|
+
** ^If pMem is NULL and N is non-zero, then each database connection
|
1720
|
+
** does an initial bulk allocation for page cache memory
|
1721
|
+
** from [sqlite3_malloc()] sufficient for N cache lines if N is positive or
|
1722
|
+
** of -1024*N bytes if N is negative, . ^If additional
|
1723
|
+
** page cache memory is needed beyond what is provided by the initial
|
1724
|
+
** allocation, then SQLite goes to [sqlite3_malloc()] separately for each
|
1725
|
+
** additional cache line. </dd>
|
1624
1726
|
**
|
1625
1727
|
** [[SQLITE_CONFIG_HEAP]] <dt>SQLITE_CONFIG_HEAP</dt>
|
1626
1728
|
** <dd> ^The SQLITE_CONFIG_HEAP option specifies a static memory buffer
|
1627
1729
|
** that SQLite will use for all of its dynamic memory allocation needs
|
1628
|
-
** beyond those provided for by [
|
1629
|
-
** [SQLITE_CONFIG_PAGECACHE].
|
1730
|
+
** beyond those provided for by [SQLITE_CONFIG_PAGECACHE].
|
1630
1731
|
** ^The SQLITE_CONFIG_HEAP option is only available if SQLite is compiled
|
1631
1732
|
** with either [SQLITE_ENABLE_MEMSYS3] or [SQLITE_ENABLE_MEMSYS5] and returns
|
1632
1733
|
** [SQLITE_ERROR] if invoked otherwise.
|
@@ -1798,6 +1899,20 @@ struct sqlite3_mem_methods {
|
|
1798
1899
|
** is enabled (using the [PRAGMA threads] command) and the amount of content
|
1799
1900
|
** to be sorted exceeds the page size times the minimum of the
|
1800
1901
|
** [PRAGMA cache_size] setting and this value.
|
1902
|
+
**
|
1903
|
+
** [[SQLITE_CONFIG_STMTJRNL_SPILL]]
|
1904
|
+
** <dt>SQLITE_CONFIG_STMTJRNL_SPILL
|
1905
|
+
** <dd>^The SQLITE_CONFIG_STMTJRNL_SPILL option takes a single parameter which
|
1906
|
+
** becomes the [statement journal] spill-to-disk threshold.
|
1907
|
+
** [Statement journals] are held in memory until their size (in bytes)
|
1908
|
+
** exceeds this threshold, at which point they are written to disk.
|
1909
|
+
** Or if the threshold is -1, statement journals are always held
|
1910
|
+
** exclusively in memory.
|
1911
|
+
** Since many statement journals never become large, setting the spill
|
1912
|
+
** threshold to a value such as 64KiB can greatly reduce the amount of
|
1913
|
+
** I/O required to support statement rollback.
|
1914
|
+
** The default value for this setting is controlled by the
|
1915
|
+
** [SQLITE_STMTJRNL_SPILL] compile-time option.
|
1801
1916
|
** </dl>
|
1802
1917
|
*/
|
1803
1918
|
#define SQLITE_CONFIG_SINGLETHREAD 1 /* nil */
|
@@ -1805,7 +1920,7 @@ struct sqlite3_mem_methods {
|
|
1805
1920
|
#define SQLITE_CONFIG_SERIALIZED 3 /* nil */
|
1806
1921
|
#define SQLITE_CONFIG_MALLOC 4 /* sqlite3_mem_methods* */
|
1807
1922
|
#define SQLITE_CONFIG_GETMALLOC 5 /* sqlite3_mem_methods* */
|
1808
|
-
#define SQLITE_CONFIG_SCRATCH 6 /*
|
1923
|
+
#define SQLITE_CONFIG_SCRATCH 6 /* No longer used */
|
1809
1924
|
#define SQLITE_CONFIG_PAGECACHE 7 /* void*, int sz, int N */
|
1810
1925
|
#define SQLITE_CONFIG_HEAP 8 /* void*, int nByte, int min */
|
1811
1926
|
#define SQLITE_CONFIG_MEMSTATUS 9 /* boolean */
|
@@ -1825,6 +1940,8 @@ struct sqlite3_mem_methods {
|
|
1825
1940
|
#define SQLITE_CONFIG_WIN32_HEAPSIZE 23 /* int nByte */
|
1826
1941
|
#define SQLITE_CONFIG_PCACHE_HDRSZ 24 /* int *psz */
|
1827
1942
|
#define SQLITE_CONFIG_PMASZ 25 /* unsigned int szPma */
|
1943
|
+
#define SQLITE_CONFIG_STMTJRNL_SPILL 26 /* int nByte */
|
1944
|
+
#define SQLITE_CONFIG_SMALL_MALLOC 27 /* boolean */
|
1828
1945
|
|
1829
1946
|
/*
|
1830
1947
|
** CAPI3REF: Database Connection Configuration Options
|
@@ -1882,11 +1999,78 @@ struct sqlite3_mem_methods {
|
|
1882
1999
|
** following this call. The second parameter may be a NULL pointer, in
|
1883
2000
|
** which case the trigger setting is not reported back. </dd>
|
1884
2001
|
**
|
2002
|
+
** <dt>SQLITE_DBCONFIG_ENABLE_FTS3_TOKENIZER</dt>
|
2003
|
+
** <dd> ^This option is used to enable or disable the two-argument
|
2004
|
+
** version of the [fts3_tokenizer()] function which is part of the
|
2005
|
+
** [FTS3] full-text search engine extension.
|
2006
|
+
** There should be two additional arguments.
|
2007
|
+
** The first argument is an integer which is 0 to disable fts3_tokenizer() or
|
2008
|
+
** positive to enable fts3_tokenizer() or negative to leave the setting
|
2009
|
+
** unchanged.
|
2010
|
+
** The second parameter is a pointer to an integer into which
|
2011
|
+
** is written 0 or 1 to indicate whether fts3_tokenizer is disabled or enabled
|
2012
|
+
** following this call. The second parameter may be a NULL pointer, in
|
2013
|
+
** which case the new setting is not reported back. </dd>
|
2014
|
+
**
|
2015
|
+
** <dt>SQLITE_DBCONFIG_ENABLE_LOAD_EXTENSION</dt>
|
2016
|
+
** <dd> ^This option is used to enable or disable the [sqlite3_load_extension()]
|
2017
|
+
** interface independently of the [load_extension()] SQL function.
|
2018
|
+
** The [sqlite3_enable_load_extension()] API enables or disables both the
|
2019
|
+
** C-API [sqlite3_load_extension()] and the SQL function [load_extension()].
|
2020
|
+
** There should be two additional arguments.
|
2021
|
+
** When the first argument to this interface is 1, then only the C-API is
|
2022
|
+
** enabled and the SQL function remains disabled. If the first argument to
|
2023
|
+
** this interface is 0, then both the C-API and the SQL function are disabled.
|
2024
|
+
** If the first argument is -1, then no changes are made to state of either the
|
2025
|
+
** C-API or the SQL function.
|
2026
|
+
** The second parameter is a pointer to an integer into which
|
2027
|
+
** is written 0 or 1 to indicate whether [sqlite3_load_extension()] interface
|
2028
|
+
** is disabled or enabled following this call. The second parameter may
|
2029
|
+
** be a NULL pointer, in which case the new setting is not reported back.
|
2030
|
+
** </dd>
|
2031
|
+
**
|
2032
|
+
** <dt>SQLITE_DBCONFIG_MAINDBNAME</dt>
|
2033
|
+
** <dd> ^This option is used to change the name of the "main" database
|
2034
|
+
** schema. ^The sole argument is a pointer to a constant UTF8 string
|
2035
|
+
** which will become the new schema name in place of "main". ^SQLite
|
2036
|
+
** does not make a copy of the new main schema name string, so the application
|
2037
|
+
** must ensure that the argument passed into this DBCONFIG option is unchanged
|
2038
|
+
** until after the database connection closes.
|
2039
|
+
** </dd>
|
2040
|
+
**
|
2041
|
+
** <dt>SQLITE_DBCONFIG_NO_CKPT_ON_CLOSE</dt>
|
2042
|
+
** <dd> Usually, when a database in wal mode is closed or detached from a
|
2043
|
+
** database handle, SQLite checks if this will mean that there are now no
|
2044
|
+
** connections at all to the database. If so, it performs a checkpoint
|
2045
|
+
** operation before closing the connection. This option may be used to
|
2046
|
+
** override this behaviour. The first parameter passed to this operation
|
2047
|
+
** is an integer - non-zero to disable checkpoints-on-close, or zero (the
|
2048
|
+
** default) to enable them. The second parameter is a pointer to an integer
|
2049
|
+
** into which is written 0 or 1 to indicate whether checkpoints-on-close
|
2050
|
+
** have been disabled - 0 if they are not disabled, 1 if they are.
|
2051
|
+
** </dd>
|
2052
|
+
**
|
2053
|
+
** <dt>SQLITE_DBCONFIG_ENABLE_QPSG</dt>
|
2054
|
+
** <dd>^(The SQLITE_DBCONFIG_ENABLE_QPSG option activates or deactivates
|
2055
|
+
** the [query planner stability guarantee] (QPSG). When the QPSG is active,
|
2056
|
+
** a single SQL query statement will always use the same algorithm regardless
|
2057
|
+
** of values of [bound parameters].)^ The QPSG disables some query optimizations
|
2058
|
+
** that look at the values of bound parameters, which can make some queries
|
2059
|
+
** slower. But the QPSG has the advantage of more predictable behavior. With
|
2060
|
+
** the QPSG active, SQLite will always use the same query plan in the field as
|
2061
|
+
** was used during testing in the lab.
|
2062
|
+
** </dd>
|
2063
|
+
**
|
1885
2064
|
** </dl>
|
1886
2065
|
*/
|
1887
|
-
#define
|
1888
|
-
#define
|
1889
|
-
#define
|
2066
|
+
#define SQLITE_DBCONFIG_MAINDBNAME 1000 /* const char* */
|
2067
|
+
#define SQLITE_DBCONFIG_LOOKASIDE 1001 /* void* int int */
|
2068
|
+
#define SQLITE_DBCONFIG_ENABLE_FKEY 1002 /* int int* */
|
2069
|
+
#define SQLITE_DBCONFIG_ENABLE_TRIGGER 1003 /* int int* */
|
2070
|
+
#define SQLITE_DBCONFIG_ENABLE_FTS3_TOKENIZER 1004 /* int int* */
|
2071
|
+
#define SQLITE_DBCONFIG_ENABLE_LOAD_EXTENSION 1005 /* int int* */
|
2072
|
+
#define SQLITE_DBCONFIG_NO_CKPT_ON_CLOSE 1006 /* int int* */
|
2073
|
+
#define SQLITE_DBCONFIG_ENABLE_QPSG 1007 /* int int* */
|
1890
2074
|
|
1891
2075
|
|
1892
2076
|
/*
|
@@ -1897,7 +2081,7 @@ struct sqlite3_mem_methods {
|
|
1897
2081
|
** [extended result codes] feature of SQLite. ^The extended result
|
1898
2082
|
** codes are disabled by default for historical compatibility.
|
1899
2083
|
*/
|
1900
|
-
SQLITE_API int
|
2084
|
+
SQLITE_API int sqlite3_extended_result_codes(sqlite3*, int onoff);
|
1901
2085
|
|
1902
2086
|
/*
|
1903
2087
|
** CAPI3REF: Last Insert Rowid
|
@@ -1911,20 +2095,30 @@ SQLITE_API int SQLITE_STDCALL sqlite3_extended_result_codes(sqlite3*, int onoff)
|
|
1911
2095
|
** the table has a column of type [INTEGER PRIMARY KEY] then that column
|
1912
2096
|
** is another alias for the rowid.
|
1913
2097
|
**
|
1914
|
-
** ^The sqlite3_last_insert_rowid(D) interface returns the [rowid] of
|
1915
|
-
** most recent successful [INSERT] into a rowid table or [virtual table]
|
1916
|
-
** on database connection D.
|
1917
|
-
** ^
|
1918
|
-
**
|
1919
|
-
**
|
1920
|
-
**
|
1921
|
-
**
|
1922
|
-
**
|
1923
|
-
**
|
1924
|
-
**
|
1925
|
-
**
|
1926
|
-
**
|
1927
|
-
**
|
2098
|
+
** ^The sqlite3_last_insert_rowid(D) interface usually returns the [rowid] of
|
2099
|
+
** the most recent successful [INSERT] into a rowid table or [virtual table]
|
2100
|
+
** on database connection D. ^Inserts into [WITHOUT ROWID] tables are not
|
2101
|
+
** recorded. ^If no successful [INSERT]s into rowid tables have ever occurred
|
2102
|
+
** on the database connection D, then sqlite3_last_insert_rowid(D) returns
|
2103
|
+
** zero.
|
2104
|
+
**
|
2105
|
+
** As well as being set automatically as rows are inserted into database
|
2106
|
+
** tables, the value returned by this function may be set explicitly by
|
2107
|
+
** [sqlite3_set_last_insert_rowid()]
|
2108
|
+
**
|
2109
|
+
** Some virtual table implementations may INSERT rows into rowid tables as
|
2110
|
+
** part of committing a transaction (e.g. to flush data accumulated in memory
|
2111
|
+
** to disk). In this case subsequent calls to this function return the rowid
|
2112
|
+
** associated with these internal INSERT operations, which leads to
|
2113
|
+
** unintuitive results. Virtual table implementations that do write to rowid
|
2114
|
+
** tables in this way can avoid this problem by restoring the original
|
2115
|
+
** rowid value using [sqlite3_set_last_insert_rowid()] before returning
|
2116
|
+
** control to the user.
|
2117
|
+
**
|
2118
|
+
** ^(If an [INSERT] occurs within a trigger then this routine will
|
2119
|
+
** return the [rowid] of the inserted row as long as the trigger is
|
2120
|
+
** running. Once the trigger program ends, the value returned
|
2121
|
+
** by this routine reverts to what it was before the trigger was fired.)^
|
1928
2122
|
**
|
1929
2123
|
** ^An [INSERT] that fails due to a constraint violation is not a
|
1930
2124
|
** successful [INSERT] and does not change the value returned by this
|
@@ -1949,7 +2143,17 @@ SQLITE_API int SQLITE_STDCALL sqlite3_extended_result_codes(sqlite3*, int onoff)
|
|
1949
2143
|
** unpredictable and might not equal either the old or the new
|
1950
2144
|
** last insert [rowid].
|
1951
2145
|
*/
|
1952
|
-
SQLITE_API sqlite3_int64
|
2146
|
+
SQLITE_API sqlite3_int64 sqlite3_last_insert_rowid(sqlite3*);
|
2147
|
+
|
2148
|
+
/*
|
2149
|
+
** CAPI3REF: Set the Last Insert Rowid value.
|
2150
|
+
** METHOD: sqlite3
|
2151
|
+
**
|
2152
|
+
** The sqlite3_set_last_insert_rowid(D, R) method allows the application to
|
2153
|
+
** set the value returned by calling sqlite3_last_insert_rowid(D) to R
|
2154
|
+
** without inserting a row into the database.
|
2155
|
+
*/
|
2156
|
+
SQLITE_API void sqlite3_set_last_insert_rowid(sqlite3*,sqlite3_int64);
|
1953
2157
|
|
1954
2158
|
/*
|
1955
2159
|
** CAPI3REF: Count The Number Of Rows Modified
|
@@ -2002,7 +2206,7 @@ SQLITE_API sqlite3_int64 SQLITE_STDCALL sqlite3_last_insert_rowid(sqlite3*);
|
|
2002
2206
|
** while [sqlite3_changes()] is running then the value returned
|
2003
2207
|
** is unpredictable and not meaningful.
|
2004
2208
|
*/
|
2005
|
-
SQLITE_API int
|
2209
|
+
SQLITE_API int sqlite3_changes(sqlite3*);
|
2006
2210
|
|
2007
2211
|
/*
|
2008
2212
|
** CAPI3REF: Total Number Of Rows Modified
|
@@ -2026,7 +2230,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_changes(sqlite3*);
|
|
2026
2230
|
** while [sqlite3_total_changes()] is running then the value
|
2027
2231
|
** returned is unpredictable and not meaningful.
|
2028
2232
|
*/
|
2029
|
-
SQLITE_API int
|
2233
|
+
SQLITE_API int sqlite3_total_changes(sqlite3*);
|
2030
2234
|
|
2031
2235
|
/*
|
2032
2236
|
** CAPI3REF: Interrupt A Long-Running Query
|
@@ -2062,11 +2266,8 @@ SQLITE_API int SQLITE_STDCALL sqlite3_total_changes(sqlite3*);
|
|
2062
2266
|
** ^A call to sqlite3_interrupt(D) that occurs when there are no running
|
2063
2267
|
** SQL statements is a no-op and has no effect on SQL statements
|
2064
2268
|
** that are started after the sqlite3_interrupt() call returns.
|
2065
|
-
**
|
2066
|
-
** If the database connection closes while [sqlite3_interrupt()]
|
2067
|
-
** is running then bad things will likely happen.
|
2068
2269
|
*/
|
2069
|
-
SQLITE_API void
|
2270
|
+
SQLITE_API void sqlite3_interrupt(sqlite3*);
|
2070
2271
|
|
2071
2272
|
/*
|
2072
2273
|
** CAPI3REF: Determine If An SQL Statement Is Complete
|
@@ -2101,8 +2302,8 @@ SQLITE_API void SQLITE_STDCALL sqlite3_interrupt(sqlite3*);
|
|
2101
2302
|
** The input to [sqlite3_complete16()] must be a zero-terminated
|
2102
2303
|
** UTF-16 string in native byte order.
|
2103
2304
|
*/
|
2104
|
-
SQLITE_API int
|
2105
|
-
SQLITE_API int
|
2305
|
+
SQLITE_API int sqlite3_complete(const char *sql);
|
2306
|
+
SQLITE_API int sqlite3_complete16(const void *sql);
|
2106
2307
|
|
2107
2308
|
/*
|
2108
2309
|
** CAPI3REF: Register A Callback To Handle SQLITE_BUSY Errors
|
@@ -2163,7 +2364,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_complete16(const void *sql);
|
|
2163
2364
|
** A busy handler must not close the database connection
|
2164
2365
|
** or [prepared statement] that invoked the busy handler.
|
2165
2366
|
*/
|
2166
|
-
SQLITE_API int
|
2367
|
+
SQLITE_API int sqlite3_busy_handler(sqlite3*,int(*)(void*,int),void*);
|
2167
2368
|
|
2168
2369
|
/*
|
2169
2370
|
** CAPI3REF: Set A Busy Timeout
|
@@ -2186,7 +2387,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_busy_handler(sqlite3*, int(*)(void*,int),
|
|
2186
2387
|
**
|
2187
2388
|
** See also: [PRAGMA busy_timeout]
|
2188
2389
|
*/
|
2189
|
-
SQLITE_API int
|
2390
|
+
SQLITE_API int sqlite3_busy_timeout(sqlite3*, int ms);
|
2190
2391
|
|
2191
2392
|
/*
|
2192
2393
|
** CAPI3REF: Convenience Routines For Running Queries
|
@@ -2261,7 +2462,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_busy_timeout(sqlite3*, int ms);
|
|
2261
2462
|
** reflected in subsequent calls to [sqlite3_errcode()] or
|
2262
2463
|
** [sqlite3_errmsg()].
|
2263
2464
|
*/
|
2264
|
-
SQLITE_API int
|
2465
|
+
SQLITE_API int sqlite3_get_table(
|
2265
2466
|
sqlite3 *db, /* An open database */
|
2266
2467
|
const char *zSql, /* SQL to be evaluated */
|
2267
2468
|
char ***pazResult, /* Results of the query */
|
@@ -2269,7 +2470,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_get_table(
|
|
2269
2470
|
int *pnColumn, /* Number of result columns written here */
|
2270
2471
|
char **pzErrmsg /* Error msg written here */
|
2271
2472
|
);
|
2272
|
-
SQLITE_API void
|
2473
|
+
SQLITE_API void sqlite3_free_table(char **result);
|
2273
2474
|
|
2274
2475
|
/*
|
2275
2476
|
** CAPI3REF: Formatted String Printing Functions
|
@@ -2375,10 +2576,10 @@ SQLITE_API void SQLITE_STDCALL sqlite3_free_table(char **result);
|
|
2375
2576
|
** addition that after the string has been read and copied into
|
2376
2577
|
** the result, [sqlite3_free()] is called on the input string.)^
|
2377
2578
|
*/
|
2378
|
-
SQLITE_API char *
|
2379
|
-
SQLITE_API char *
|
2380
|
-
SQLITE_API char *
|
2381
|
-
SQLITE_API char *
|
2579
|
+
SQLITE_API char *sqlite3_mprintf(const char*,...);
|
2580
|
+
SQLITE_API char *sqlite3_vmprintf(const char*, va_list);
|
2581
|
+
SQLITE_API char *sqlite3_snprintf(int,char*,const char*, ...);
|
2582
|
+
SQLITE_API char *sqlite3_vsnprintf(int,char*,const char*, va_list);
|
2382
2583
|
|
2383
2584
|
/*
|
2384
2585
|
** CAPI3REF: Memory Allocation Subsystem
|
@@ -2468,12 +2669,12 @@ SQLITE_API char *SQLITE_STDCALL sqlite3_vsnprintf(int,char*,const char*, va_list
|
|
2468
2669
|
** a block of memory after it has been released using
|
2469
2670
|
** [sqlite3_free()] or [sqlite3_realloc()].
|
2470
2671
|
*/
|
2471
|
-
SQLITE_API void *
|
2472
|
-
SQLITE_API void *
|
2473
|
-
SQLITE_API void *
|
2474
|
-
SQLITE_API void *
|
2475
|
-
SQLITE_API void
|
2476
|
-
SQLITE_API sqlite3_uint64
|
2672
|
+
SQLITE_API void *sqlite3_malloc(int);
|
2673
|
+
SQLITE_API void *sqlite3_malloc64(sqlite3_uint64);
|
2674
|
+
SQLITE_API void *sqlite3_realloc(void*, int);
|
2675
|
+
SQLITE_API void *sqlite3_realloc64(void*, sqlite3_uint64);
|
2676
|
+
SQLITE_API void sqlite3_free(void*);
|
2677
|
+
SQLITE_API sqlite3_uint64 sqlite3_msize(void*);
|
2477
2678
|
|
2478
2679
|
/*
|
2479
2680
|
** CAPI3REF: Memory Allocator Statistics
|
@@ -2498,8 +2699,8 @@ SQLITE_API sqlite3_uint64 SQLITE_STDCALL sqlite3_msize(void*);
|
|
2498
2699
|
** by [sqlite3_memory_highwater(1)] is the high-water mark
|
2499
2700
|
** prior to the reset.
|
2500
2701
|
*/
|
2501
|
-
SQLITE_API sqlite3_int64
|
2502
|
-
SQLITE_API sqlite3_int64
|
2702
|
+
SQLITE_API sqlite3_int64 sqlite3_memory_used(void);
|
2703
|
+
SQLITE_API sqlite3_int64 sqlite3_memory_highwater(int resetFlag);
|
2503
2704
|
|
2504
2705
|
/*
|
2505
2706
|
** CAPI3REF: Pseudo-Random Number Generator
|
@@ -2522,17 +2723,19 @@ SQLITE_API sqlite3_int64 SQLITE_STDCALL sqlite3_memory_highwater(int resetFlag);
|
|
2522
2723
|
** internally and without recourse to the [sqlite3_vfs] xRandomness
|
2523
2724
|
** method.
|
2524
2725
|
*/
|
2525
|
-
SQLITE_API void
|
2726
|
+
SQLITE_API void sqlite3_randomness(int N, void *P);
|
2526
2727
|
|
2527
2728
|
/*
|
2528
2729
|
** CAPI3REF: Compile-Time Authorization Callbacks
|
2529
2730
|
** METHOD: sqlite3
|
2731
|
+
** KEYWORDS: {authorizer callback}
|
2530
2732
|
**
|
2531
2733
|
** ^This routine registers an authorizer callback with a particular
|
2532
2734
|
** [database connection], supplied in the first argument.
|
2533
2735
|
** ^The authorizer callback is invoked as SQL statements are being compiled
|
2534
2736
|
** by [sqlite3_prepare()] or its variants [sqlite3_prepare_v2()],
|
2535
|
-
** [sqlite3_prepare16()]
|
2737
|
+
** [sqlite3_prepare_v3()], [sqlite3_prepare16()], [sqlite3_prepare16_v2()],
|
2738
|
+
** and [sqlite3_prepare16_v3()]. ^At various
|
2536
2739
|
** points during the compilation process, as logic is being created
|
2537
2740
|
** to perform various actions, the authorizer callback is invoked to
|
2538
2741
|
** see if those actions are allowed. ^The authorizer callback should
|
@@ -2554,8 +2757,10 @@ SQLITE_API void SQLITE_STDCALL sqlite3_randomness(int N, void *P);
|
|
2554
2757
|
** parameter to the sqlite3_set_authorizer() interface. ^The second parameter
|
2555
2758
|
** to the callback is an integer [SQLITE_COPY | action code] that specifies
|
2556
2759
|
** the particular action to be authorized. ^The third through sixth parameters
|
2557
|
-
** to the callback are zero-terminated strings
|
2558
|
-
** details about the action to be authorized.
|
2760
|
+
** to the callback are either NULL pointers or zero-terminated strings
|
2761
|
+
** that contain additional details about the action to be authorized.
|
2762
|
+
** Applications must always be prepared to encounter a NULL pointer in any
|
2763
|
+
** of the third through the sixth parameters of the authorization callback.
|
2559
2764
|
**
|
2560
2765
|
** ^If the action code is [SQLITE_READ]
|
2561
2766
|
** and the callback returns [SQLITE_IGNORE] then the
|
@@ -2564,6 +2769,10 @@ SQLITE_API void SQLITE_STDCALL sqlite3_randomness(int N, void *P);
|
|
2564
2769
|
** been read if [SQLITE_OK] had been returned. The [SQLITE_IGNORE]
|
2565
2770
|
** return can be used to deny an untrusted user access to individual
|
2566
2771
|
** columns of a table.
|
2772
|
+
** ^When a table is referenced by a [SELECT] but no column values are
|
2773
|
+
** extracted from that table (for example in a query like
|
2774
|
+
** "SELECT count(*) FROM tab") then the [SQLITE_READ] authorizer callback
|
2775
|
+
** is invoked once for that table with a column name that is an empty string.
|
2567
2776
|
** ^If the action code is [SQLITE_DELETE] and the callback returns
|
2568
2777
|
** [SQLITE_IGNORE] then the [DELETE] operation proceeds but the
|
2569
2778
|
** [truncate optimization] is disabled and all rows are deleted individually.
|
@@ -2605,7 +2814,7 @@ SQLITE_API void SQLITE_STDCALL sqlite3_randomness(int N, void *P);
|
|
2605
2814
|
** as stated in the previous paragraph, sqlite3_step() invokes
|
2606
2815
|
** sqlite3_prepare_v2() to reprepare a statement after a schema change.
|
2607
2816
|
*/
|
2608
|
-
SQLITE_API int
|
2817
|
+
SQLITE_API int sqlite3_set_authorizer(
|
2609
2818
|
sqlite3*,
|
2610
2819
|
int (*xAuth)(void*,int,const char*,const char*,const char*,const char*),
|
2611
2820
|
void *pUserData
|
@@ -2685,6 +2894,9 @@ SQLITE_API int SQLITE_STDCALL sqlite3_set_authorizer(
|
|
2685
2894
|
** CAPI3REF: Tracing And Profiling Functions
|
2686
2895
|
** METHOD: sqlite3
|
2687
2896
|
**
|
2897
|
+
** These routines are deprecated. Use the [sqlite3_trace_v2()] interface
|
2898
|
+
** instead of the routines described here.
|
2899
|
+
**
|
2688
2900
|
** These routines register callback functions that can be used for
|
2689
2901
|
** tracing and profiling the execution of SQL statements.
|
2690
2902
|
**
|
@@ -2710,10 +2922,104 @@ SQLITE_API int SQLITE_STDCALL sqlite3_set_authorizer(
|
|
2710
2922
|
** sqlite3_profile() function is considered experimental and is
|
2711
2923
|
** subject to change in future versions of SQLite.
|
2712
2924
|
*/
|
2713
|
-
SQLITE_API void *
|
2714
|
-
|
2925
|
+
SQLITE_API SQLITE_DEPRECATED void *sqlite3_trace(sqlite3*,
|
2926
|
+
void(*xTrace)(void*,const char*), void*);
|
2927
|
+
SQLITE_API SQLITE_DEPRECATED void *sqlite3_profile(sqlite3*,
|
2715
2928
|
void(*xProfile)(void*,const char*,sqlite3_uint64), void*);
|
2716
2929
|
|
2930
|
+
/*
|
2931
|
+
** CAPI3REF: SQL Trace Event Codes
|
2932
|
+
** KEYWORDS: SQLITE_TRACE
|
2933
|
+
**
|
2934
|
+
** These constants identify classes of events that can be monitored
|
2935
|
+
** using the [sqlite3_trace_v2()] tracing logic. The third argument
|
2936
|
+
** to [sqlite3_trace_v2()] is an OR-ed combination of one or more of
|
2937
|
+
** the following constants. ^The first argument to the trace callback
|
2938
|
+
** is one of the following constants.
|
2939
|
+
**
|
2940
|
+
** New tracing constants may be added in future releases.
|
2941
|
+
**
|
2942
|
+
** ^A trace callback has four arguments: xCallback(T,C,P,X).
|
2943
|
+
** ^The T argument is one of the integer type codes above.
|
2944
|
+
** ^The C argument is a copy of the context pointer passed in as the
|
2945
|
+
** fourth argument to [sqlite3_trace_v2()].
|
2946
|
+
** The P and X arguments are pointers whose meanings depend on T.
|
2947
|
+
**
|
2948
|
+
** <dl>
|
2949
|
+
** [[SQLITE_TRACE_STMT]] <dt>SQLITE_TRACE_STMT</dt>
|
2950
|
+
** <dd>^An SQLITE_TRACE_STMT callback is invoked when a prepared statement
|
2951
|
+
** first begins running and possibly at other times during the
|
2952
|
+
** execution of the prepared statement, such as at the start of each
|
2953
|
+
** trigger subprogram. ^The P argument is a pointer to the
|
2954
|
+
** [prepared statement]. ^The X argument is a pointer to a string which
|
2955
|
+
** is the unexpanded SQL text of the prepared statement or an SQL comment
|
2956
|
+
** that indicates the invocation of a trigger. ^The callback can compute
|
2957
|
+
** the same text that would have been returned by the legacy [sqlite3_trace()]
|
2958
|
+
** interface by using the X argument when X begins with "--" and invoking
|
2959
|
+
** [sqlite3_expanded_sql(P)] otherwise.
|
2960
|
+
**
|
2961
|
+
** [[SQLITE_TRACE_PROFILE]] <dt>SQLITE_TRACE_PROFILE</dt>
|
2962
|
+
** <dd>^An SQLITE_TRACE_PROFILE callback provides approximately the same
|
2963
|
+
** information as is provided by the [sqlite3_profile()] callback.
|
2964
|
+
** ^The P argument is a pointer to the [prepared statement] and the
|
2965
|
+
** X argument points to a 64-bit integer which is the estimated of
|
2966
|
+
** the number of nanosecond that the prepared statement took to run.
|
2967
|
+
** ^The SQLITE_TRACE_PROFILE callback is invoked when the statement finishes.
|
2968
|
+
**
|
2969
|
+
** [[SQLITE_TRACE_ROW]] <dt>SQLITE_TRACE_ROW</dt>
|
2970
|
+
** <dd>^An SQLITE_TRACE_ROW callback is invoked whenever a prepared
|
2971
|
+
** statement generates a single row of result.
|
2972
|
+
** ^The P argument is a pointer to the [prepared statement] and the
|
2973
|
+
** X argument is unused.
|
2974
|
+
**
|
2975
|
+
** [[SQLITE_TRACE_CLOSE]] <dt>SQLITE_TRACE_CLOSE</dt>
|
2976
|
+
** <dd>^An SQLITE_TRACE_CLOSE callback is invoked when a database
|
2977
|
+
** connection closes.
|
2978
|
+
** ^The P argument is a pointer to the [database connection] object
|
2979
|
+
** and the X argument is unused.
|
2980
|
+
** </dl>
|
2981
|
+
*/
|
2982
|
+
#define SQLITE_TRACE_STMT 0x01
|
2983
|
+
#define SQLITE_TRACE_PROFILE 0x02
|
2984
|
+
#define SQLITE_TRACE_ROW 0x04
|
2985
|
+
#define SQLITE_TRACE_CLOSE 0x08
|
2986
|
+
|
2987
|
+
/*
|
2988
|
+
** CAPI3REF: SQL Trace Hook
|
2989
|
+
** METHOD: sqlite3
|
2990
|
+
**
|
2991
|
+
** ^The sqlite3_trace_v2(D,M,X,P) interface registers a trace callback
|
2992
|
+
** function X against [database connection] D, using property mask M
|
2993
|
+
** and context pointer P. ^If the X callback is
|
2994
|
+
** NULL or if the M mask is zero, then tracing is disabled. The
|
2995
|
+
** M argument should be the bitwise OR-ed combination of
|
2996
|
+
** zero or more [SQLITE_TRACE] constants.
|
2997
|
+
**
|
2998
|
+
** ^Each call to either sqlite3_trace() or sqlite3_trace_v2() overrides
|
2999
|
+
** (cancels) any prior calls to sqlite3_trace() or sqlite3_trace_v2().
|
3000
|
+
**
|
3001
|
+
** ^The X callback is invoked whenever any of the events identified by
|
3002
|
+
** mask M occur. ^The integer return value from the callback is currently
|
3003
|
+
** ignored, though this may change in future releases. Callback
|
3004
|
+
** implementations should return zero to ensure future compatibility.
|
3005
|
+
**
|
3006
|
+
** ^A trace callback is invoked with four arguments: callback(T,C,P,X).
|
3007
|
+
** ^The T argument is one of the [SQLITE_TRACE]
|
3008
|
+
** constants to indicate why the callback was invoked.
|
3009
|
+
** ^The C argument is a copy of the context pointer.
|
3010
|
+
** The P and X arguments are pointers whose meanings depend on T.
|
3011
|
+
**
|
3012
|
+
** The sqlite3_trace_v2() interface is intended to replace the legacy
|
3013
|
+
** interfaces [sqlite3_trace()] and [sqlite3_profile()], both of which
|
3014
|
+
** are deprecated.
|
3015
|
+
*/
|
3016
|
+
SQLITE_API int sqlite3_trace_v2(
|
3017
|
+
sqlite3*,
|
3018
|
+
unsigned uMask,
|
3019
|
+
int(*xCallback)(unsigned,void*,void*,void*),
|
3020
|
+
void *pCtx
|
3021
|
+
);
|
3022
|
+
|
2717
3023
|
/*
|
2718
3024
|
** CAPI3REF: Query Progress Callbacks
|
2719
3025
|
** METHOD: sqlite3
|
@@ -2746,7 +3052,7 @@ SQLITE_API SQLITE_EXPERIMENTAL void *SQLITE_STDCALL sqlite3_profile(sqlite3*,
|
|
2746
3052
|
** database connections for the meaning of "modify" in this paragraph.
|
2747
3053
|
**
|
2748
3054
|
*/
|
2749
|
-
SQLITE_API void
|
3055
|
+
SQLITE_API void sqlite3_progress_handler(sqlite3*, int, int(*)(void*), void*);
|
2750
3056
|
|
2751
3057
|
/*
|
2752
3058
|
** CAPI3REF: Opening A New Database Connection
|
@@ -2836,10 +3142,10 @@ SQLITE_API void SQLITE_STDCALL sqlite3_progress_handler(sqlite3*, int, int(*)(vo
|
|
2836
3142
|
** ^If [URI filename] interpretation is enabled, and the filename argument
|
2837
3143
|
** begins with "file:", then the filename is interpreted as a URI. ^URI
|
2838
3144
|
** filename interpretation is enabled if the [SQLITE_OPEN_URI] flag is
|
2839
|
-
** set in the
|
3145
|
+
** set in the third argument to sqlite3_open_v2(), or if it has
|
2840
3146
|
** been enabled globally using the [SQLITE_CONFIG_URI] option with the
|
2841
3147
|
** [sqlite3_config()] method or by the [SQLITE_USE_URI] compile-time option.
|
2842
|
-
**
|
3148
|
+
** URI filename interpretation is turned off
|
2843
3149
|
** by default, but future releases of SQLite might enable URI filename
|
2844
3150
|
** interpretation by default. See "[URI filenames]" for additional
|
2845
3151
|
** information.
|
@@ -2975,15 +3281,15 @@ SQLITE_API void SQLITE_STDCALL sqlite3_progress_handler(sqlite3*, int, int(*)(vo
|
|
2975
3281
|
**
|
2976
3282
|
** See also: [sqlite3_temp_directory]
|
2977
3283
|
*/
|
2978
|
-
SQLITE_API int
|
3284
|
+
SQLITE_API int sqlite3_open(
|
2979
3285
|
const char *filename, /* Database filename (UTF-8) */
|
2980
3286
|
sqlite3 **ppDb /* OUT: SQLite db handle */
|
2981
3287
|
);
|
2982
|
-
SQLITE_API int
|
3288
|
+
SQLITE_API int sqlite3_open16(
|
2983
3289
|
const void *filename, /* Database filename (UTF-16) */
|
2984
3290
|
sqlite3 **ppDb /* OUT: SQLite db handle */
|
2985
3291
|
);
|
2986
|
-
SQLITE_API int
|
3292
|
+
SQLITE_API int sqlite3_open_v2(
|
2987
3293
|
const char *filename, /* Database filename (UTF-8) */
|
2988
3294
|
sqlite3 **ppDb, /* OUT: SQLite db handle */
|
2989
3295
|
int flags, /* Flags */
|
@@ -3029,9 +3335,9 @@ SQLITE_API int SQLITE_STDCALL sqlite3_open_v2(
|
|
3029
3335
|
** VFS method, then the behavior of this routine is undefined and probably
|
3030
3336
|
** undesirable.
|
3031
3337
|
*/
|
3032
|
-
SQLITE_API const char *
|
3033
|
-
SQLITE_API int
|
3034
|
-
SQLITE_API sqlite3_int64
|
3338
|
+
SQLITE_API const char *sqlite3_uri_parameter(const char *zFilename, const char *zParam);
|
3339
|
+
SQLITE_API int sqlite3_uri_boolean(const char *zFile, const char *zParam, int bDefault);
|
3340
|
+
SQLITE_API sqlite3_int64 sqlite3_uri_int64(const char*, const char*, sqlite3_int64);
|
3035
3341
|
|
3036
3342
|
|
3037
3343
|
/*
|
@@ -3075,11 +3381,11 @@ SQLITE_API sqlite3_int64 SQLITE_STDCALL sqlite3_uri_int64(const char*, const cha
|
|
3075
3381
|
** was invoked incorrectly by the application. In that case, the
|
3076
3382
|
** error code and message may or may not be set.
|
3077
3383
|
*/
|
3078
|
-
SQLITE_API int
|
3079
|
-
SQLITE_API int
|
3080
|
-
SQLITE_API const char *
|
3081
|
-
SQLITE_API const void *
|
3082
|
-
SQLITE_API const char *
|
3384
|
+
SQLITE_API int sqlite3_errcode(sqlite3 *db);
|
3385
|
+
SQLITE_API int sqlite3_extended_errcode(sqlite3 *db);
|
3386
|
+
SQLITE_API const char *sqlite3_errmsg(sqlite3*);
|
3387
|
+
SQLITE_API const void *sqlite3_errmsg16(sqlite3*);
|
3388
|
+
SQLITE_API const char *sqlite3_errstr(int);
|
3083
3389
|
|
3084
3390
|
/*
|
3085
3391
|
** CAPI3REF: Prepared Statement Object
|
@@ -3147,7 +3453,7 @@ typedef struct sqlite3_stmt sqlite3_stmt;
|
|
3147
3453
|
**
|
3148
3454
|
** New run-time limit categories may be added in future releases.
|
3149
3455
|
*/
|
3150
|
-
SQLITE_API int
|
3456
|
+
SQLITE_API int sqlite3_limit(sqlite3*, int id, int newVal);
|
3151
3457
|
|
3152
3458
|
/*
|
3153
3459
|
** CAPI3REF: Run-Time Limit Categories
|
@@ -3178,9 +3484,9 @@ SQLITE_API int SQLITE_STDCALL sqlite3_limit(sqlite3*, int id, int newVal);
|
|
3178
3484
|
**
|
3179
3485
|
** [[SQLITE_LIMIT_VDBE_OP]] ^(<dt>SQLITE_LIMIT_VDBE_OP</dt>
|
3180
3486
|
** <dd>The maximum number of instructions in a virtual machine program
|
3181
|
-
** used to implement an SQL statement.
|
3182
|
-
**
|
3183
|
-
**
|
3487
|
+
** used to implement an SQL statement. If [sqlite3_prepare_v2()] or
|
3488
|
+
** the equivalent tries to allocate space for more than this many opcodes
|
3489
|
+
** in a single prepared statement, an SQLITE_NOMEM error is returned.</dd>)^
|
3184
3490
|
**
|
3185
3491
|
** [[SQLITE_LIMIT_FUNCTION_ARG]] ^(<dt>SQLITE_LIMIT_FUNCTION_ARG</dt>
|
3186
3492
|
** <dd>The maximum number of arguments on a function.</dd>)^
|
@@ -3218,23 +3524,59 @@ SQLITE_API int SQLITE_STDCALL sqlite3_limit(sqlite3*, int id, int newVal);
|
|
3218
3524
|
#define SQLITE_LIMIT_TRIGGER_DEPTH 10
|
3219
3525
|
#define SQLITE_LIMIT_WORKER_THREADS 11
|
3220
3526
|
|
3527
|
+
/*
|
3528
|
+
** CAPI3REF: Prepare Flags
|
3529
|
+
**
|
3530
|
+
** These constants define various flags that can be passed into
|
3531
|
+
** "prepFlags" parameter of the [sqlite3_prepare_v3()] and
|
3532
|
+
** [sqlite3_prepare16_v3()] interfaces.
|
3533
|
+
**
|
3534
|
+
** New flags may be added in future releases of SQLite.
|
3535
|
+
**
|
3536
|
+
** <dl>
|
3537
|
+
** [[SQLITE_PREPARE_PERSISTENT]] ^(<dt>SQLITE_PREPARE_PERSISTENT</dt>
|
3538
|
+
** <dd>The SQLITE_PREPARE_PERSISTENT flag is a hint to the query planner
|
3539
|
+
** that the prepared statement will be retained for a long time and
|
3540
|
+
** probably reused many times.)^ ^Without this flag, [sqlite3_prepare_v3()]
|
3541
|
+
** and [sqlite3_prepare16_v3()] assume that the prepared statement will
|
3542
|
+
** be used just once or at most a few times and then destroyed using
|
3543
|
+
** [sqlite3_finalize()] relatively soon. The current implementation acts
|
3544
|
+
** on this hint by avoiding the use of [lookaside memory] so as not to
|
3545
|
+
** deplete the limited store of lookaside memory. Future versions of
|
3546
|
+
** SQLite may act on this hint differently.
|
3547
|
+
** </dl>
|
3548
|
+
*/
|
3549
|
+
#define SQLITE_PREPARE_PERSISTENT 0x01
|
3550
|
+
|
3221
3551
|
/*
|
3222
3552
|
** CAPI3REF: Compiling An SQL Statement
|
3223
3553
|
** KEYWORDS: {SQL statement compiler}
|
3224
3554
|
** METHOD: sqlite3
|
3225
3555
|
** CONSTRUCTOR: sqlite3_stmt
|
3226
3556
|
**
|
3227
|
-
** To execute an SQL
|
3228
|
-
** program using one of these routines.
|
3557
|
+
** To execute an SQL statement, it must first be compiled into a byte-code
|
3558
|
+
** program using one of these routines. Or, in other words, these routines
|
3559
|
+
** are constructors for the [prepared statement] object.
|
3560
|
+
**
|
3561
|
+
** The preferred routine to use is [sqlite3_prepare_v2()]. The
|
3562
|
+
** [sqlite3_prepare()] interface is legacy and should be avoided.
|
3563
|
+
** [sqlite3_prepare_v3()] has an extra "prepFlags" option that is used
|
3564
|
+
** for special purposes.
|
3565
|
+
**
|
3566
|
+
** The use of the UTF-8 interfaces is preferred, as SQLite currently
|
3567
|
+
** does all parsing using UTF-8. The UTF-16 interfaces are provided
|
3568
|
+
** as a convenience. The UTF-16 interfaces work by converting the
|
3569
|
+
** input text into UTF-8, then invoking the corresponding UTF-8 interface.
|
3229
3570
|
**
|
3230
3571
|
** The first argument, "db", is a [database connection] obtained from a
|
3231
3572
|
** prior successful call to [sqlite3_open()], [sqlite3_open_v2()] or
|
3232
3573
|
** [sqlite3_open16()]. The database connection must not have been closed.
|
3233
3574
|
**
|
3234
3575
|
** The second argument, "zSql", is the statement to be compiled, encoded
|
3235
|
-
** as either UTF-8 or UTF-16. The sqlite3_prepare()
|
3236
|
-
**
|
3237
|
-
** use UTF-
|
3576
|
+
** as either UTF-8 or UTF-16. The sqlite3_prepare(), sqlite3_prepare_v2(),
|
3577
|
+
** and sqlite3_prepare_v3()
|
3578
|
+
** interfaces use UTF-8, and sqlite3_prepare16(), sqlite3_prepare16_v2(),
|
3579
|
+
** and sqlite3_prepare16_v3() use UTF-16.
|
3238
3580
|
**
|
3239
3581
|
** ^If the nByte argument is negative, then zSql is read up to the
|
3240
3582
|
** first zero terminator. ^If nByte is positive, then it is the
|
@@ -3261,10 +3603,11 @@ SQLITE_API int SQLITE_STDCALL sqlite3_limit(sqlite3*, int id, int newVal);
|
|
3261
3603
|
** ^On success, the sqlite3_prepare() family of routines return [SQLITE_OK];
|
3262
3604
|
** otherwise an [error code] is returned.
|
3263
3605
|
**
|
3264
|
-
** The sqlite3_prepare_v2()
|
3265
|
-
** recommended for all new programs.
|
3266
|
-
**
|
3267
|
-
**
|
3606
|
+
** The sqlite3_prepare_v2(), sqlite3_prepare_v3(), sqlite3_prepare16_v2(),
|
3607
|
+
** and sqlite3_prepare16_v3() interfaces are recommended for all new programs.
|
3608
|
+
** The older interfaces (sqlite3_prepare() and sqlite3_prepare16())
|
3609
|
+
** are retained for backwards compatibility, but their use is discouraged.
|
3610
|
+
** ^In the "vX" interfaces, the prepared statement
|
3268
3611
|
** that is returned (the [sqlite3_stmt] object) contains a copy of the
|
3269
3612
|
** original SQL text. This causes the [sqlite3_step()] interface to
|
3270
3613
|
** behave differently in three ways:
|
@@ -3297,46 +3640,93 @@ SQLITE_API int SQLITE_STDCALL sqlite3_limit(sqlite3*, int id, int newVal);
|
|
3297
3640
|
** or [GLOB] operator or if the parameter is compared to an indexed column
|
3298
3641
|
** and the [SQLITE_ENABLE_STAT3] compile-time option is enabled.
|
3299
3642
|
** </li>
|
3643
|
+
**
|
3644
|
+
** <p>^sqlite3_prepare_v3() differs from sqlite3_prepare_v2() only in having
|
3645
|
+
** the extra prepFlags parameter, which is a bit array consisting of zero or
|
3646
|
+
** more of the [SQLITE_PREPARE_PERSISTENT|SQLITE_PREPARE_*] flags. ^The
|
3647
|
+
** sqlite3_prepare_v2() interface works exactly the same as
|
3648
|
+
** sqlite3_prepare_v3() with a zero prepFlags parameter.
|
3300
3649
|
** </ol>
|
3301
3650
|
*/
|
3302
|
-
SQLITE_API int
|
3651
|
+
SQLITE_API int sqlite3_prepare(
|
3303
3652
|
sqlite3 *db, /* Database handle */
|
3304
3653
|
const char *zSql, /* SQL statement, UTF-8 encoded */
|
3305
3654
|
int nByte, /* Maximum length of zSql in bytes. */
|
3306
3655
|
sqlite3_stmt **ppStmt, /* OUT: Statement handle */
|
3307
3656
|
const char **pzTail /* OUT: Pointer to unused portion of zSql */
|
3308
3657
|
);
|
3309
|
-
SQLITE_API int
|
3658
|
+
SQLITE_API int sqlite3_prepare_v2(
|
3310
3659
|
sqlite3 *db, /* Database handle */
|
3311
3660
|
const char *zSql, /* SQL statement, UTF-8 encoded */
|
3312
3661
|
int nByte, /* Maximum length of zSql in bytes. */
|
3313
3662
|
sqlite3_stmt **ppStmt, /* OUT: Statement handle */
|
3314
3663
|
const char **pzTail /* OUT: Pointer to unused portion of zSql */
|
3315
3664
|
);
|
3316
|
-
SQLITE_API int
|
3665
|
+
SQLITE_API int sqlite3_prepare_v3(
|
3666
|
+
sqlite3 *db, /* Database handle */
|
3667
|
+
const char *zSql, /* SQL statement, UTF-8 encoded */
|
3668
|
+
int nByte, /* Maximum length of zSql in bytes. */
|
3669
|
+
unsigned int prepFlags, /* Zero or more SQLITE_PREPARE_ flags */
|
3670
|
+
sqlite3_stmt **ppStmt, /* OUT: Statement handle */
|
3671
|
+
const char **pzTail /* OUT: Pointer to unused portion of zSql */
|
3672
|
+
);
|
3673
|
+
SQLITE_API int sqlite3_prepare16(
|
3317
3674
|
sqlite3 *db, /* Database handle */
|
3318
3675
|
const void *zSql, /* SQL statement, UTF-16 encoded */
|
3319
3676
|
int nByte, /* Maximum length of zSql in bytes. */
|
3320
3677
|
sqlite3_stmt **ppStmt, /* OUT: Statement handle */
|
3321
3678
|
const void **pzTail /* OUT: Pointer to unused portion of zSql */
|
3322
3679
|
);
|
3323
|
-
SQLITE_API int
|
3680
|
+
SQLITE_API int sqlite3_prepare16_v2(
|
3324
3681
|
sqlite3 *db, /* Database handle */
|
3325
3682
|
const void *zSql, /* SQL statement, UTF-16 encoded */
|
3326
3683
|
int nByte, /* Maximum length of zSql in bytes. */
|
3327
3684
|
sqlite3_stmt **ppStmt, /* OUT: Statement handle */
|
3328
3685
|
const void **pzTail /* OUT: Pointer to unused portion of zSql */
|
3329
3686
|
);
|
3687
|
+
SQLITE_API int sqlite3_prepare16_v3(
|
3688
|
+
sqlite3 *db, /* Database handle */
|
3689
|
+
const void *zSql, /* SQL statement, UTF-16 encoded */
|
3690
|
+
int nByte, /* Maximum length of zSql in bytes. */
|
3691
|
+
unsigned int prepFlags, /* Zero or more SQLITE_PREPARE_ flags */
|
3692
|
+
sqlite3_stmt **ppStmt, /* OUT: Statement handle */
|
3693
|
+
const void **pzTail /* OUT: Pointer to unused portion of zSql */
|
3694
|
+
);
|
3330
3695
|
|
3331
3696
|
/*
|
3332
3697
|
** CAPI3REF: Retrieving Statement SQL
|
3333
3698
|
** METHOD: sqlite3_stmt
|
3334
3699
|
**
|
3335
|
-
** ^
|
3336
|
-
** SQL text used to create
|
3337
|
-
**
|
3700
|
+
** ^The sqlite3_sql(P) interface returns a pointer to a copy of the UTF-8
|
3701
|
+
** SQL text used to create [prepared statement] P if P was
|
3702
|
+
** created by [sqlite3_prepare_v2()], [sqlite3_prepare_v3()],
|
3703
|
+
** [sqlite3_prepare16_v2()], or [sqlite3_prepare16_v3()].
|
3704
|
+
** ^The sqlite3_expanded_sql(P) interface returns a pointer to a UTF-8
|
3705
|
+
** string containing the SQL text of prepared statement P with
|
3706
|
+
** [bound parameters] expanded.
|
3707
|
+
**
|
3708
|
+
** ^(For example, if a prepared statement is created using the SQL
|
3709
|
+
** text "SELECT $abc,:xyz" and if parameter $abc is bound to integer 2345
|
3710
|
+
** and parameter :xyz is unbound, then sqlite3_sql() will return
|
3711
|
+
** the original string, "SELECT $abc,:xyz" but sqlite3_expanded_sql()
|
3712
|
+
** will return "SELECT 2345,NULL".)^
|
3713
|
+
**
|
3714
|
+
** ^The sqlite3_expanded_sql() interface returns NULL if insufficient memory
|
3715
|
+
** is available to hold the result, or if the result would exceed the
|
3716
|
+
** the maximum string length determined by the [SQLITE_LIMIT_LENGTH].
|
3717
|
+
**
|
3718
|
+
** ^The [SQLITE_TRACE_SIZE_LIMIT] compile-time option limits the size of
|
3719
|
+
** bound parameter expansions. ^The [SQLITE_OMIT_TRACE] compile-time
|
3720
|
+
** option causes sqlite3_expanded_sql() to always return NULL.
|
3721
|
+
**
|
3722
|
+
** ^The string returned by sqlite3_sql(P) is managed by SQLite and is
|
3723
|
+
** automatically freed when the prepared statement is finalized.
|
3724
|
+
** ^The string returned by sqlite3_expanded_sql(P), on the other hand,
|
3725
|
+
** is obtained from [sqlite3_malloc()] and must be free by the application
|
3726
|
+
** by passing it to [sqlite3_free()].
|
3338
3727
|
*/
|
3339
|
-
SQLITE_API const char *
|
3728
|
+
SQLITE_API const char *sqlite3_sql(sqlite3_stmt *pStmt);
|
3729
|
+
SQLITE_API char *sqlite3_expanded_sql(sqlite3_stmt *pStmt);
|
3340
3730
|
|
3341
3731
|
/*
|
3342
3732
|
** CAPI3REF: Determine If An SQL Statement Writes The Database
|
@@ -3367,8 +3757,12 @@ SQLITE_API const char *SQLITE_STDCALL sqlite3_sql(sqlite3_stmt *pStmt);
|
|
3367
3757
|
** sqlite3_stmt_readonly() to return true since, while those statements
|
3368
3758
|
** change the configuration of a database connection, they do not make
|
3369
3759
|
** changes to the content of the database files on disk.
|
3760
|
+
** ^The sqlite3_stmt_readonly() interface returns true for [BEGIN] since
|
3761
|
+
** [BEGIN] merely sets internal flags, but the [BEGIN|BEGIN IMMEDIATE] and
|
3762
|
+
** [BEGIN|BEGIN EXCLUSIVE] commands do touch the database and so
|
3763
|
+
** sqlite3_stmt_readonly() returns false for those commands.
|
3370
3764
|
*/
|
3371
|
-
SQLITE_API int
|
3765
|
+
SQLITE_API int sqlite3_stmt_readonly(sqlite3_stmt *pStmt);
|
3372
3766
|
|
3373
3767
|
/*
|
3374
3768
|
** CAPI3REF: Determine If A Prepared Statement Has Been Reset
|
@@ -3389,7 +3783,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_stmt_readonly(sqlite3_stmt *pStmt);
|
|
3389
3783
|
** for example, in diagnostic routines to search for prepared
|
3390
3784
|
** statements that are holding a transaction open.
|
3391
3785
|
*/
|
3392
|
-
SQLITE_API int
|
3786
|
+
SQLITE_API int sqlite3_stmt_busy(sqlite3_stmt*);
|
3393
3787
|
|
3394
3788
|
/*
|
3395
3789
|
** CAPI3REF: Dynamically Typed Value Object
|
@@ -3425,12 +3819,13 @@ SQLITE_API int SQLITE_STDCALL sqlite3_stmt_busy(sqlite3_stmt*);
|
|
3425
3819
|
** implementation of [application-defined SQL functions] are protected.
|
3426
3820
|
** ^The sqlite3_value object returned by
|
3427
3821
|
** [sqlite3_column_value()] is unprotected.
|
3428
|
-
** Unprotected sqlite3_value objects may only be used
|
3429
|
-
** [sqlite3_result_value()]
|
3822
|
+
** Unprotected sqlite3_value objects may only be used as arguments
|
3823
|
+
** to [sqlite3_result_value()], [sqlite3_bind_value()], and
|
3824
|
+
** [sqlite3_value_dup()].
|
3430
3825
|
** The [sqlite3_value_blob | sqlite3_value_type()] family of
|
3431
3826
|
** interfaces require protected sqlite3_value objects.
|
3432
3827
|
*/
|
3433
|
-
typedef struct
|
3828
|
+
typedef struct sqlite3_value sqlite3_value;
|
3434
3829
|
|
3435
3830
|
/*
|
3436
3831
|
** CAPI3REF: SQL Function Context Object
|
@@ -3532,6 +3927,15 @@ typedef struct sqlite3_context sqlite3_context;
|
|
3532
3927
|
** [sqlite3_blob_open | incremental BLOB I/O] routines.
|
3533
3928
|
** ^A negative value for the zeroblob results in a zero-length BLOB.
|
3534
3929
|
**
|
3930
|
+
** ^The sqlite3_bind_pointer(S,I,P,T,D) routine causes the I-th parameter in
|
3931
|
+
** [prepared statement] S to have an SQL value of NULL, but to also be
|
3932
|
+
** associated with the pointer P of type T. ^D is either a NULL pointer or
|
3933
|
+
** a pointer to a destructor function for P. ^SQLite will invoke the
|
3934
|
+
** destructor D with a single argument of P when it is finished using
|
3935
|
+
** P. The T parameter should be a static string, preferably a string
|
3936
|
+
** literal. The sqlite3_bind_pointer() routine is part of the
|
3937
|
+
** [pointer passing interface] added for SQLite 3.20.0.
|
3938
|
+
**
|
3535
3939
|
** ^If any of the sqlite3_bind_*() routines are called with a NULL pointer
|
3536
3940
|
** for the [prepared statement] or with a prepared statement for which
|
3537
3941
|
** [sqlite3_step()] has been called more recently than [sqlite3_reset()],
|
@@ -3553,20 +3957,21 @@ typedef struct sqlite3_context sqlite3_context;
|
|
3553
3957
|
** See also: [sqlite3_bind_parameter_count()],
|
3554
3958
|
** [sqlite3_bind_parameter_name()], and [sqlite3_bind_parameter_index()].
|
3555
3959
|
*/
|
3556
|
-
SQLITE_API int
|
3557
|
-
SQLITE_API int
|
3960
|
+
SQLITE_API int sqlite3_bind_blob(sqlite3_stmt*, int, const void*, int n, void(*)(void*));
|
3961
|
+
SQLITE_API int sqlite3_bind_blob64(sqlite3_stmt*, int, const void*, sqlite3_uint64,
|
3558
3962
|
void(*)(void*));
|
3559
|
-
SQLITE_API int
|
3560
|
-
SQLITE_API int
|
3561
|
-
SQLITE_API int
|
3562
|
-
SQLITE_API int
|
3563
|
-
SQLITE_API int
|
3564
|
-
SQLITE_API int
|
3565
|
-
SQLITE_API int
|
3963
|
+
SQLITE_API int sqlite3_bind_double(sqlite3_stmt*, int, double);
|
3964
|
+
SQLITE_API int sqlite3_bind_int(sqlite3_stmt*, int, int);
|
3965
|
+
SQLITE_API int sqlite3_bind_int64(sqlite3_stmt*, int, sqlite3_int64);
|
3966
|
+
SQLITE_API int sqlite3_bind_null(sqlite3_stmt*, int);
|
3967
|
+
SQLITE_API int sqlite3_bind_text(sqlite3_stmt*,int,const char*,int,void(*)(void*));
|
3968
|
+
SQLITE_API int sqlite3_bind_text16(sqlite3_stmt*, int, const void*, int, void(*)(void*));
|
3969
|
+
SQLITE_API int sqlite3_bind_text64(sqlite3_stmt*, int, const char*, sqlite3_uint64,
|
3566
3970
|
void(*)(void*), unsigned char encoding);
|
3567
|
-
SQLITE_API int
|
3568
|
-
SQLITE_API int
|
3569
|
-
SQLITE_API int
|
3971
|
+
SQLITE_API int sqlite3_bind_value(sqlite3_stmt*, int, const sqlite3_value*);
|
3972
|
+
SQLITE_API int sqlite3_bind_pointer(sqlite3_stmt*, int, void*, const char*,void(*)(void*));
|
3973
|
+
SQLITE_API int sqlite3_bind_zeroblob(sqlite3_stmt*, int, int n);
|
3974
|
+
SQLITE_API int sqlite3_bind_zeroblob64(sqlite3_stmt*, int, sqlite3_uint64);
|
3570
3975
|
|
3571
3976
|
/*
|
3572
3977
|
** CAPI3REF: Number Of SQL Parameters
|
@@ -3587,7 +3992,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_bind_zeroblob64(sqlite3_stmt*, int, sqlite
|
|
3587
3992
|
** [sqlite3_bind_parameter_name()], and
|
3588
3993
|
** [sqlite3_bind_parameter_index()].
|
3589
3994
|
*/
|
3590
|
-
SQLITE_API int
|
3995
|
+
SQLITE_API int sqlite3_bind_parameter_count(sqlite3_stmt*);
|
3591
3996
|
|
3592
3997
|
/*
|
3593
3998
|
** CAPI3REF: Name Of A Host Parameter
|
@@ -3608,14 +4013,14 @@ SQLITE_API int SQLITE_STDCALL sqlite3_bind_parameter_count(sqlite3_stmt*);
|
|
3608
4013
|
** ^If the value N is out of range or if the N-th parameter is
|
3609
4014
|
** nameless, then NULL is returned. ^The returned string is
|
3610
4015
|
** always in UTF-8 encoding even if the named parameter was
|
3611
|
-
** originally specified as UTF-16 in [sqlite3_prepare16()]
|
3612
|
-
** [sqlite3_prepare16_v2()].
|
4016
|
+
** originally specified as UTF-16 in [sqlite3_prepare16()],
|
4017
|
+
** [sqlite3_prepare16_v2()], or [sqlite3_prepare16_v3()].
|
3613
4018
|
**
|
3614
4019
|
** See also: [sqlite3_bind_blob|sqlite3_bind()],
|
3615
4020
|
** [sqlite3_bind_parameter_count()], and
|
3616
4021
|
** [sqlite3_bind_parameter_index()].
|
3617
4022
|
*/
|
3618
|
-
SQLITE_API const char *
|
4023
|
+
SQLITE_API const char *sqlite3_bind_parameter_name(sqlite3_stmt*, int);
|
3619
4024
|
|
3620
4025
|
/*
|
3621
4026
|
** CAPI3REF: Index Of A Parameter With A Given Name
|
@@ -3626,13 +4031,14 @@ SQLITE_API const char *SQLITE_STDCALL sqlite3_bind_parameter_name(sqlite3_stmt*,
|
|
3626
4031
|
** parameter to [sqlite3_bind_blob|sqlite3_bind()]. ^A zero
|
3627
4032
|
** is returned if no matching parameter is found. ^The parameter
|
3628
4033
|
** name must be given in UTF-8 even if the original statement
|
3629
|
-
** was prepared from UTF-16 text using [sqlite3_prepare16_v2()]
|
4034
|
+
** was prepared from UTF-16 text using [sqlite3_prepare16_v2()] or
|
4035
|
+
** [sqlite3_prepare16_v3()].
|
3630
4036
|
**
|
3631
4037
|
** See also: [sqlite3_bind_blob|sqlite3_bind()],
|
3632
4038
|
** [sqlite3_bind_parameter_count()], and
|
3633
4039
|
** [sqlite3_bind_parameter_name()].
|
3634
4040
|
*/
|
3635
|
-
SQLITE_API int
|
4041
|
+
SQLITE_API int sqlite3_bind_parameter_index(sqlite3_stmt*, const char *zName);
|
3636
4042
|
|
3637
4043
|
/*
|
3638
4044
|
** CAPI3REF: Reset All Bindings On A Prepared Statement
|
@@ -3642,19 +4048,23 @@ SQLITE_API int SQLITE_STDCALL sqlite3_bind_parameter_index(sqlite3_stmt*, const
|
|
3642
4048
|
** the [sqlite3_bind_blob | bindings] on a [prepared statement].
|
3643
4049
|
** ^Use this routine to reset all host parameters to NULL.
|
3644
4050
|
*/
|
3645
|
-
SQLITE_API int
|
4051
|
+
SQLITE_API int sqlite3_clear_bindings(sqlite3_stmt*);
|
3646
4052
|
|
3647
4053
|
/*
|
3648
4054
|
** CAPI3REF: Number Of Columns In A Result Set
|
3649
4055
|
** METHOD: sqlite3_stmt
|
3650
4056
|
**
|
3651
4057
|
** ^Return the number of columns in the result set returned by the
|
3652
|
-
** [prepared statement]. ^
|
3653
|
-
** statement
|
4058
|
+
** [prepared statement]. ^If this routine returns 0, that means the
|
4059
|
+
** [prepared statement] returns no data (for example an [UPDATE]).
|
4060
|
+
** ^However, just because this routine returns a positive number does not
|
4061
|
+
** mean that one or more rows of data will be returned. ^A SELECT statement
|
4062
|
+
** will always have a positive sqlite3_column_count() but depending on the
|
4063
|
+
** WHERE clause constraints and the table content, it might return no rows.
|
3654
4064
|
**
|
3655
4065
|
** See also: [sqlite3_data_count()]
|
3656
4066
|
*/
|
3657
|
-
SQLITE_API int
|
4067
|
+
SQLITE_API int sqlite3_column_count(sqlite3_stmt *pStmt);
|
3658
4068
|
|
3659
4069
|
/*
|
3660
4070
|
** CAPI3REF: Column Names In A Result Set
|
@@ -3683,8 +4093,8 @@ SQLITE_API int SQLITE_STDCALL sqlite3_column_count(sqlite3_stmt *pStmt);
|
|
3683
4093
|
** then the name of the column is unspecified and may change from
|
3684
4094
|
** one release of SQLite to the next.
|
3685
4095
|
*/
|
3686
|
-
SQLITE_API const char *
|
3687
|
-
SQLITE_API const void *
|
4096
|
+
SQLITE_API const char *sqlite3_column_name(sqlite3_stmt*, int N);
|
4097
|
+
SQLITE_API const void *sqlite3_column_name16(sqlite3_stmt*, int N);
|
3688
4098
|
|
3689
4099
|
/*
|
3690
4100
|
** CAPI3REF: Source Of Data In A Query Result
|
@@ -3732,12 +4142,12 @@ SQLITE_API const void *SQLITE_STDCALL sqlite3_column_name16(sqlite3_stmt*, int N
|
|
3732
4142
|
** for the same [prepared statement] and result column
|
3733
4143
|
** at the same time then the results are undefined.
|
3734
4144
|
*/
|
3735
|
-
SQLITE_API const char *
|
3736
|
-
SQLITE_API const void *
|
3737
|
-
SQLITE_API const char *
|
3738
|
-
SQLITE_API const void *
|
3739
|
-
SQLITE_API const char *
|
3740
|
-
SQLITE_API const void *
|
4145
|
+
SQLITE_API const char *sqlite3_column_database_name(sqlite3_stmt*,int);
|
4146
|
+
SQLITE_API const void *sqlite3_column_database_name16(sqlite3_stmt*,int);
|
4147
|
+
SQLITE_API const char *sqlite3_column_table_name(sqlite3_stmt*,int);
|
4148
|
+
SQLITE_API const void *sqlite3_column_table_name16(sqlite3_stmt*,int);
|
4149
|
+
SQLITE_API const char *sqlite3_column_origin_name(sqlite3_stmt*,int);
|
4150
|
+
SQLITE_API const void *sqlite3_column_origin_name16(sqlite3_stmt*,int);
|
3741
4151
|
|
3742
4152
|
/*
|
3743
4153
|
** CAPI3REF: Declared Datatype Of A Query Result
|
@@ -3769,23 +4179,25 @@ SQLITE_API const void *SQLITE_STDCALL sqlite3_column_origin_name16(sqlite3_stmt*
|
|
3769
4179
|
** is associated with individual values, not with the containers
|
3770
4180
|
** used to hold those values.
|
3771
4181
|
*/
|
3772
|
-
SQLITE_API const char *
|
3773
|
-
SQLITE_API const void *
|
4182
|
+
SQLITE_API const char *sqlite3_column_decltype(sqlite3_stmt*,int);
|
4183
|
+
SQLITE_API const void *sqlite3_column_decltype16(sqlite3_stmt*,int);
|
3774
4184
|
|
3775
4185
|
/*
|
3776
4186
|
** CAPI3REF: Evaluate An SQL Statement
|
3777
4187
|
** METHOD: sqlite3_stmt
|
3778
4188
|
**
|
3779
|
-
** After a [prepared statement] has been prepared using
|
3780
|
-
** [sqlite3_prepare_v2()]
|
4189
|
+
** After a [prepared statement] has been prepared using any of
|
4190
|
+
** [sqlite3_prepare_v2()], [sqlite3_prepare_v3()], [sqlite3_prepare16_v2()],
|
4191
|
+
** or [sqlite3_prepare16_v3()] or one of the legacy
|
3781
4192
|
** interfaces [sqlite3_prepare()] or [sqlite3_prepare16()], this function
|
3782
4193
|
** must be called one or more times to evaluate the statement.
|
3783
4194
|
**
|
3784
4195
|
** The details of the behavior of the sqlite3_step() interface depend
|
3785
|
-
** on whether the statement was prepared using the newer "
|
3786
|
-
** [sqlite3_prepare_v2()]
|
3787
|
-
**
|
3788
|
-
**
|
4196
|
+
** on whether the statement was prepared using the newer "vX" interfaces
|
4197
|
+
** [sqlite3_prepare_v3()], [sqlite3_prepare_v2()], [sqlite3_prepare16_v3()],
|
4198
|
+
** [sqlite3_prepare16_v2()] or the older legacy
|
4199
|
+
** interfaces [sqlite3_prepare()] and [sqlite3_prepare16()]. The use of the
|
4200
|
+
** new "vX" interface is recommended for new applications but the legacy
|
3789
4201
|
** interface will continue to be supported.
|
3790
4202
|
**
|
3791
4203
|
** ^In the legacy interface, the return value will be either [SQLITE_BUSY],
|
@@ -3831,7 +4243,8 @@ SQLITE_API const void *SQLITE_STDCALL sqlite3_column_decltype16(sqlite3_stmt*,in
|
|
3831
4243
|
** other than [SQLITE_ROW] before any subsequent invocation of
|
3832
4244
|
** sqlite3_step(). Failure to reset the prepared statement using
|
3833
4245
|
** [sqlite3_reset()] would result in an [SQLITE_MISUSE] return from
|
3834
|
-
** sqlite3_step(). But after version 3.6.23.1
|
4246
|
+
** sqlite3_step(). But after [version 3.6.23.1] ([dateof:3.6.23.1],
|
4247
|
+
** sqlite3_step() began
|
3835
4248
|
** calling [sqlite3_reset()] automatically in this circumstance rather
|
3836
4249
|
** than returning [SQLITE_MISUSE]. This is not considered a compatibility
|
3837
4250
|
** break because any application that ever receives an SQLITE_MISUSE error
|
@@ -3845,12 +4258,13 @@ SQLITE_API const void *SQLITE_STDCALL sqlite3_column_decltype16(sqlite3_stmt*,in
|
|
3845
4258
|
** specific [error codes] that better describes the error.
|
3846
4259
|
** We admit that this is a goofy design. The problem has been fixed
|
3847
4260
|
** with the "v2" interface. If you prepare all of your SQL statements
|
3848
|
-
** using
|
4261
|
+
** using [sqlite3_prepare_v3()] or [sqlite3_prepare_v2()]
|
4262
|
+
** or [sqlite3_prepare16_v2()] or [sqlite3_prepare16_v3()] instead
|
3849
4263
|
** of the legacy [sqlite3_prepare()] and [sqlite3_prepare16()] interfaces,
|
3850
4264
|
** then the more specific [error codes] are returned directly
|
3851
|
-
** by sqlite3_step(). The use of the "
|
4265
|
+
** by sqlite3_step(). The use of the "vX" interfaces is recommended.
|
3852
4266
|
*/
|
3853
|
-
SQLITE_API int
|
4267
|
+
SQLITE_API int sqlite3_step(sqlite3_stmt*);
|
3854
4268
|
|
3855
4269
|
/*
|
3856
4270
|
** CAPI3REF: Number of columns in a result set
|
@@ -3871,7 +4285,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_step(sqlite3_stmt*);
|
|
3871
4285
|
**
|
3872
4286
|
** See also: [sqlite3_column_count()]
|
3873
4287
|
*/
|
3874
|
-
SQLITE_API int
|
4288
|
+
SQLITE_API int sqlite3_data_count(sqlite3_stmt *pStmt);
|
3875
4289
|
|
3876
4290
|
/*
|
3877
4291
|
** CAPI3REF: Fundamental Datatypes
|
@@ -3910,6 +4324,28 @@ SQLITE_API int SQLITE_STDCALL sqlite3_data_count(sqlite3_stmt *pStmt);
|
|
3910
4324
|
** KEYWORDS: {column access functions}
|
3911
4325
|
** METHOD: sqlite3_stmt
|
3912
4326
|
**
|
4327
|
+
** <b>Summary:</b>
|
4328
|
+
** <blockquote><table border=0 cellpadding=0 cellspacing=0>
|
4329
|
+
** <tr><td><b>sqlite3_column_blob</b><td>→<td>BLOB result
|
4330
|
+
** <tr><td><b>sqlite3_column_double</b><td>→<td>REAL result
|
4331
|
+
** <tr><td><b>sqlite3_column_int</b><td>→<td>32-bit INTEGER result
|
4332
|
+
** <tr><td><b>sqlite3_column_int64</b><td>→<td>64-bit INTEGER result
|
4333
|
+
** <tr><td><b>sqlite3_column_text</b><td>→<td>UTF-8 TEXT result
|
4334
|
+
** <tr><td><b>sqlite3_column_text16</b><td>→<td>UTF-16 TEXT result
|
4335
|
+
** <tr><td><b>sqlite3_column_value</b><td>→<td>The result as an
|
4336
|
+
** [sqlite3_value|unprotected sqlite3_value] object.
|
4337
|
+
** <tr><td> <td> <td>
|
4338
|
+
** <tr><td><b>sqlite3_column_bytes</b><td>→<td>Size of a BLOB
|
4339
|
+
** or a UTF-8 TEXT result in bytes
|
4340
|
+
** <tr><td><b>sqlite3_column_bytes16 </b>
|
4341
|
+
** <td>→ <td>Size of UTF-16
|
4342
|
+
** TEXT in bytes
|
4343
|
+
** <tr><td><b>sqlite3_column_type</b><td>→<td>Default
|
4344
|
+
** datatype of the result
|
4345
|
+
** </table></blockquote>
|
4346
|
+
**
|
4347
|
+
** <b>Details:</b>
|
4348
|
+
**
|
3913
4349
|
** ^These routines return information about a single column of the current
|
3914
4350
|
** result row of a query. ^In every case the first argument is a pointer
|
3915
4351
|
** to the [prepared statement] that is being evaluated (the [sqlite3_stmt*]
|
@@ -3931,16 +4367,29 @@ SQLITE_API int SQLITE_STDCALL sqlite3_data_count(sqlite3_stmt *pStmt);
|
|
3931
4367
|
** are called from a different thread while any of these routines
|
3932
4368
|
** are pending, then the results are undefined.
|
3933
4369
|
**
|
4370
|
+
** The first six interfaces (_blob, _double, _int, _int64, _text, and _text16)
|
4371
|
+
** each return the value of a result column in a specific data format. If
|
4372
|
+
** the result column is not initially in the requested format (for example,
|
4373
|
+
** if the query returns an integer but the sqlite3_column_text() interface
|
4374
|
+
** is used to extract the value) then an automatic type conversion is performed.
|
4375
|
+
**
|
3934
4376
|
** ^The sqlite3_column_type() routine returns the
|
3935
4377
|
** [SQLITE_INTEGER | datatype code] for the initial data type
|
3936
4378
|
** of the result column. ^The returned value is one of [SQLITE_INTEGER],
|
3937
|
-
** [SQLITE_FLOAT], [SQLITE_TEXT], [SQLITE_BLOB], or [SQLITE_NULL].
|
3938
|
-
**
|
3939
|
-
**
|
3940
|
-
**
|
4379
|
+
** [SQLITE_FLOAT], [SQLITE_TEXT], [SQLITE_BLOB], or [SQLITE_NULL].
|
4380
|
+
** The return value of sqlite3_column_type() can be used to decide which
|
4381
|
+
** of the first six interface should be used to extract the column value.
|
4382
|
+
** The value returned by sqlite3_column_type() is only meaningful if no
|
4383
|
+
** automatic type conversions have occurred for the value in question.
|
4384
|
+
** After a type conversion, the result of calling sqlite3_column_type()
|
4385
|
+
** is undefined, though harmless. Future
|
3941
4386
|
** versions of SQLite may change the behavior of sqlite3_column_type()
|
3942
4387
|
** following a type conversion.
|
3943
4388
|
**
|
4389
|
+
** If the result is a BLOB or a TEXT string, then the sqlite3_column_bytes()
|
4390
|
+
** or sqlite3_column_bytes16() interfaces can be used to determine the size
|
4391
|
+
** of that BLOB or string.
|
4392
|
+
**
|
3944
4393
|
** ^If the result is a BLOB or UTF-8 string then the sqlite3_column_bytes()
|
3945
4394
|
** routine returns the number of bytes in that BLOB or string.
|
3946
4395
|
** ^If the result is a UTF-16 string, then sqlite3_column_bytes() converts
|
@@ -3977,9 +4426,13 @@ SQLITE_API int SQLITE_STDCALL sqlite3_data_count(sqlite3_stmt *pStmt);
|
|
3977
4426
|
** [sqlite3_column_value()] is used in any other way, including calls
|
3978
4427
|
** to routines like [sqlite3_value_int()], [sqlite3_value_text()],
|
3979
4428
|
** or [sqlite3_value_bytes()], the behavior is not threadsafe.
|
4429
|
+
** Hence, the sqlite3_column_value() interface
|
4430
|
+
** is normally only useful within the implementation of
|
4431
|
+
** [application-defined SQL functions] or [virtual tables], not within
|
4432
|
+
** top-level application code.
|
3980
4433
|
**
|
3981
|
-
**
|
3982
|
-
** example, if the internal representation is FLOAT and a text result
|
4434
|
+
** The these routines may attempt to convert the datatype of the result.
|
4435
|
+
** ^For example, if the internal representation is FLOAT and a text result
|
3983
4436
|
** is requested, [sqlite3_snprintf()] is used internally to perform the
|
3984
4437
|
** conversion automatically. ^(The following table details the conversions
|
3985
4438
|
** that are applied:
|
@@ -4051,7 +4504,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_data_count(sqlite3_stmt *pStmt);
|
|
4051
4504
|
** ^The pointers returned are valid until a type conversion occurs as
|
4052
4505
|
** described above, or until [sqlite3_step()] or [sqlite3_reset()] or
|
4053
4506
|
** [sqlite3_finalize()] is called. ^The memory space used to hold strings
|
4054
|
-
** and BLOBs is freed automatically. Do
|
4507
|
+
** and BLOBs is freed automatically. Do not pass the pointers returned
|
4055
4508
|
** from [sqlite3_column_blob()], [sqlite3_column_text()], etc. into
|
4056
4509
|
** [sqlite3_free()].
|
4057
4510
|
**
|
@@ -4061,16 +4514,16 @@ SQLITE_API int SQLITE_STDCALL sqlite3_data_count(sqlite3_stmt *pStmt);
|
|
4061
4514
|
** pointer. Subsequent calls to [sqlite3_errcode()] will return
|
4062
4515
|
** [SQLITE_NOMEM].)^
|
4063
4516
|
*/
|
4064
|
-
SQLITE_API const void *
|
4065
|
-
SQLITE_API
|
4066
|
-
SQLITE_API int
|
4067
|
-
SQLITE_API
|
4068
|
-
SQLITE_API
|
4069
|
-
SQLITE_API
|
4070
|
-
SQLITE_API
|
4071
|
-
SQLITE_API
|
4072
|
-
SQLITE_API int
|
4073
|
-
SQLITE_API
|
4517
|
+
SQLITE_API const void *sqlite3_column_blob(sqlite3_stmt*, int iCol);
|
4518
|
+
SQLITE_API double sqlite3_column_double(sqlite3_stmt*, int iCol);
|
4519
|
+
SQLITE_API int sqlite3_column_int(sqlite3_stmt*, int iCol);
|
4520
|
+
SQLITE_API sqlite3_int64 sqlite3_column_int64(sqlite3_stmt*, int iCol);
|
4521
|
+
SQLITE_API const unsigned char *sqlite3_column_text(sqlite3_stmt*, int iCol);
|
4522
|
+
SQLITE_API const void *sqlite3_column_text16(sqlite3_stmt*, int iCol);
|
4523
|
+
SQLITE_API sqlite3_value *sqlite3_column_value(sqlite3_stmt*, int iCol);
|
4524
|
+
SQLITE_API int sqlite3_column_bytes(sqlite3_stmt*, int iCol);
|
4525
|
+
SQLITE_API int sqlite3_column_bytes16(sqlite3_stmt*, int iCol);
|
4526
|
+
SQLITE_API int sqlite3_column_type(sqlite3_stmt*, int iCol);
|
4074
4527
|
|
4075
4528
|
/*
|
4076
4529
|
** CAPI3REF: Destroy A Prepared Statement Object
|
@@ -4098,7 +4551,7 @@ SQLITE_API sqlite3_value *SQLITE_STDCALL sqlite3_column_value(sqlite3_stmt*, int
|
|
4098
4551
|
** statement after it has been finalized can result in undefined and
|
4099
4552
|
** undesirable behavior such as segfaults and heap corruption.
|
4100
4553
|
*/
|
4101
|
-
SQLITE_API int
|
4554
|
+
SQLITE_API int sqlite3_finalize(sqlite3_stmt *pStmt);
|
4102
4555
|
|
4103
4556
|
/*
|
4104
4557
|
** CAPI3REF: Reset A Prepared Statement Object
|
@@ -4125,7 +4578,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_finalize(sqlite3_stmt *pStmt);
|
|
4125
4578
|
** ^The [sqlite3_reset(S)] interface does not change the values
|
4126
4579
|
** of any [sqlite3_bind_blob|bindings] on the [prepared statement] S.
|
4127
4580
|
*/
|
4128
|
-
SQLITE_API int
|
4581
|
+
SQLITE_API int sqlite3_reset(sqlite3_stmt *pStmt);
|
4129
4582
|
|
4130
4583
|
/*
|
4131
4584
|
** CAPI3REF: Create Or Redefine SQL Functions
|
@@ -4225,7 +4678,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_reset(sqlite3_stmt *pStmt);
|
|
4225
4678
|
** close the database connection nor finalize or reset the prepared
|
4226
4679
|
** statement in which the function is running.
|
4227
4680
|
*/
|
4228
|
-
SQLITE_API int
|
4681
|
+
SQLITE_API int sqlite3_create_function(
|
4229
4682
|
sqlite3 *db,
|
4230
4683
|
const char *zFunctionName,
|
4231
4684
|
int nArg,
|
@@ -4235,7 +4688,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_create_function(
|
|
4235
4688
|
void (*xStep)(sqlite3_context*,int,sqlite3_value**),
|
4236
4689
|
void (*xFinal)(sqlite3_context*)
|
4237
4690
|
);
|
4238
|
-
SQLITE_API int
|
4691
|
+
SQLITE_API int sqlite3_create_function16(
|
4239
4692
|
sqlite3 *db,
|
4240
4693
|
const void *zFunctionName,
|
4241
4694
|
int nArg,
|
@@ -4245,7 +4698,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_create_function16(
|
|
4245
4698
|
void (*xStep)(sqlite3_context*,int,sqlite3_value**),
|
4246
4699
|
void (*xFinal)(sqlite3_context*)
|
4247
4700
|
);
|
4248
|
-
SQLITE_API int
|
4701
|
+
SQLITE_API int sqlite3_create_function_v2(
|
4249
4702
|
sqlite3 *db,
|
4250
4703
|
const char *zFunctionName,
|
4251
4704
|
int nArg,
|
@@ -4291,12 +4744,12 @@ SQLITE_API int SQLITE_STDCALL sqlite3_create_function_v2(
|
|
4291
4744
|
** these functions, we will not explain what they do.
|
4292
4745
|
*/
|
4293
4746
|
#ifndef SQLITE_OMIT_DEPRECATED
|
4294
|
-
SQLITE_API SQLITE_DEPRECATED int
|
4295
|
-
SQLITE_API SQLITE_DEPRECATED int
|
4296
|
-
SQLITE_API SQLITE_DEPRECATED int
|
4297
|
-
SQLITE_API SQLITE_DEPRECATED int
|
4298
|
-
SQLITE_API SQLITE_DEPRECATED void
|
4299
|
-
SQLITE_API SQLITE_DEPRECATED int
|
4747
|
+
SQLITE_API SQLITE_DEPRECATED int sqlite3_aggregate_count(sqlite3_context*);
|
4748
|
+
SQLITE_API SQLITE_DEPRECATED int sqlite3_expired(sqlite3_stmt*);
|
4749
|
+
SQLITE_API SQLITE_DEPRECATED int sqlite3_transfer_bindings(sqlite3_stmt*, sqlite3_stmt*);
|
4750
|
+
SQLITE_API SQLITE_DEPRECATED int sqlite3_global_recover(void);
|
4751
|
+
SQLITE_API SQLITE_DEPRECATED void sqlite3_thread_cleanup(void);
|
4752
|
+
SQLITE_API SQLITE_DEPRECATED int sqlite3_memory_alarm(void(*)(void*,sqlite3_int64,int),
|
4300
4753
|
void*,sqlite3_int64);
|
4301
4754
|
#endif
|
4302
4755
|
|
@@ -4304,21 +4757,40 @@ SQLITE_API SQLITE_DEPRECATED int SQLITE_STDCALL sqlite3_memory_alarm(void(*)(voi
|
|
4304
4757
|
** CAPI3REF: Obtaining SQL Values
|
4305
4758
|
** METHOD: sqlite3_value
|
4306
4759
|
**
|
4307
|
-
**
|
4308
|
-
**
|
4309
|
-
**
|
4310
|
-
**
|
4311
|
-
**
|
4312
|
-
**
|
4313
|
-
**
|
4314
|
-
**
|
4315
|
-
**
|
4316
|
-
**
|
4317
|
-
**
|
4760
|
+
** <b>Summary:</b>
|
4761
|
+
** <blockquote><table border=0 cellpadding=0 cellspacing=0>
|
4762
|
+
** <tr><td><b>sqlite3_value_blob</b><td>→<td>BLOB value
|
4763
|
+
** <tr><td><b>sqlite3_value_double</b><td>→<td>REAL value
|
4764
|
+
** <tr><td><b>sqlite3_value_int</b><td>→<td>32-bit INTEGER value
|
4765
|
+
** <tr><td><b>sqlite3_value_int64</b><td>→<td>64-bit INTEGER value
|
4766
|
+
** <tr><td><b>sqlite3_value_pointer</b><td>→<td>Pointer value
|
4767
|
+
** <tr><td><b>sqlite3_value_text</b><td>→<td>UTF-8 TEXT value
|
4768
|
+
** <tr><td><b>sqlite3_value_text16</b><td>→<td>UTF-16 TEXT value in
|
4769
|
+
** the native byteorder
|
4770
|
+
** <tr><td><b>sqlite3_value_text16be</b><td>→<td>UTF-16be TEXT value
|
4771
|
+
** <tr><td><b>sqlite3_value_text16le</b><td>→<td>UTF-16le TEXT value
|
4772
|
+
** <tr><td> <td> <td>
|
4773
|
+
** <tr><td><b>sqlite3_value_bytes</b><td>→<td>Size of a BLOB
|
4774
|
+
** or a UTF-8 TEXT in bytes
|
4775
|
+
** <tr><td><b>sqlite3_value_bytes16 </b>
|
4776
|
+
** <td>→ <td>Size of UTF-16
|
4777
|
+
** TEXT in bytes
|
4778
|
+
** <tr><td><b>sqlite3_value_type</b><td>→<td>Default
|
4779
|
+
** datatype of the value
|
4780
|
+
** <tr><td><b>sqlite3_value_numeric_type </b>
|
4781
|
+
** <td>→ <td>Best numeric datatype of the value
|
4782
|
+
** </table></blockquote>
|
4783
|
+
**
|
4784
|
+
** <b>Details:</b>
|
4785
|
+
**
|
4786
|
+
** These routines extract type, size, and content information from
|
4787
|
+
** [protected sqlite3_value] objects. Protected sqlite3_value objects
|
4788
|
+
** are used to pass parameter information into implementation of
|
4789
|
+
** [application-defined SQL functions] and [virtual tables].
|
4318
4790
|
**
|
4319
4791
|
** These routines work only with [protected sqlite3_value] objects.
|
4320
4792
|
** Any attempt to use these routines on an [unprotected sqlite3_value]
|
4321
|
-
**
|
4793
|
+
** is not threadsafe.
|
4322
4794
|
**
|
4323
4795
|
** ^These routines work just like the corresponding [column access functions]
|
4324
4796
|
** except that these routines take a single [protected sqlite3_value] object
|
@@ -4329,6 +4801,24 @@ SQLITE_API SQLITE_DEPRECATED int SQLITE_STDCALL sqlite3_memory_alarm(void(*)(voi
|
|
4329
4801
|
** sqlite3_value_text16be() and sqlite3_value_text16le() interfaces
|
4330
4802
|
** extract UTF-16 strings as big-endian and little-endian respectively.
|
4331
4803
|
**
|
4804
|
+
** ^If [sqlite3_value] object V was initialized
|
4805
|
+
** using [sqlite3_bind_pointer(S,I,P,X,D)] or [sqlite3_result_pointer(C,P,X,D)]
|
4806
|
+
** and if X and Y are strings that compare equal according to strcmp(X,Y),
|
4807
|
+
** then sqlite3_value_pointer(V,Y) will return the pointer P. ^Otherwise,
|
4808
|
+
** sqlite3_value_pointer(V,Y) returns a NULL. The sqlite3_bind_pointer()
|
4809
|
+
** routine is part of the [pointer passing interface] added for SQLite 3.20.0.
|
4810
|
+
**
|
4811
|
+
** ^(The sqlite3_value_type(V) interface returns the
|
4812
|
+
** [SQLITE_INTEGER | datatype code] for the initial datatype of the
|
4813
|
+
** [sqlite3_value] object V. The returned value is one of [SQLITE_INTEGER],
|
4814
|
+
** [SQLITE_FLOAT], [SQLITE_TEXT], [SQLITE_BLOB], or [SQLITE_NULL].)^
|
4815
|
+
** Other interfaces might change the datatype for an sqlite3_value object.
|
4816
|
+
** For example, if the datatype is initially SQLITE_INTEGER and
|
4817
|
+
** sqlite3_value_text(V) is called to extract a text value for that
|
4818
|
+
** integer, then subsequent calls to sqlite3_value_type(V) might return
|
4819
|
+
** SQLITE_TEXT. Whether or not a persistent internal datatype conversion
|
4820
|
+
** occurs is undefined and may change from one release of SQLite to the next.
|
4821
|
+
**
|
4332
4822
|
** ^(The sqlite3_value_numeric_type() interface attempts to apply
|
4333
4823
|
** numeric affinity to the value. This means that an attempt is
|
4334
4824
|
** made to convert the value to an integer or floating point. If
|
@@ -4346,18 +4836,19 @@ SQLITE_API SQLITE_DEPRECATED int SQLITE_STDCALL sqlite3_memory_alarm(void(*)(voi
|
|
4346
4836
|
** These routines must be called from the same thread as
|
4347
4837
|
** the SQL function that supplied the [sqlite3_value*] parameters.
|
4348
4838
|
*/
|
4349
|
-
SQLITE_API const void *
|
4350
|
-
SQLITE_API
|
4351
|
-
SQLITE_API int
|
4352
|
-
SQLITE_API
|
4353
|
-
SQLITE_API
|
4354
|
-
SQLITE_API
|
4355
|
-
SQLITE_API const
|
4356
|
-
SQLITE_API const void *
|
4357
|
-
SQLITE_API const void *
|
4358
|
-
SQLITE_API
|
4359
|
-
SQLITE_API int
|
4360
|
-
SQLITE_API int
|
4839
|
+
SQLITE_API const void *sqlite3_value_blob(sqlite3_value*);
|
4840
|
+
SQLITE_API double sqlite3_value_double(sqlite3_value*);
|
4841
|
+
SQLITE_API int sqlite3_value_int(sqlite3_value*);
|
4842
|
+
SQLITE_API sqlite3_int64 sqlite3_value_int64(sqlite3_value*);
|
4843
|
+
SQLITE_API void *sqlite3_value_pointer(sqlite3_value*, const char*);
|
4844
|
+
SQLITE_API const unsigned char *sqlite3_value_text(sqlite3_value*);
|
4845
|
+
SQLITE_API const void *sqlite3_value_text16(sqlite3_value*);
|
4846
|
+
SQLITE_API const void *sqlite3_value_text16le(sqlite3_value*);
|
4847
|
+
SQLITE_API const void *sqlite3_value_text16be(sqlite3_value*);
|
4848
|
+
SQLITE_API int sqlite3_value_bytes(sqlite3_value*);
|
4849
|
+
SQLITE_API int sqlite3_value_bytes16(sqlite3_value*);
|
4850
|
+
SQLITE_API int sqlite3_value_type(sqlite3_value*);
|
4851
|
+
SQLITE_API int sqlite3_value_numeric_type(sqlite3_value*);
|
4361
4852
|
|
4362
4853
|
/*
|
4363
4854
|
** CAPI3REF: Finding The Subtype Of SQL Values
|
@@ -4368,12 +4859,8 @@ SQLITE_API int SQLITE_STDCALL sqlite3_value_numeric_type(sqlite3_value*);
|
|
4368
4859
|
** information can be used to pass a limited amount of context from
|
4369
4860
|
** one SQL function to another. Use the [sqlite3_result_subtype()]
|
4370
4861
|
** routine to set the subtype for the return value of an SQL function.
|
4371
|
-
**
|
4372
|
-
** SQLite makes no use of subtype itself. It merely passes the subtype
|
4373
|
-
** from the result of one [application-defined SQL function] into the
|
4374
|
-
** input of another.
|
4375
4862
|
*/
|
4376
|
-
SQLITE_API unsigned int
|
4863
|
+
SQLITE_API unsigned int sqlite3_value_subtype(sqlite3_value*);
|
4377
4864
|
|
4378
4865
|
/*
|
4379
4866
|
** CAPI3REF: Copy And Free SQL Values
|
@@ -4389,8 +4876,8 @@ SQLITE_API unsigned int SQLITE_STDCALL sqlite3_value_subtype(sqlite3_value*);
|
|
4389
4876
|
** previously obtained from [sqlite3_value_dup()]. ^If V is a NULL pointer
|
4390
4877
|
** then sqlite3_value_free(V) is a harmless no-op.
|
4391
4878
|
*/
|
4392
|
-
SQLITE_API
|
4393
|
-
SQLITE_API
|
4879
|
+
SQLITE_API sqlite3_value *sqlite3_value_dup(const sqlite3_value*);
|
4880
|
+
SQLITE_API void sqlite3_value_free(sqlite3_value*);
|
4394
4881
|
|
4395
4882
|
/*
|
4396
4883
|
** CAPI3REF: Obtain Aggregate Function Context
|
@@ -4435,7 +4922,7 @@ SQLITE_API SQLITE_EXPERIMENTAL void SQLITE_STDCALL sqlite3_value_free(sqlite3_va
|
|
4435
4922
|
** This routine must be called from the same thread in which
|
4436
4923
|
** the aggregate SQL function is running.
|
4437
4924
|
*/
|
4438
|
-
SQLITE_API void *
|
4925
|
+
SQLITE_API void *sqlite3_aggregate_context(sqlite3_context*, int nBytes);
|
4439
4926
|
|
4440
4927
|
/*
|
4441
4928
|
** CAPI3REF: User Data For Functions
|
@@ -4450,7 +4937,7 @@ SQLITE_API void *SQLITE_STDCALL sqlite3_aggregate_context(sqlite3_context*, int
|
|
4450
4937
|
** This routine must be called from the same thread in which
|
4451
4938
|
** the application-defined function is running.
|
4452
4939
|
*/
|
4453
|
-
SQLITE_API void *
|
4940
|
+
SQLITE_API void *sqlite3_user_data(sqlite3_context*);
|
4454
4941
|
|
4455
4942
|
/*
|
4456
4943
|
** CAPI3REF: Database Connection For Functions
|
@@ -4462,7 +4949,7 @@ SQLITE_API void *SQLITE_STDCALL sqlite3_user_data(sqlite3_context*);
|
|
4462
4949
|
** and [sqlite3_create_function16()] routines that originally
|
4463
4950
|
** registered the application defined function.
|
4464
4951
|
*/
|
4465
|
-
SQLITE_API sqlite3 *
|
4952
|
+
SQLITE_API sqlite3 *sqlite3_context_db_handle(sqlite3_context*);
|
4466
4953
|
|
4467
4954
|
/*
|
4468
4955
|
** CAPI3REF: Function Auxiliary Data
|
@@ -4479,10 +4966,11 @@ SQLITE_API sqlite3 *SQLITE_STDCALL sqlite3_context_db_handle(sqlite3_context*);
|
|
4479
4966
|
** the compiled regular expression can be reused on multiple
|
4480
4967
|
** invocations of the same function.
|
4481
4968
|
**
|
4482
|
-
** ^The sqlite3_get_auxdata() interface returns a pointer to the metadata
|
4483
|
-
** associated by the sqlite3_set_auxdata() function with the Nth argument
|
4484
|
-
** value to the application-defined function.
|
4485
|
-
**
|
4969
|
+
** ^The sqlite3_get_auxdata(C,N) interface returns a pointer to the metadata
|
4970
|
+
** associated by the sqlite3_set_auxdata(C,N,P,X) function with the Nth argument
|
4971
|
+
** value to the application-defined function. ^N is zero for the left-most
|
4972
|
+
** function argument. ^If there is no metadata
|
4973
|
+
** associated with the function argument, the sqlite3_get_auxdata(C,N) interface
|
4486
4974
|
** returns a NULL pointer.
|
4487
4975
|
**
|
4488
4976
|
** ^The sqlite3_set_auxdata(C,N,P,X) interface saves P as metadata for the N-th
|
@@ -4494,12 +4982,13 @@ SQLITE_API sqlite3 *SQLITE_STDCALL sqlite3_context_db_handle(sqlite3_context*);
|
|
4494
4982
|
** SQLite will invoke the destructor function X with parameter P exactly
|
4495
4983
|
** once, when the metadata is discarded.
|
4496
4984
|
** SQLite is free to discard the metadata at any time, including: <ul>
|
4497
|
-
** <li> when the corresponding function parameter changes
|
4498
|
-
** <li> when [sqlite3_reset()] or [sqlite3_finalize()] is called for the
|
4499
|
-
** SQL statement
|
4500
|
-
** <li> when sqlite3_set_auxdata() is invoked again on the same
|
4501
|
-
**
|
4502
|
-
**
|
4985
|
+
** <li> ^(when the corresponding function parameter changes)^, or
|
4986
|
+
** <li> ^(when [sqlite3_reset()] or [sqlite3_finalize()] is called for the
|
4987
|
+
** SQL statement)^, or
|
4988
|
+
** <li> ^(when sqlite3_set_auxdata() is invoked again on the same
|
4989
|
+
** parameter)^, or
|
4990
|
+
** <li> ^(during the original sqlite3_set_auxdata() call when a memory
|
4991
|
+
** allocation error occurs.)^ </ul>
|
4503
4992
|
**
|
4504
4993
|
** Note the last bullet in particular. The destructor X in
|
4505
4994
|
** sqlite3_set_auxdata(C,N,P,X) might be called immediately, before the
|
@@ -4512,11 +5001,15 @@ SQLITE_API sqlite3 *SQLITE_STDCALL sqlite3_context_db_handle(sqlite3_context*);
|
|
4512
5001
|
** function parameters that are compile-time constants, including literal
|
4513
5002
|
** values and [parameters] and expressions composed from the same.)^
|
4514
5003
|
**
|
5004
|
+
** The value of the N parameter to these interfaces should be non-negative.
|
5005
|
+
** Future enhancements may make use of negative N values to define new
|
5006
|
+
** kinds of function caching behavior.
|
5007
|
+
**
|
4515
5008
|
** These routines must be called from the same thread in which
|
4516
5009
|
** the SQL function is running.
|
4517
5010
|
*/
|
4518
|
-
SQLITE_API void *
|
4519
|
-
SQLITE_API void
|
5011
|
+
SQLITE_API void *sqlite3_get_auxdata(sqlite3_context*, int N);
|
5012
|
+
SQLITE_API void sqlite3_set_auxdata(sqlite3_context*, int N, void*, void (*)(void*));
|
4520
5013
|
|
4521
5014
|
|
4522
5015
|
/*
|
@@ -4635,7 +5128,7 @@ typedef void (*sqlite3_destructor_type)(void*);
|
|
4635
5128
|
** when it has finished using that result.
|
4636
5129
|
** ^If the 4th parameter to the sqlite3_result_text* interfaces
|
4637
5130
|
** or sqlite3_result_blob is the special constant SQLITE_TRANSIENT
|
4638
|
-
** then SQLite makes a copy of the result into space obtained
|
5131
|
+
** then SQLite makes a copy of the result into space obtained
|
4639
5132
|
** from [sqlite3_malloc()] before it returns.
|
4640
5133
|
**
|
4641
5134
|
** ^The sqlite3_result_value() interface sets the result of
|
@@ -4648,31 +5141,43 @@ typedef void (*sqlite3_destructor_type)(void*);
|
|
4648
5141
|
** [unprotected sqlite3_value] object is required, so either
|
4649
5142
|
** kind of [sqlite3_value] object can be used with this interface.
|
4650
5143
|
**
|
5144
|
+
** ^The sqlite3_result_pointer(C,P,T,D) interface sets the result to an
|
5145
|
+
** SQL NULL value, just like [sqlite3_result_null(C)], except that it
|
5146
|
+
** also associates the host-language pointer P or type T with that
|
5147
|
+
** NULL value such that the pointer can be retrieved within an
|
5148
|
+
** [application-defined SQL function] using [sqlite3_value_pointer()].
|
5149
|
+
** ^If the D parameter is not NULL, then it is a pointer to a destructor
|
5150
|
+
** for the P parameter. ^SQLite invokes D with P as its only argument
|
5151
|
+
** when SQLite is finished with P. The T parameter should be a static
|
5152
|
+
** string and preferably a string literal. The sqlite3_result_pointer()
|
5153
|
+
** routine is part of the [pointer passing interface] added for SQLite 3.20.0.
|
5154
|
+
**
|
4651
5155
|
** If these routines are called from within the different thread
|
4652
5156
|
** than the one containing the application-defined function that received
|
4653
5157
|
** the [sqlite3_context] pointer, the results are undefined.
|
4654
5158
|
*/
|
4655
|
-
SQLITE_API void
|
4656
|
-
SQLITE_API void
|
5159
|
+
SQLITE_API void sqlite3_result_blob(sqlite3_context*, const void*, int, void(*)(void*));
|
5160
|
+
SQLITE_API void sqlite3_result_blob64(sqlite3_context*,const void*,
|
4657
5161
|
sqlite3_uint64,void(*)(void*));
|
4658
|
-
SQLITE_API void
|
4659
|
-
SQLITE_API void
|
4660
|
-
SQLITE_API void
|
4661
|
-
SQLITE_API void
|
4662
|
-
SQLITE_API void
|
4663
|
-
SQLITE_API void
|
4664
|
-
SQLITE_API void
|
4665
|
-
SQLITE_API void
|
4666
|
-
SQLITE_API void
|
4667
|
-
SQLITE_API void
|
4668
|
-
SQLITE_API void
|
5162
|
+
SQLITE_API void sqlite3_result_double(sqlite3_context*, double);
|
5163
|
+
SQLITE_API void sqlite3_result_error(sqlite3_context*, const char*, int);
|
5164
|
+
SQLITE_API void sqlite3_result_error16(sqlite3_context*, const void*, int);
|
5165
|
+
SQLITE_API void sqlite3_result_error_toobig(sqlite3_context*);
|
5166
|
+
SQLITE_API void sqlite3_result_error_nomem(sqlite3_context*);
|
5167
|
+
SQLITE_API void sqlite3_result_error_code(sqlite3_context*, int);
|
5168
|
+
SQLITE_API void sqlite3_result_int(sqlite3_context*, int);
|
5169
|
+
SQLITE_API void sqlite3_result_int64(sqlite3_context*, sqlite3_int64);
|
5170
|
+
SQLITE_API void sqlite3_result_null(sqlite3_context*);
|
5171
|
+
SQLITE_API void sqlite3_result_text(sqlite3_context*, const char*, int, void(*)(void*));
|
5172
|
+
SQLITE_API void sqlite3_result_text64(sqlite3_context*, const char*,sqlite3_uint64,
|
4669
5173
|
void(*)(void*), unsigned char encoding);
|
4670
|
-
SQLITE_API void
|
4671
|
-
SQLITE_API void
|
4672
|
-
SQLITE_API void
|
4673
|
-
SQLITE_API void
|
4674
|
-
SQLITE_API void
|
4675
|
-
SQLITE_API
|
5174
|
+
SQLITE_API void sqlite3_result_text16(sqlite3_context*, const void*, int, void(*)(void*));
|
5175
|
+
SQLITE_API void sqlite3_result_text16le(sqlite3_context*, const void*, int,void(*)(void*));
|
5176
|
+
SQLITE_API void sqlite3_result_text16be(sqlite3_context*, const void*, int,void(*)(void*));
|
5177
|
+
SQLITE_API void sqlite3_result_value(sqlite3_context*, sqlite3_value*);
|
5178
|
+
SQLITE_API void sqlite3_result_pointer(sqlite3_context*, void*,const char*,void(*)(void*));
|
5179
|
+
SQLITE_API void sqlite3_result_zeroblob(sqlite3_context*, int n);
|
5180
|
+
SQLITE_API int sqlite3_result_zeroblob64(sqlite3_context*, sqlite3_uint64 n);
|
4676
5181
|
|
4677
5182
|
|
4678
5183
|
/*
|
@@ -4687,7 +5192,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_result_zeroblob64(sqlite3_context*, sqlite
|
|
4687
5192
|
** The number of subtype bytes preserved by SQLite might increase
|
4688
5193
|
** in future releases of SQLite.
|
4689
5194
|
*/
|
4690
|
-
SQLITE_API void
|
5195
|
+
SQLITE_API void sqlite3_result_subtype(sqlite3_context*,unsigned int);
|
4691
5196
|
|
4692
5197
|
/*
|
4693
5198
|
** CAPI3REF: Define New Collating Sequences
|
@@ -4769,14 +5274,14 @@ SQLITE_API void SQLITE_STDCALL sqlite3_result_subtype(sqlite3_context*,unsigned
|
|
4769
5274
|
**
|
4770
5275
|
** See also: [sqlite3_collation_needed()] and [sqlite3_collation_needed16()].
|
4771
5276
|
*/
|
4772
|
-
SQLITE_API int
|
5277
|
+
SQLITE_API int sqlite3_create_collation(
|
4773
5278
|
sqlite3*,
|
4774
5279
|
const char *zName,
|
4775
5280
|
int eTextRep,
|
4776
5281
|
void *pArg,
|
4777
5282
|
int(*xCompare)(void*,int,const void*,int,const void*)
|
4778
5283
|
);
|
4779
|
-
SQLITE_API int
|
5284
|
+
SQLITE_API int sqlite3_create_collation_v2(
|
4780
5285
|
sqlite3*,
|
4781
5286
|
const char *zName,
|
4782
5287
|
int eTextRep,
|
@@ -4784,7 +5289,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_create_collation_v2(
|
|
4784
5289
|
int(*xCompare)(void*,int,const void*,int,const void*),
|
4785
5290
|
void(*xDestroy)(void*)
|
4786
5291
|
);
|
4787
|
-
SQLITE_API int
|
5292
|
+
SQLITE_API int sqlite3_create_collation16(
|
4788
5293
|
sqlite3*,
|
4789
5294
|
const void *zName,
|
4790
5295
|
int eTextRep,
|
@@ -4819,12 +5324,12 @@ SQLITE_API int SQLITE_STDCALL sqlite3_create_collation16(
|
|
4819
5324
|
** [sqlite3_create_collation()], [sqlite3_create_collation16()], or
|
4820
5325
|
** [sqlite3_create_collation_v2()].
|
4821
5326
|
*/
|
4822
|
-
SQLITE_API int
|
5327
|
+
SQLITE_API int sqlite3_collation_needed(
|
4823
5328
|
sqlite3*,
|
4824
5329
|
void*,
|
4825
5330
|
void(*)(void*,sqlite3*,int eTextRep,const char*)
|
4826
5331
|
);
|
4827
|
-
SQLITE_API int
|
5332
|
+
SQLITE_API int sqlite3_collation_needed16(
|
4828
5333
|
sqlite3*,
|
4829
5334
|
void*,
|
4830
5335
|
void(*)(void*,sqlite3*,int eTextRep,const void*)
|
@@ -4838,11 +5343,11 @@ SQLITE_API int SQLITE_STDCALL sqlite3_collation_needed16(
|
|
4838
5343
|
** The code to implement this API is not available in the public release
|
4839
5344
|
** of SQLite.
|
4840
5345
|
*/
|
4841
|
-
SQLITE_API int
|
5346
|
+
SQLITE_API int sqlite3_key(
|
4842
5347
|
sqlite3 *db, /* Database to be rekeyed */
|
4843
5348
|
const void *pKey, int nKey /* The key */
|
4844
5349
|
);
|
4845
|
-
SQLITE_API int
|
5350
|
+
SQLITE_API int sqlite3_key_v2(
|
4846
5351
|
sqlite3 *db, /* Database to be rekeyed */
|
4847
5352
|
const char *zDbName, /* Name of the database */
|
4848
5353
|
const void *pKey, int nKey /* The key */
|
@@ -4856,11 +5361,11 @@ SQLITE_API int SQLITE_STDCALL sqlite3_key_v2(
|
|
4856
5361
|
** The code to implement this API is not available in the public release
|
4857
5362
|
** of SQLite.
|
4858
5363
|
*/
|
4859
|
-
SQLITE_API int
|
5364
|
+
SQLITE_API int sqlite3_rekey(
|
4860
5365
|
sqlite3 *db, /* Database to be rekeyed */
|
4861
5366
|
const void *pKey, int nKey /* The new key */
|
4862
5367
|
);
|
4863
|
-
SQLITE_API int
|
5368
|
+
SQLITE_API int sqlite3_rekey_v2(
|
4864
5369
|
sqlite3 *db, /* Database to be rekeyed */
|
4865
5370
|
const char *zDbName, /* Name of the database */
|
4866
5371
|
const void *pKey, int nKey /* The new key */
|
@@ -4870,7 +5375,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_rekey_v2(
|
|
4870
5375
|
** Specify the activation key for a SEE database. Unless
|
4871
5376
|
** activated, none of the SEE routines will work.
|
4872
5377
|
*/
|
4873
|
-
SQLITE_API void
|
5378
|
+
SQLITE_API void sqlite3_activate_see(
|
4874
5379
|
const char *zPassPhrase /* Activation phrase */
|
4875
5380
|
);
|
4876
5381
|
#endif
|
@@ -4880,7 +5385,7 @@ SQLITE_API void SQLITE_STDCALL sqlite3_activate_see(
|
|
4880
5385
|
** Specify the activation key for a CEROD database. Unless
|
4881
5386
|
** activated, none of the CEROD routines will work.
|
4882
5387
|
*/
|
4883
|
-
SQLITE_API void
|
5388
|
+
SQLITE_API void sqlite3_activate_cerod(
|
4884
5389
|
const char *zPassPhrase /* Activation phrase */
|
4885
5390
|
);
|
4886
5391
|
#endif
|
@@ -4902,7 +5407,7 @@ SQLITE_API void SQLITE_STDCALL sqlite3_activate_cerod(
|
|
4902
5407
|
** all, then the behavior of sqlite3_sleep() may deviate from the description
|
4903
5408
|
** in the previous paragraphs.
|
4904
5409
|
*/
|
4905
|
-
SQLITE_API int
|
5410
|
+
SQLITE_API int sqlite3_sleep(int);
|
4906
5411
|
|
4907
5412
|
/*
|
4908
5413
|
** CAPI3REF: Name Of The Folder Holding Temporary Files
|
@@ -5021,7 +5526,7 @@ SQLITE_API SQLITE_EXTERN char *sqlite3_data_directory;
|
|
5021
5526
|
** connection while this routine is running, then the return value
|
5022
5527
|
** is undefined.
|
5023
5528
|
*/
|
5024
|
-
SQLITE_API int
|
5529
|
+
SQLITE_API int sqlite3_get_autocommit(sqlite3*);
|
5025
5530
|
|
5026
5531
|
/*
|
5027
5532
|
** CAPI3REF: Find The Database Handle Of A Prepared Statement
|
@@ -5034,7 +5539,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_get_autocommit(sqlite3*);
|
|
5034
5539
|
** to the [sqlite3_prepare_v2()] call (or its variants) that was used to
|
5035
5540
|
** create the statement in the first place.
|
5036
5541
|
*/
|
5037
|
-
SQLITE_API sqlite3 *
|
5542
|
+
SQLITE_API sqlite3 *sqlite3_db_handle(sqlite3_stmt*);
|
5038
5543
|
|
5039
5544
|
/*
|
5040
5545
|
** CAPI3REF: Return The Filename For A Database Connection
|
@@ -5051,7 +5556,7 @@ SQLITE_API sqlite3 *SQLITE_STDCALL sqlite3_db_handle(sqlite3_stmt*);
|
|
5051
5556
|
** will be an absolute pathname, even if the filename used
|
5052
5557
|
** to open the database originally was a URI or relative pathname.
|
5053
5558
|
*/
|
5054
|
-
SQLITE_API const char *
|
5559
|
+
SQLITE_API const char *sqlite3_db_filename(sqlite3 *db, const char *zDbName);
|
5055
5560
|
|
5056
5561
|
/*
|
5057
5562
|
** CAPI3REF: Determine if a database is read-only
|
@@ -5061,7 +5566,7 @@ SQLITE_API const char *SQLITE_STDCALL sqlite3_db_filename(sqlite3 *db, const cha
|
|
5061
5566
|
** of connection D is read-only, 0 if it is read/write, or -1 if N is not
|
5062
5567
|
** the name of a database on connection D.
|
5063
5568
|
*/
|
5064
|
-
SQLITE_API int
|
5569
|
+
SQLITE_API int sqlite3_db_readonly(sqlite3 *db, const char *zDbName);
|
5065
5570
|
|
5066
5571
|
/*
|
5067
5572
|
** CAPI3REF: Find the next prepared statement
|
@@ -5077,7 +5582,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_db_readonly(sqlite3 *db, const char *zDbNa
|
|
5077
5582
|
** [sqlite3_next_stmt(D,S)] must refer to an open database
|
5078
5583
|
** connection and in particular must not be a NULL pointer.
|
5079
5584
|
*/
|
5080
|
-
SQLITE_API sqlite3_stmt *
|
5585
|
+
SQLITE_API sqlite3_stmt *sqlite3_next_stmt(sqlite3 *pDb, sqlite3_stmt *pStmt);
|
5081
5586
|
|
5082
5587
|
/*
|
5083
5588
|
** CAPI3REF: Commit And Rollback Notification Callbacks
|
@@ -5126,8 +5631,8 @@ SQLITE_API sqlite3_stmt *SQLITE_STDCALL sqlite3_next_stmt(sqlite3 *pDb, sqlite3_
|
|
5126
5631
|
**
|
5127
5632
|
** See also the [sqlite3_update_hook()] interface.
|
5128
5633
|
*/
|
5129
|
-
SQLITE_API void *
|
5130
|
-
SQLITE_API void *
|
5634
|
+
SQLITE_API void *sqlite3_commit_hook(sqlite3*, int(*)(void*), void*);
|
5635
|
+
SQLITE_API void *sqlite3_rollback_hook(sqlite3*, void(*)(void *), void*);
|
5131
5636
|
|
5132
5637
|
/*
|
5133
5638
|
** CAPI3REF: Data Change Notification Callbacks
|
@@ -5136,7 +5641,7 @@ SQLITE_API void *SQLITE_STDCALL sqlite3_rollback_hook(sqlite3*, void(*)(void *),
|
|
5136
5641
|
** ^The sqlite3_update_hook() interface registers a callback function
|
5137
5642
|
** with the [database connection] identified by the first argument
|
5138
5643
|
** to be invoked whenever a row is updated, inserted or deleted in
|
5139
|
-
** a rowid table.
|
5644
|
+
** a [rowid table].
|
5140
5645
|
** ^Any callback set by a previous call to this function
|
5141
5646
|
** for the same database connection is overridden.
|
5142
5647
|
**
|
@@ -5157,7 +5662,7 @@ SQLITE_API void *SQLITE_STDCALL sqlite3_rollback_hook(sqlite3*, void(*)(void *),
|
|
5157
5662
|
** ^The update hook is not invoked when [WITHOUT ROWID] tables are modified.
|
5158
5663
|
**
|
5159
5664
|
** ^In the current implementation, the update hook
|
5160
|
-
** is not invoked when
|
5665
|
+
** is not invoked when conflicting rows are deleted because of an
|
5161
5666
|
** [ON CONFLICT | ON CONFLICT REPLACE] clause. ^Nor is the update hook
|
5162
5667
|
** invoked when rows are deleted using the [truncate optimization].
|
5163
5668
|
** The exceptions defined in this paragraph might change in a future
|
@@ -5175,10 +5680,10 @@ SQLITE_API void *SQLITE_STDCALL sqlite3_rollback_hook(sqlite3*, void(*)(void *),
|
|
5175
5680
|
** on the same [database connection] D, or NULL for
|
5176
5681
|
** the first call on D.
|
5177
5682
|
**
|
5178
|
-
** See also the [sqlite3_commit_hook()]
|
5179
|
-
** interfaces.
|
5683
|
+
** See also the [sqlite3_commit_hook()], [sqlite3_rollback_hook()],
|
5684
|
+
** and [sqlite3_preupdate_hook()] interfaces.
|
5180
5685
|
*/
|
5181
|
-
SQLITE_API void *
|
5686
|
+
SQLITE_API void *sqlite3_update_hook(
|
5182
5687
|
sqlite3*,
|
5183
5688
|
void(*)(void *,int ,char const *,char const *,sqlite3_int64),
|
5184
5689
|
void*
|
@@ -5193,7 +5698,8 @@ SQLITE_API void *SQLITE_STDCALL sqlite3_update_hook(
|
|
5193
5698
|
** and disabled if the argument is false.)^
|
5194
5699
|
**
|
5195
5700
|
** ^Cache sharing is enabled and disabled for an entire process.
|
5196
|
-
** This is a change as of SQLite version 3.5.0.
|
5701
|
+
** This is a change as of SQLite [version 3.5.0] ([dateof:3.5.0]).
|
5702
|
+
** In prior versions of SQLite,
|
5197
5703
|
** sharing was enabled or disabled for each thread separately.
|
5198
5704
|
**
|
5199
5705
|
** ^(The cache sharing mode set by this interface effects all subsequent
|
@@ -5218,7 +5724,7 @@ SQLITE_API void *SQLITE_STDCALL sqlite3_update_hook(
|
|
5218
5724
|
**
|
5219
5725
|
** See Also: [SQLite Shared-Cache Mode]
|
5220
5726
|
*/
|
5221
|
-
SQLITE_API int
|
5727
|
+
SQLITE_API int sqlite3_enable_shared_cache(int);
|
5222
5728
|
|
5223
5729
|
/*
|
5224
5730
|
** CAPI3REF: Attempt To Free Heap Memory
|
@@ -5234,7 +5740,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_enable_shared_cache(int);
|
|
5234
5740
|
**
|
5235
5741
|
** See also: [sqlite3_db_release_memory()]
|
5236
5742
|
*/
|
5237
|
-
SQLITE_API int
|
5743
|
+
SQLITE_API int sqlite3_release_memory(int);
|
5238
5744
|
|
5239
5745
|
/*
|
5240
5746
|
** CAPI3REF: Free Memory Used By A Database Connection
|
@@ -5248,7 +5754,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_release_memory(int);
|
|
5248
5754
|
**
|
5249
5755
|
** See also: [sqlite3_release_memory()]
|
5250
5756
|
*/
|
5251
|
-
SQLITE_API int
|
5757
|
+
SQLITE_API int sqlite3_db_release_memory(sqlite3*);
|
5252
5758
|
|
5253
5759
|
/*
|
5254
5760
|
** CAPI3REF: Impose A Limit On Heap Size
|
@@ -5287,7 +5793,8 @@ SQLITE_API int SQLITE_STDCALL sqlite3_db_release_memory(sqlite3*);
|
|
5287
5793
|
** from the heap.
|
5288
5794
|
** </ul>)^
|
5289
5795
|
**
|
5290
|
-
** Beginning with SQLite version 3.7.3,
|
5796
|
+
** Beginning with SQLite [version 3.7.3] ([dateof:3.7.3]),
|
5797
|
+
** the soft heap limit is enforced
|
5291
5798
|
** regardless of whether or not the [SQLITE_ENABLE_MEMORY_MANAGEMENT]
|
5292
5799
|
** compile-time option is invoked. With [SQLITE_ENABLE_MEMORY_MANAGEMENT],
|
5293
5800
|
** the soft heap limit is enforced on every memory allocation. Without
|
@@ -5300,7 +5807,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_db_release_memory(sqlite3*);
|
|
5300
5807
|
** The circumstances under which SQLite will enforce the soft heap limit may
|
5301
5808
|
** changes in future releases of SQLite.
|
5302
5809
|
*/
|
5303
|
-
SQLITE_API sqlite3_int64
|
5810
|
+
SQLITE_API sqlite3_int64 sqlite3_soft_heap_limit64(sqlite3_int64 N);
|
5304
5811
|
|
5305
5812
|
/*
|
5306
5813
|
** CAPI3REF: Deprecated Soft Heap Limit Interface
|
@@ -5311,7 +5818,7 @@ SQLITE_API sqlite3_int64 SQLITE_STDCALL sqlite3_soft_heap_limit64(sqlite3_int64
|
|
5311
5818
|
** only. All new applications should use the
|
5312
5819
|
** [sqlite3_soft_heap_limit64()] interface rather than this one.
|
5313
5820
|
*/
|
5314
|
-
SQLITE_API SQLITE_DEPRECATED void
|
5821
|
+
SQLITE_API SQLITE_DEPRECATED void sqlite3_soft_heap_limit(int N);
|
5315
5822
|
|
5316
5823
|
|
5317
5824
|
/*
|
@@ -5326,9 +5833,11 @@ SQLITE_API SQLITE_DEPRECATED void SQLITE_STDCALL sqlite3_soft_heap_limit(int N);
|
|
5326
5833
|
** column exists. ^The sqlite3_table_column_metadata() interface returns
|
5327
5834
|
** SQLITE_ERROR and if the specified column does not exist.
|
5328
5835
|
** ^If the column-name parameter to sqlite3_table_column_metadata() is a
|
5329
|
-
** NULL pointer, then this routine simply checks for the
|
5836
|
+
** NULL pointer, then this routine simply checks for the existence of the
|
5330
5837
|
** table and returns SQLITE_OK if the table exists and SQLITE_ERROR if it
|
5331
|
-
** does not.
|
5838
|
+
** does not. If the table name parameter T in a call to
|
5839
|
+
** sqlite3_table_column_metadata(X,D,T,C,...) is NULL then the result is
|
5840
|
+
** undefined behavior.
|
5332
5841
|
**
|
5333
5842
|
** ^The column is identified by the second, third and fourth parameters to
|
5334
5843
|
** this function. ^(The second parameter is either the name of the database
|
@@ -5381,7 +5890,7 @@ SQLITE_API SQLITE_DEPRECATED void SQLITE_STDCALL sqlite3_soft_heap_limit(int N);
|
|
5381
5890
|
** parsed, if that has not already been done, and returns an error if
|
5382
5891
|
** any errors are encountered while loading the schema.
|
5383
5892
|
*/
|
5384
|
-
SQLITE_API int
|
5893
|
+
SQLITE_API int sqlite3_table_column_metadata(
|
5385
5894
|
sqlite3 *db, /* Connection handle */
|
5386
5895
|
const char *zDbName, /* Database name or NULL */
|
5387
5896
|
const char *zTableName, /* Table name */
|
@@ -5423,12 +5932,21 @@ SQLITE_API int SQLITE_STDCALL sqlite3_table_column_metadata(
|
|
5423
5932
|
** should free this memory by calling [sqlite3_free()].
|
5424
5933
|
**
|
5425
5934
|
** ^Extension loading must be enabled using
|
5426
|
-
** [sqlite3_enable_load_extension()]
|
5935
|
+
** [sqlite3_enable_load_extension()] or
|
5936
|
+
** [sqlite3_db_config](db,[SQLITE_DBCONFIG_ENABLE_LOAD_EXTENSION],1,NULL)
|
5937
|
+
** prior to calling this API,
|
5427
5938
|
** otherwise an error will be returned.
|
5428
5939
|
**
|
5940
|
+
** <b>Security warning:</b> It is recommended that the
|
5941
|
+
** [SQLITE_DBCONFIG_ENABLE_LOAD_EXTENSION] method be used to enable only this
|
5942
|
+
** interface. The use of the [sqlite3_enable_load_extension()] interface
|
5943
|
+
** should be avoided. This will keep the SQL function [load_extension()]
|
5944
|
+
** disabled and prevent SQL injections from giving attackers
|
5945
|
+
** access to extension loading capabilities.
|
5946
|
+
**
|
5429
5947
|
** See also the [load_extension() SQL function].
|
5430
5948
|
*/
|
5431
|
-
SQLITE_API int
|
5949
|
+
SQLITE_API int sqlite3_load_extension(
|
5432
5950
|
sqlite3 *db, /* Load the extension into this database connection */
|
5433
5951
|
const char *zFile, /* Name of the shared library containing extension */
|
5434
5952
|
const char *zProc, /* Entry point. Derived from zFile if 0 */
|
@@ -5448,8 +5966,19 @@ SQLITE_API int SQLITE_STDCALL sqlite3_load_extension(
|
|
5448
5966
|
** ^Call the sqlite3_enable_load_extension() routine with onoff==1
|
5449
5967
|
** to turn extension loading on and call it with onoff==0 to turn
|
5450
5968
|
** it back off again.
|
5969
|
+
**
|
5970
|
+
** ^This interface enables or disables both the C-API
|
5971
|
+
** [sqlite3_load_extension()] and the SQL function [load_extension()].
|
5972
|
+
** ^(Use [sqlite3_db_config](db,[SQLITE_DBCONFIG_ENABLE_LOAD_EXTENSION],..)
|
5973
|
+
** to enable or disable only the C-API.)^
|
5974
|
+
**
|
5975
|
+
** <b>Security warning:</b> It is recommended that extension loading
|
5976
|
+
** be disabled using the [SQLITE_DBCONFIG_ENABLE_LOAD_EXTENSION] method
|
5977
|
+
** rather than this interface, so the [load_extension()] SQL function
|
5978
|
+
** remains disabled. This will prevent SQL injections from giving attackers
|
5979
|
+
** access to extension loading capabilities.
|
5451
5980
|
*/
|
5452
|
-
SQLITE_API int
|
5981
|
+
SQLITE_API int sqlite3_enable_load_extension(sqlite3 *db, int onoff);
|
5453
5982
|
|
5454
5983
|
/*
|
5455
5984
|
** CAPI3REF: Automatically Load Statically Linked Extensions
|
@@ -5461,7 +5990,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_enable_load_extension(sqlite3 *db, int ono
|
|
5461
5990
|
**
|
5462
5991
|
** ^(Even though the function prototype shows that xEntryPoint() takes
|
5463
5992
|
** no arguments and returns void, SQLite invokes xEntryPoint() with three
|
5464
|
-
** arguments and expects
|
5993
|
+
** arguments and expects an integer result as if the signature of the
|
5465
5994
|
** entry point where as follows:
|
5466
5995
|
**
|
5467
5996
|
** <blockquote><pre>
|
@@ -5487,7 +6016,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_enable_load_extension(sqlite3 *db, int ono
|
|
5487
6016
|
** See also: [sqlite3_reset_auto_extension()]
|
5488
6017
|
** and [sqlite3_cancel_auto_extension()]
|
5489
6018
|
*/
|
5490
|
-
SQLITE_API int
|
6019
|
+
SQLITE_API int sqlite3_auto_extension(void(*xEntryPoint)(void));
|
5491
6020
|
|
5492
6021
|
/*
|
5493
6022
|
** CAPI3REF: Cancel Automatic Extension Loading
|
@@ -5499,7 +6028,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_auto_extension(void (*xEntryPoint)(void));
|
|
5499
6028
|
** unregistered and it returns 0 if X was not on the list of initialization
|
5500
6029
|
** routines.
|
5501
6030
|
*/
|
5502
|
-
SQLITE_API int
|
6031
|
+
SQLITE_API int sqlite3_cancel_auto_extension(void(*xEntryPoint)(void));
|
5503
6032
|
|
5504
6033
|
/*
|
5505
6034
|
** CAPI3REF: Reset Automatic Extension Loading
|
@@ -5507,7 +6036,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_cancel_auto_extension(void (*xEntryPoint)(
|
|
5507
6036
|
** ^This interface disables all automatic extensions previously
|
5508
6037
|
** registered using [sqlite3_auto_extension()].
|
5509
6038
|
*/
|
5510
|
-
SQLITE_API void
|
6039
|
+
SQLITE_API void sqlite3_reset_auto_extension(void);
|
5511
6040
|
|
5512
6041
|
/*
|
5513
6042
|
** The interface to the virtual-table mechanism is currently considered
|
@@ -5609,6 +6138,17 @@ struct sqlite3_module {
|
|
5609
6138
|
** ^Information about the ORDER BY clause is stored in aOrderBy[].
|
5610
6139
|
** ^Each term of aOrderBy records a column of the ORDER BY clause.
|
5611
6140
|
**
|
6141
|
+
** The colUsed field indicates which columns of the virtual table may be
|
6142
|
+
** required by the current scan. Virtual table columns are numbered from
|
6143
|
+
** zero in the order in which they appear within the CREATE TABLE statement
|
6144
|
+
** passed to sqlite3_declare_vtab(). For the first 63 columns (columns 0-62),
|
6145
|
+
** the corresponding bit is set within the colUsed mask if the column may be
|
6146
|
+
** required by SQLite. If the table has at least 64 columns and any column
|
6147
|
+
** to the right of the first 63 is required, then bit 63 of colUsed is also
|
6148
|
+
** set. In other words, column iCol may be required if the expression
|
6149
|
+
** (colUsed & ((sqlite3_uint64)1 << (iCol>=63 ? 63 : iCol))) evaluates to
|
6150
|
+
** non-zero.
|
6151
|
+
**
|
5612
6152
|
** The [xBestIndex] method must fill aConstraintUsage[] with information
|
5613
6153
|
** about what parameters to pass to xFilter. ^If argvIndex>0 then
|
5614
6154
|
** the right-hand side of the corresponding aConstraint[] is evaluated
|
@@ -5650,13 +6190,15 @@ struct sqlite3_module {
|
|
5650
6190
|
** the xUpdate method are automatically rolled back by SQLite.
|
5651
6191
|
**
|
5652
6192
|
** IMPORTANT: The estimatedRows field was added to the sqlite3_index_info
|
5653
|
-
** structure for SQLite version 3.8.2.
|
6193
|
+
** structure for SQLite [version 3.8.2] ([dateof:3.8.2]).
|
6194
|
+
** If a virtual table extension is
|
5654
6195
|
** used with an SQLite version earlier than 3.8.2, the results of attempting
|
5655
6196
|
** to read or write the estimatedRows field are undefined (but are likely
|
5656
6197
|
** to included crashing the application). The estimatedRows field should
|
5657
6198
|
** therefore only be used if [sqlite3_libversion_number()] returns a
|
5658
6199
|
** value greater than or equal to 3008002. Similarly, the idxFlags field
|
5659
|
-
** was added for version 3.9.0.
|
6200
|
+
** was added for [version 3.9.0] ([dateof:3.9.0]).
|
6201
|
+
** It may therefore only be used if
|
5660
6202
|
** sqlite3_libversion_number() returns a value greater than or equal to
|
5661
6203
|
** 3009000.
|
5662
6204
|
*/
|
@@ -5664,7 +6206,7 @@ struct sqlite3_index_info {
|
|
5664
6206
|
/* Inputs */
|
5665
6207
|
int nConstraint; /* Number of entries in aConstraint */
|
5666
6208
|
struct sqlite3_index_constraint {
|
5667
|
-
int iColumn; /* Column
|
6209
|
+
int iColumn; /* Column constrained. -1 for ROWID */
|
5668
6210
|
unsigned char op; /* Constraint operator */
|
5669
6211
|
unsigned char usable; /* True if this constraint is usable */
|
5670
6212
|
int iTermOffset; /* Used internally - xBestIndex should ignore */
|
@@ -5688,6 +6230,8 @@ struct sqlite3_index_info {
|
|
5688
6230
|
sqlite3_int64 estimatedRows; /* Estimated number of rows returned */
|
5689
6231
|
/* Fields below are only available in SQLite 3.9.0 and later */
|
5690
6232
|
int idxFlags; /* Mask of SQLITE_INDEX_SCAN_* flags */
|
6233
|
+
/* Fields below are only available in SQLite 3.10.0 and later */
|
6234
|
+
sqlite3_uint64 colUsed; /* Input: Mask of columns used by statement */
|
5691
6235
|
};
|
5692
6236
|
|
5693
6237
|
/*
|
@@ -5703,12 +6247,20 @@ struct sqlite3_index_info {
|
|
5703
6247
|
** an operator that is part of a constraint term in the wHERE clause of
|
5704
6248
|
** a query that uses a [virtual table].
|
5705
6249
|
*/
|
5706
|
-
#define SQLITE_INDEX_CONSTRAINT_EQ
|
5707
|
-
#define SQLITE_INDEX_CONSTRAINT_GT
|
5708
|
-
#define SQLITE_INDEX_CONSTRAINT_LE
|
5709
|
-
#define SQLITE_INDEX_CONSTRAINT_LT
|
5710
|
-
#define SQLITE_INDEX_CONSTRAINT_GE
|
5711
|
-
#define SQLITE_INDEX_CONSTRAINT_MATCH
|
6250
|
+
#define SQLITE_INDEX_CONSTRAINT_EQ 2
|
6251
|
+
#define SQLITE_INDEX_CONSTRAINT_GT 4
|
6252
|
+
#define SQLITE_INDEX_CONSTRAINT_LE 8
|
6253
|
+
#define SQLITE_INDEX_CONSTRAINT_LT 16
|
6254
|
+
#define SQLITE_INDEX_CONSTRAINT_GE 32
|
6255
|
+
#define SQLITE_INDEX_CONSTRAINT_MATCH 64
|
6256
|
+
#define SQLITE_INDEX_CONSTRAINT_LIKE 65
|
6257
|
+
#define SQLITE_INDEX_CONSTRAINT_GLOB 66
|
6258
|
+
#define SQLITE_INDEX_CONSTRAINT_REGEXP 67
|
6259
|
+
#define SQLITE_INDEX_CONSTRAINT_NE 68
|
6260
|
+
#define SQLITE_INDEX_CONSTRAINT_ISNOT 69
|
6261
|
+
#define SQLITE_INDEX_CONSTRAINT_ISNOTNULL 70
|
6262
|
+
#define SQLITE_INDEX_CONSTRAINT_ISNULL 71
|
6263
|
+
#define SQLITE_INDEX_CONSTRAINT_IS 72
|
5712
6264
|
|
5713
6265
|
/*
|
5714
6266
|
** CAPI3REF: Register A Virtual Table Implementation
|
@@ -5736,13 +6288,13 @@ struct sqlite3_index_info {
|
|
5736
6288
|
** interface is equivalent to sqlite3_create_module_v2() with a NULL
|
5737
6289
|
** destructor.
|
5738
6290
|
*/
|
5739
|
-
SQLITE_API int
|
6291
|
+
SQLITE_API int sqlite3_create_module(
|
5740
6292
|
sqlite3 *db, /* SQLite connection to register module with */
|
5741
6293
|
const char *zName, /* Name of the module */
|
5742
6294
|
const sqlite3_module *p, /* Methods for the module */
|
5743
6295
|
void *pClientData /* Client data for xCreate/xConnect */
|
5744
6296
|
);
|
5745
|
-
SQLITE_API int
|
6297
|
+
SQLITE_API int sqlite3_create_module_v2(
|
5746
6298
|
sqlite3 *db, /* SQLite connection to register module with */
|
5747
6299
|
const char *zName, /* Name of the module */
|
5748
6300
|
const sqlite3_module *p, /* Methods for the module */
|
@@ -5805,7 +6357,7 @@ struct sqlite3_vtab_cursor {
|
|
5805
6357
|
** to declare the format (the names and datatypes of the columns) of
|
5806
6358
|
** the virtual tables they implement.
|
5807
6359
|
*/
|
5808
|
-
SQLITE_API int
|
6360
|
+
SQLITE_API int sqlite3_declare_vtab(sqlite3*, const char *zSQL);
|
5809
6361
|
|
5810
6362
|
/*
|
5811
6363
|
** CAPI3REF: Overload A Function For A Virtual Table
|
@@ -5824,7 +6376,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_declare_vtab(sqlite3*, const char *zSQL);
|
|
5824
6376
|
** purpose is to be a placeholder function that can be overloaded
|
5825
6377
|
** by a [virtual table].
|
5826
6378
|
*/
|
5827
|
-
SQLITE_API int
|
6379
|
+
SQLITE_API int sqlite3_overload_function(sqlite3*, const char *zFuncName, int nArg);
|
5828
6380
|
|
5829
6381
|
/*
|
5830
6382
|
** The interface to the virtual-table mechanism defined above (back up
|
@@ -5899,6 +6451,12 @@ typedef struct sqlite3_blob sqlite3_blob;
|
|
5899
6451
|
** [database connection] error code and message accessible via
|
5900
6452
|
** [sqlite3_errcode()] and [sqlite3_errmsg()] and related functions.
|
5901
6453
|
**
|
6454
|
+
** A BLOB referenced by sqlite3_blob_open() may be read using the
|
6455
|
+
** [sqlite3_blob_read()] interface and modified by using
|
6456
|
+
** [sqlite3_blob_write()]. The [BLOB handle] can be moved to a
|
6457
|
+
** different row of the same table using the [sqlite3_blob_reopen()]
|
6458
|
+
** interface. However, the column, table, or database of a [BLOB handle]
|
6459
|
+
** cannot be changed after the [BLOB handle] is opened.
|
5902
6460
|
**
|
5903
6461
|
** ^(If the row that a BLOB handle points to is modified by an
|
5904
6462
|
** [UPDATE], [DELETE], or by [ON CONFLICT] side-effects
|
@@ -5922,8 +6480,12 @@ typedef struct sqlite3_blob sqlite3_blob;
|
|
5922
6480
|
**
|
5923
6481
|
** To avoid a resource leak, every open [BLOB handle] should eventually
|
5924
6482
|
** be released by a call to [sqlite3_blob_close()].
|
6483
|
+
**
|
6484
|
+
** See also: [sqlite3_blob_close()],
|
6485
|
+
** [sqlite3_blob_reopen()], [sqlite3_blob_read()],
|
6486
|
+
** [sqlite3_blob_bytes()], [sqlite3_blob_write()].
|
5925
6487
|
*/
|
5926
|
-
SQLITE_API int
|
6488
|
+
SQLITE_API int sqlite3_blob_open(
|
5927
6489
|
sqlite3*,
|
5928
6490
|
const char *zDb,
|
5929
6491
|
const char *zTable,
|
@@ -5937,11 +6499,11 @@ SQLITE_API int SQLITE_STDCALL sqlite3_blob_open(
|
|
5937
6499
|
** CAPI3REF: Move a BLOB Handle to a New Row
|
5938
6500
|
** METHOD: sqlite3_blob
|
5939
6501
|
**
|
5940
|
-
** ^This function is used to move an existing
|
6502
|
+
** ^This function is used to move an existing [BLOB handle] so that it points
|
5941
6503
|
** to a different row of the same database table. ^The new row is identified
|
5942
6504
|
** by the rowid value passed as the second argument. Only the row can be
|
5943
6505
|
** changed. ^The database, table and column on which the blob handle is open
|
5944
|
-
** remain the same. Moving an existing
|
6506
|
+
** remain the same. Moving an existing [BLOB handle] to a new row is
|
5945
6507
|
** faster than closing the existing handle and opening a new one.
|
5946
6508
|
**
|
5947
6509
|
** ^(The new row must meet the same criteria as for [sqlite3_blob_open()] -
|
@@ -5956,7 +6518,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_blob_open(
|
|
5956
6518
|
**
|
5957
6519
|
** ^This function sets the database handle error code and message.
|
5958
6520
|
*/
|
5959
|
-
SQLITE_API int
|
6521
|
+
SQLITE_API int sqlite3_blob_reopen(sqlite3_blob *, sqlite3_int64);
|
5960
6522
|
|
5961
6523
|
/*
|
5962
6524
|
** CAPI3REF: Close A BLOB Handle
|
@@ -5979,7 +6541,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_blob_reopen(sqlite3_blob *, sqlite3_int64)
|
|
5979
6541
|
** is passed a valid open blob handle, the values returned by the
|
5980
6542
|
** sqlite3_errcode() and sqlite3_errmsg() functions are set before returning.
|
5981
6543
|
*/
|
5982
|
-
SQLITE_API int
|
6544
|
+
SQLITE_API int sqlite3_blob_close(sqlite3_blob *);
|
5983
6545
|
|
5984
6546
|
/*
|
5985
6547
|
** CAPI3REF: Return The Size Of An Open BLOB
|
@@ -5995,7 +6557,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_blob_close(sqlite3_blob *);
|
|
5995
6557
|
** been closed by [sqlite3_blob_close()]. Passing any other pointer in
|
5996
6558
|
** to this routine results in undefined and probably undesirable behavior.
|
5997
6559
|
*/
|
5998
|
-
SQLITE_API int
|
6560
|
+
SQLITE_API int sqlite3_blob_bytes(sqlite3_blob *);
|
5999
6561
|
|
6000
6562
|
/*
|
6001
6563
|
** CAPI3REF: Read Data From A BLOB Incrementally
|
@@ -6024,7 +6586,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_blob_bytes(sqlite3_blob *);
|
|
6024
6586
|
**
|
6025
6587
|
** See also: [sqlite3_blob_write()].
|
6026
6588
|
*/
|
6027
|
-
SQLITE_API int
|
6589
|
+
SQLITE_API int sqlite3_blob_read(sqlite3_blob *, void *Z, int N, int iOffset);
|
6028
6590
|
|
6029
6591
|
/*
|
6030
6592
|
** CAPI3REF: Write Data Into A BLOB Incrementally
|
@@ -6066,7 +6628,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_blob_read(sqlite3_blob *, void *Z, int N,
|
|
6066
6628
|
**
|
6067
6629
|
** See also: [sqlite3_blob_read()].
|
6068
6630
|
*/
|
6069
|
-
SQLITE_API int
|
6631
|
+
SQLITE_API int sqlite3_blob_write(sqlite3_blob *, const void *z, int n, int iOffset);
|
6070
6632
|
|
6071
6633
|
/*
|
6072
6634
|
** CAPI3REF: Virtual File System Objects
|
@@ -6097,9 +6659,9 @@ SQLITE_API int SQLITE_STDCALL sqlite3_blob_write(sqlite3_blob *, const void *z,
|
|
6097
6659
|
** ^(If the default VFS is unregistered, another VFS is chosen as
|
6098
6660
|
** the default. The choice for the new VFS is arbitrary.)^
|
6099
6661
|
*/
|
6100
|
-
SQLITE_API sqlite3_vfs *
|
6101
|
-
SQLITE_API int
|
6102
|
-
SQLITE_API int
|
6662
|
+
SQLITE_API sqlite3_vfs *sqlite3_vfs_find(const char *zVfsName);
|
6663
|
+
SQLITE_API int sqlite3_vfs_register(sqlite3_vfs*, int makeDflt);
|
6664
|
+
SQLITE_API int sqlite3_vfs_unregister(sqlite3_vfs*);
|
6103
6665
|
|
6104
6666
|
/*
|
6105
6667
|
** CAPI3REF: Mutexes
|
@@ -6215,11 +6777,11 @@ SQLITE_API int SQLITE_STDCALL sqlite3_vfs_unregister(sqlite3_vfs*);
|
|
6215
6777
|
**
|
6216
6778
|
** See also: [sqlite3_mutex_held()] and [sqlite3_mutex_notheld()].
|
6217
6779
|
*/
|
6218
|
-
SQLITE_API sqlite3_mutex *
|
6219
|
-
SQLITE_API void
|
6220
|
-
SQLITE_API void
|
6221
|
-
SQLITE_API int
|
6222
|
-
SQLITE_API void
|
6780
|
+
SQLITE_API sqlite3_mutex *sqlite3_mutex_alloc(int);
|
6781
|
+
SQLITE_API void sqlite3_mutex_free(sqlite3_mutex*);
|
6782
|
+
SQLITE_API void sqlite3_mutex_enter(sqlite3_mutex*);
|
6783
|
+
SQLITE_API int sqlite3_mutex_try(sqlite3_mutex*);
|
6784
|
+
SQLITE_API void sqlite3_mutex_leave(sqlite3_mutex*);
|
6223
6785
|
|
6224
6786
|
/*
|
6225
6787
|
** CAPI3REF: Mutex Methods Object
|
@@ -6329,8 +6891,8 @@ struct sqlite3_mutex_methods {
|
|
6329
6891
|
** interface should also return 1 when given a NULL pointer.
|
6330
6892
|
*/
|
6331
6893
|
#ifndef NDEBUG
|
6332
|
-
SQLITE_API int
|
6333
|
-
SQLITE_API int
|
6894
|
+
SQLITE_API int sqlite3_mutex_held(sqlite3_mutex*);
|
6895
|
+
SQLITE_API int sqlite3_mutex_notheld(sqlite3_mutex*);
|
6334
6896
|
#endif
|
6335
6897
|
|
6336
6898
|
/*
|
@@ -6349,7 +6911,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_mutex_notheld(sqlite3_mutex*);
|
|
6349
6911
|
#define SQLITE_MUTEX_STATIC_MEM 3 /* sqlite3_malloc() */
|
6350
6912
|
#define SQLITE_MUTEX_STATIC_MEM2 4 /* NOT USED */
|
6351
6913
|
#define SQLITE_MUTEX_STATIC_OPEN 4 /* sqlite3BtreeOpen() */
|
6352
|
-
#define SQLITE_MUTEX_STATIC_PRNG 5 /*
|
6914
|
+
#define SQLITE_MUTEX_STATIC_PRNG 5 /* sqlite3_randomness() */
|
6353
6915
|
#define SQLITE_MUTEX_STATIC_LRU 6 /* lru page list */
|
6354
6916
|
#define SQLITE_MUTEX_STATIC_LRU2 7 /* NOT USED */
|
6355
6917
|
#define SQLITE_MUTEX_STATIC_PMEM 7 /* sqlite3PageMalloc() */
|
@@ -6370,7 +6932,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_mutex_notheld(sqlite3_mutex*);
|
|
6370
6932
|
** ^If the [threading mode] is Single-thread or Multi-thread then this
|
6371
6933
|
** routine returns a NULL pointer.
|
6372
6934
|
*/
|
6373
|
-
SQLITE_API sqlite3_mutex *
|
6935
|
+
SQLITE_API sqlite3_mutex *sqlite3_db_mutex(sqlite3*);
|
6374
6936
|
|
6375
6937
|
/*
|
6376
6938
|
** CAPI3REF: Low-Level Control Of Database Files
|
@@ -6405,7 +6967,7 @@ SQLITE_API sqlite3_mutex *SQLITE_STDCALL sqlite3_db_mutex(sqlite3*);
|
|
6405
6967
|
**
|
6406
6968
|
** See also: [SQLITE_FCNTL_LOCKSTATE]
|
6407
6969
|
*/
|
6408
|
-
SQLITE_API int
|
6970
|
+
SQLITE_API int sqlite3_file_control(sqlite3*, const char *zDbName, int op, void*);
|
6409
6971
|
|
6410
6972
|
/*
|
6411
6973
|
** CAPI3REF: Testing Interface
|
@@ -6424,7 +6986,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_file_control(sqlite3*, const char *zDbName
|
|
6424
6986
|
** Unlike most of the SQLite API, this function is not guaranteed to
|
6425
6987
|
** operate consistently from one release to the next.
|
6426
6988
|
*/
|
6427
|
-
SQLITE_API int
|
6989
|
+
SQLITE_API int sqlite3_test_control(int op, ...);
|
6428
6990
|
|
6429
6991
|
/*
|
6430
6992
|
** CAPI3REF: Testing Interface Operation Codes
|
@@ -6450,9 +7012,10 @@ SQLITE_API int SQLITE_CDECL sqlite3_test_control(int op, ...);
|
|
6450
7012
|
#define SQLITE_TESTCTRL_RESERVE 14
|
6451
7013
|
#define SQLITE_TESTCTRL_OPTIMIZATIONS 15
|
6452
7014
|
#define SQLITE_TESTCTRL_ISKEYWORD 16
|
6453
|
-
#define SQLITE_TESTCTRL_SCRATCHMALLOC 17
|
7015
|
+
#define SQLITE_TESTCTRL_SCRATCHMALLOC 17 /* NOT USED */
|
6454
7016
|
#define SQLITE_TESTCTRL_LOCALTIME_FAULT 18
|
6455
7017
|
#define SQLITE_TESTCTRL_EXPLAIN_STMT 19 /* NOT USED */
|
7018
|
+
#define SQLITE_TESTCTRL_ONCE_RESET_THRESHOLD 19
|
6456
7019
|
#define SQLITE_TESTCTRL_NEVER_CORRUPT 20
|
6457
7020
|
#define SQLITE_TESTCTRL_VDBE_COVERAGE 21
|
6458
7021
|
#define SQLITE_TESTCTRL_BYTEORDER 22
|
@@ -6487,8 +7050,8 @@ SQLITE_API int SQLITE_CDECL sqlite3_test_control(int op, ...);
|
|
6487
7050
|
**
|
6488
7051
|
** See also: [sqlite3_db_status()]
|
6489
7052
|
*/
|
6490
|
-
SQLITE_API int
|
6491
|
-
SQLITE_API int
|
7053
|
+
SQLITE_API int sqlite3_status(int op, int *pCurrent, int *pHighwater, int resetFlag);
|
7054
|
+
SQLITE_API int sqlite3_status64(
|
6492
7055
|
int op,
|
6493
7056
|
sqlite3_int64 *pCurrent,
|
6494
7057
|
sqlite3_int64 *pHighwater,
|
@@ -6508,8 +7071,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_status64(
|
|
6508
7071
|
** <dd>This parameter is the current amount of memory checked out
|
6509
7072
|
** using [sqlite3_malloc()], either directly or indirectly. The
|
6510
7073
|
** figure includes calls made to [sqlite3_malloc()] by the application
|
6511
|
-
** and internal memory usage by the SQLite library.
|
6512
|
-
** controlled by [SQLITE_CONFIG_SCRATCH] and auxiliary page-cache
|
7074
|
+
** and internal memory usage by the SQLite library. Auxiliary page-cache
|
6513
7075
|
** memory controlled by [SQLITE_CONFIG_PAGECACHE] is not included in
|
6514
7076
|
** this parameter. The amount returned is the sum of the allocation
|
6515
7077
|
** sizes as reported by the xSize method in [sqlite3_mem_methods].</dd>)^
|
@@ -6544,35 +7106,21 @@ SQLITE_API int SQLITE_STDCALL sqlite3_status64(
|
|
6544
7106
|
** [[SQLITE_STATUS_PAGECACHE_SIZE]] ^(<dt>SQLITE_STATUS_PAGECACHE_SIZE</dt>
|
6545
7107
|
** <dd>This parameter records the largest memory allocation request
|
6546
7108
|
** handed to [pagecache memory allocator]. Only the value returned in the
|
6547
|
-
** *pHighwater parameter to [sqlite3_status()] is of interest.
|
7109
|
+
** *pHighwater parameter to [sqlite3_status()] is of interest.
|
6548
7110
|
** The value written into the *pCurrent parameter is undefined.</dd>)^
|
6549
7111
|
**
|
6550
|
-
** [[SQLITE_STATUS_SCRATCH_USED]]
|
6551
|
-
** <dd>
|
6552
|
-
** [scratch memory allocator] configured using
|
6553
|
-
** [SQLITE_CONFIG_SCRATCH]. The value returned is in allocations, not
|
6554
|
-
** in bytes. Since a single thread may only have one scratch allocation
|
6555
|
-
** outstanding at time, this parameter also reports the number of threads
|
6556
|
-
** using scratch memory at the same time.</dd>)^
|
7112
|
+
** [[SQLITE_STATUS_SCRATCH_USED]] <dt>SQLITE_STATUS_SCRATCH_USED</dt>
|
7113
|
+
** <dd>No longer used.</dd>
|
6557
7114
|
**
|
6558
7115
|
** [[SQLITE_STATUS_SCRATCH_OVERFLOW]] ^(<dt>SQLITE_STATUS_SCRATCH_OVERFLOW</dt>
|
6559
|
-
** <dd>
|
6560
|
-
**
|
6561
|
-
**
|
6562
|
-
**
|
6563
|
-
** larger (that is, because the requested allocation was larger than the
|
6564
|
-
** "sz" parameter to [SQLITE_CONFIG_SCRATCH]) and because no scratch buffer
|
6565
|
-
** slots were available.
|
6566
|
-
** </dd>)^
|
6567
|
-
**
|
6568
|
-
** [[SQLITE_STATUS_SCRATCH_SIZE]] ^(<dt>SQLITE_STATUS_SCRATCH_SIZE</dt>
|
6569
|
-
** <dd>This parameter records the largest memory allocation request
|
6570
|
-
** handed to [scratch memory allocator]. Only the value returned in the
|
6571
|
-
** *pHighwater parameter to [sqlite3_status()] is of interest.
|
6572
|
-
** The value written into the *pCurrent parameter is undefined.</dd>)^
|
7116
|
+
** <dd>No longer used.</dd>
|
7117
|
+
**
|
7118
|
+
** [[SQLITE_STATUS_SCRATCH_SIZE]] <dt>SQLITE_STATUS_SCRATCH_SIZE</dt>
|
7119
|
+
** <dd>No longer used.</dd>
|
6573
7120
|
**
|
6574
7121
|
** [[SQLITE_STATUS_PARSER_STACK]] ^(<dt>SQLITE_STATUS_PARSER_STACK</dt>
|
6575
|
-
** <dd>
|
7122
|
+
** <dd>The *pHighwater parameter records the deepest parser stack.
|
7123
|
+
** The *pCurrent value is undefined. The *pHighwater value is only
|
6576
7124
|
** meaningful if SQLite is compiled with [YYTRACKMAXSTACKDEPTH].</dd>)^
|
6577
7125
|
** </dl>
|
6578
7126
|
**
|
@@ -6581,12 +7129,12 @@ SQLITE_API int SQLITE_STDCALL sqlite3_status64(
|
|
6581
7129
|
#define SQLITE_STATUS_MEMORY_USED 0
|
6582
7130
|
#define SQLITE_STATUS_PAGECACHE_USED 1
|
6583
7131
|
#define SQLITE_STATUS_PAGECACHE_OVERFLOW 2
|
6584
|
-
#define SQLITE_STATUS_SCRATCH_USED 3
|
6585
|
-
#define SQLITE_STATUS_SCRATCH_OVERFLOW 4
|
7132
|
+
#define SQLITE_STATUS_SCRATCH_USED 3 /* NOT USED */
|
7133
|
+
#define SQLITE_STATUS_SCRATCH_OVERFLOW 4 /* NOT USED */
|
6586
7134
|
#define SQLITE_STATUS_MALLOC_SIZE 5
|
6587
7135
|
#define SQLITE_STATUS_PARSER_STACK 6
|
6588
7136
|
#define SQLITE_STATUS_PAGECACHE_SIZE 7
|
6589
|
-
#define SQLITE_STATUS_SCRATCH_SIZE 8
|
7137
|
+
#define SQLITE_STATUS_SCRATCH_SIZE 8 /* NOT USED */
|
6590
7138
|
#define SQLITE_STATUS_MALLOC_COUNT 9
|
6591
7139
|
|
6592
7140
|
/*
|
@@ -6612,7 +7160,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_status64(
|
|
6612
7160
|
**
|
6613
7161
|
** See also: [sqlite3_status()] and [sqlite3_stmt_status()].
|
6614
7162
|
*/
|
6615
|
-
SQLITE_API int
|
7163
|
+
SQLITE_API int sqlite3_db_status(sqlite3*, int op, int *pCur, int *pHiwtr, int resetFlg);
|
6616
7164
|
|
6617
7165
|
/*
|
6618
7166
|
** CAPI3REF: Status Parameters for database connections
|
@@ -6658,6 +7206,18 @@ SQLITE_API int SQLITE_STDCALL sqlite3_db_status(sqlite3*, int op, int *pCur, int
|
|
6658
7206
|
** memory used by all pager caches associated with the database connection.)^
|
6659
7207
|
** ^The highwater mark associated with SQLITE_DBSTATUS_CACHE_USED is always 0.
|
6660
7208
|
**
|
7209
|
+
** [[SQLITE_DBSTATUS_CACHE_USED_SHARED]]
|
7210
|
+
** ^(<dt>SQLITE_DBSTATUS_CACHE_USED_SHARED</dt>
|
7211
|
+
** <dd>This parameter is similar to DBSTATUS_CACHE_USED, except that if a
|
7212
|
+
** pager cache is shared between two or more connections the bytes of heap
|
7213
|
+
** memory used by that pager cache is divided evenly between the attached
|
7214
|
+
** connections.)^ In other words, if none of the pager caches associated
|
7215
|
+
** with the database connection are shared, this request returns the same
|
7216
|
+
** value as DBSTATUS_CACHE_USED. Or, if one or more or the pager caches are
|
7217
|
+
** shared, the value returned by this call will be smaller than that returned
|
7218
|
+
** by DBSTATUS_CACHE_USED. ^The highwater mark associated with
|
7219
|
+
** SQLITE_DBSTATUS_CACHE_USED_SHARED is always 0.
|
7220
|
+
**
|
6661
7221
|
** [[SQLITE_DBSTATUS_SCHEMA_USED]] ^(<dt>SQLITE_DBSTATUS_SCHEMA_USED</dt>
|
6662
7222
|
** <dd>This parameter returns the approximate number of bytes of heap
|
6663
7223
|
** memory used to store the schema for all databases associated
|
@@ -6715,7 +7275,8 @@ SQLITE_API int SQLITE_STDCALL sqlite3_db_status(sqlite3*, int op, int *pCur, int
|
|
6715
7275
|
#define SQLITE_DBSTATUS_CACHE_MISS 8
|
6716
7276
|
#define SQLITE_DBSTATUS_CACHE_WRITE 9
|
6717
7277
|
#define SQLITE_DBSTATUS_DEFERRED_FKS 10
|
6718
|
-
#define
|
7278
|
+
#define SQLITE_DBSTATUS_CACHE_USED_SHARED 11
|
7279
|
+
#define SQLITE_DBSTATUS_MAX 11 /* Largest defined DBSTATUS */
|
6719
7280
|
|
6720
7281
|
|
6721
7282
|
/*
|
@@ -6742,7 +7303,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_db_status(sqlite3*, int op, int *pCur, int
|
|
6742
7303
|
**
|
6743
7304
|
** See also: [sqlite3_status()] and [sqlite3_db_status()].
|
6744
7305
|
*/
|
6745
|
-
SQLITE_API int
|
7306
|
+
SQLITE_API int sqlite3_stmt_status(sqlite3_stmt*, int op,int resetFlg);
|
6746
7307
|
|
6747
7308
|
/*
|
6748
7309
|
** CAPI3REF: Status Parameters for prepared statements
|
@@ -6778,6 +7339,24 @@ SQLITE_API int SQLITE_STDCALL sqlite3_stmt_status(sqlite3_stmt*, int op,int rese
|
|
6778
7339
|
** used as a proxy for the total work done by the prepared statement.
|
6779
7340
|
** If the number of virtual machine operations exceeds 2147483647
|
6780
7341
|
** then the value returned by this statement status code is undefined.
|
7342
|
+
**
|
7343
|
+
** [[SQLITE_STMTSTATUS_REPREPARE]] <dt>SQLITE_STMTSTATUS_REPREPARE</dt>
|
7344
|
+
** <dd>^This is the number of times that the prepare statement has been
|
7345
|
+
** automatically regenerated due to schema changes or change to
|
7346
|
+
** [bound parameters] that might affect the query plan.
|
7347
|
+
**
|
7348
|
+
** [[SQLITE_STMTSTATUS_RUN]] <dt>SQLITE_STMTSTATUS_RUN</dt>
|
7349
|
+
** <dd>^This is the number of times that the prepared statement has
|
7350
|
+
** been run. A single "run" for the purposes of this counter is one
|
7351
|
+
** or more calls to [sqlite3_step()] followed by a call to [sqlite3_reset()].
|
7352
|
+
** The counter is incremented on the first [sqlite3_step()] call of each
|
7353
|
+
** cycle.
|
7354
|
+
**
|
7355
|
+
** [[SQLITE_STMTSTATUS_MEMUSED]] <dt>SQLITE_STMTSTATUS_MEMUSED</dt>
|
7356
|
+
** <dd>^This is the approximate number of bytes of heap memory
|
7357
|
+
** used to store the prepared statement. ^This value is not actually
|
7358
|
+
** a counter, and so the resetFlg parameter to sqlite3_stmt_status()
|
7359
|
+
** is ignored when the opcode is SQLITE_STMTSTATUS_MEMUSED.
|
6781
7360
|
** </dd>
|
6782
7361
|
** </dl>
|
6783
7362
|
*/
|
@@ -6785,6 +7364,9 @@ SQLITE_API int SQLITE_STDCALL sqlite3_stmt_status(sqlite3_stmt*, int op,int rese
|
|
6785
7364
|
#define SQLITE_STMTSTATUS_SORT 2
|
6786
7365
|
#define SQLITE_STMTSTATUS_AUTOINDEX 3
|
6787
7366
|
#define SQLITE_STMTSTATUS_VM_STEP 4
|
7367
|
+
#define SQLITE_STMTSTATUS_REPREPARE 5
|
7368
|
+
#define SQLITE_STMTSTATUS_RUN 6
|
7369
|
+
#define SQLITE_STMTSTATUS_MEMUSED 99
|
6788
7370
|
|
6789
7371
|
/*
|
6790
7372
|
** CAPI3REF: Custom Page Cache Object
|
@@ -7069,7 +7651,7 @@ typedef struct sqlite3_backup sqlite3_backup;
|
|
7069
7651
|
** must be different or else sqlite3_backup_init(D,N,S,M) will fail with
|
7070
7652
|
** an error.
|
7071
7653
|
**
|
7072
|
-
** ^A call to sqlite3_backup_init() will fail, returning
|
7654
|
+
** ^A call to sqlite3_backup_init() will fail, returning NULL, if
|
7073
7655
|
** there is already a read or read-write transaction open on the
|
7074
7656
|
** destination database.
|
7075
7657
|
**
|
@@ -7211,16 +7793,16 @@ typedef struct sqlite3_backup sqlite3_backup;
|
|
7211
7793
|
** same time as another thread is invoking sqlite3_backup_step() it is
|
7212
7794
|
** possible that they return invalid values.
|
7213
7795
|
*/
|
7214
|
-
SQLITE_API sqlite3_backup *
|
7796
|
+
SQLITE_API sqlite3_backup *sqlite3_backup_init(
|
7215
7797
|
sqlite3 *pDest, /* Destination database handle */
|
7216
7798
|
const char *zDestName, /* Destination database name */
|
7217
7799
|
sqlite3 *pSource, /* Source database handle */
|
7218
7800
|
const char *zSourceName /* Source database name */
|
7219
7801
|
);
|
7220
|
-
SQLITE_API int
|
7221
|
-
SQLITE_API int
|
7222
|
-
SQLITE_API int
|
7223
|
-
SQLITE_API int
|
7802
|
+
SQLITE_API int sqlite3_backup_step(sqlite3_backup *p, int nPage);
|
7803
|
+
SQLITE_API int sqlite3_backup_finish(sqlite3_backup *p);
|
7804
|
+
SQLITE_API int sqlite3_backup_remaining(sqlite3_backup *p);
|
7805
|
+
SQLITE_API int sqlite3_backup_pagecount(sqlite3_backup *p);
|
7224
7806
|
|
7225
7807
|
/*
|
7226
7808
|
** CAPI3REF: Unlock Notification
|
@@ -7337,7 +7919,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_backup_pagecount(sqlite3_backup *p);
|
|
7337
7919
|
** the special "DROP TABLE/INDEX" case, the extended error code is just
|
7338
7920
|
** SQLITE_LOCKED.)^
|
7339
7921
|
*/
|
7340
|
-
SQLITE_API int
|
7922
|
+
SQLITE_API int sqlite3_unlock_notify(
|
7341
7923
|
sqlite3 *pBlocked, /* Waiting connection */
|
7342
7924
|
void (*xNotify)(void **apArg, int nArg), /* Callback function to invoke */
|
7343
7925
|
void *pNotifyArg /* Argument to pass to xNotify */
|
@@ -7352,23 +7934,48 @@ SQLITE_API int SQLITE_STDCALL sqlite3_unlock_notify(
|
|
7352
7934
|
** strings in a case-independent fashion, using the same definition of "case
|
7353
7935
|
** independence" that SQLite uses internally when comparing identifiers.
|
7354
7936
|
*/
|
7355
|
-
SQLITE_API int
|
7356
|
-
SQLITE_API int
|
7937
|
+
SQLITE_API int sqlite3_stricmp(const char *, const char *);
|
7938
|
+
SQLITE_API int sqlite3_strnicmp(const char *, const char *, int);
|
7357
7939
|
|
7358
7940
|
/*
|
7359
7941
|
** CAPI3REF: String Globbing
|
7360
7942
|
*
|
7361
|
-
** ^The [sqlite3_strglob(P,X)] interface returns zero if
|
7362
|
-
** the
|
7363
|
-
**
|
7943
|
+
** ^The [sqlite3_strglob(P,X)] interface returns zero if and only if
|
7944
|
+
** string X matches the [GLOB] pattern P.
|
7945
|
+
** ^The definition of [GLOB] pattern matching used in
|
7364
7946
|
** [sqlite3_strglob(P,X)] is the same as for the "X GLOB P" operator in the
|
7365
|
-
** SQL dialect
|
7366
|
-
** sensitive.
|
7947
|
+
** SQL dialect understood by SQLite. ^The [sqlite3_strglob(P,X)] function
|
7948
|
+
** is case sensitive.
|
7367
7949
|
**
|
7368
7950
|
** Note that this routine returns zero on a match and non-zero if the strings
|
7369
7951
|
** do not match, the same as [sqlite3_stricmp()] and [sqlite3_strnicmp()].
|
7952
|
+
**
|
7953
|
+
** See also: [sqlite3_strlike()].
|
7370
7954
|
*/
|
7371
|
-
SQLITE_API int
|
7955
|
+
SQLITE_API int sqlite3_strglob(const char *zGlob, const char *zStr);
|
7956
|
+
|
7957
|
+
/*
|
7958
|
+
** CAPI3REF: String LIKE Matching
|
7959
|
+
*
|
7960
|
+
** ^The [sqlite3_strlike(P,X,E)] interface returns zero if and only if
|
7961
|
+
** string X matches the [LIKE] pattern P with escape character E.
|
7962
|
+
** ^The definition of [LIKE] pattern matching used in
|
7963
|
+
** [sqlite3_strlike(P,X,E)] is the same as for the "X LIKE P ESCAPE E"
|
7964
|
+
** operator in the SQL dialect understood by SQLite. ^For "X LIKE P" without
|
7965
|
+
** the ESCAPE clause, set the E parameter of [sqlite3_strlike(P,X,E)] to 0.
|
7966
|
+
** ^As with the LIKE operator, the [sqlite3_strlike(P,X,E)] function is case
|
7967
|
+
** insensitive - equivalent upper and lower case ASCII characters match
|
7968
|
+
** one another.
|
7969
|
+
**
|
7970
|
+
** ^The [sqlite3_strlike(P,X,E)] function matches Unicode characters, though
|
7971
|
+
** only ASCII characters are case folded.
|
7972
|
+
**
|
7973
|
+
** Note that this routine returns zero on a match and non-zero if the strings
|
7974
|
+
** do not match, the same as [sqlite3_stricmp()] and [sqlite3_strnicmp()].
|
7975
|
+
**
|
7976
|
+
** See also: [sqlite3_strglob()].
|
7977
|
+
*/
|
7978
|
+
SQLITE_API int sqlite3_strlike(const char *zGlob, const char *zStr, unsigned int cEsc);
|
7372
7979
|
|
7373
7980
|
/*
|
7374
7981
|
** CAPI3REF: Error Logging Interface
|
@@ -7391,7 +7998,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_strglob(const char *zGlob, const char *zSt
|
|
7391
7998
|
** a few hundred characters, it will be truncated to the length of the
|
7392
7999
|
** buffer.
|
7393
8000
|
*/
|
7394
|
-
SQLITE_API void
|
8001
|
+
SQLITE_API void sqlite3_log(int iErrCode, const char *zFormat, ...);
|
7395
8002
|
|
7396
8003
|
/*
|
7397
8004
|
** CAPI3REF: Write-Ahead Log Commit Hook
|
@@ -7425,9 +8032,9 @@ SQLITE_API void SQLITE_CDECL sqlite3_log(int iErrCode, const char *zFormat, ...)
|
|
7425
8032
|
** previously registered write-ahead log callback. ^Note that the
|
7426
8033
|
** [sqlite3_wal_autocheckpoint()] interface and the
|
7427
8034
|
** [wal_autocheckpoint pragma] both invoke [sqlite3_wal_hook()] and will
|
7428
|
-
**
|
8035
|
+
** overwrite any prior [sqlite3_wal_hook()] settings.
|
7429
8036
|
*/
|
7430
|
-
SQLITE_API void *
|
8037
|
+
SQLITE_API void *sqlite3_wal_hook(
|
7431
8038
|
sqlite3*,
|
7432
8039
|
int(*)(void *,sqlite3*,const char*,int),
|
7433
8040
|
void*
|
@@ -7462,7 +8069,7 @@ SQLITE_API void *SQLITE_STDCALL sqlite3_wal_hook(
|
|
7462
8069
|
** is only necessary if the default setting is found to be suboptimal
|
7463
8070
|
** for a particular application.
|
7464
8071
|
*/
|
7465
|
-
SQLITE_API int
|
8072
|
+
SQLITE_API int sqlite3_wal_autocheckpoint(sqlite3 *db, int N);
|
7466
8073
|
|
7467
8074
|
/*
|
7468
8075
|
** CAPI3REF: Checkpoint a database
|
@@ -7484,7 +8091,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_wal_autocheckpoint(sqlite3 *db, int N);
|
|
7484
8091
|
** start a callback but which do not need the full power (and corresponding
|
7485
8092
|
** complication) of [sqlite3_wal_checkpoint_v2()].
|
7486
8093
|
*/
|
7487
|
-
SQLITE_API int
|
8094
|
+
SQLITE_API int sqlite3_wal_checkpoint(sqlite3 *db, const char *zDb);
|
7488
8095
|
|
7489
8096
|
/*
|
7490
8097
|
** CAPI3REF: Checkpoint a database
|
@@ -7578,7 +8185,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_wal_checkpoint(sqlite3 *db, const char *zD
|
|
7578
8185
|
** ^The [PRAGMA wal_checkpoint] command can be used to invoke this interface
|
7579
8186
|
** from SQL.
|
7580
8187
|
*/
|
7581
|
-
SQLITE_API int
|
8188
|
+
SQLITE_API int sqlite3_wal_checkpoint_v2(
|
7582
8189
|
sqlite3 *db, /* Database handle */
|
7583
8190
|
const char *zDb, /* Name of attached database (or NULL) */
|
7584
8191
|
int eMode, /* SQLITE_CHECKPOINT_* value */
|
@@ -7614,7 +8221,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_wal_checkpoint_v2(
|
|
7614
8221
|
** this function. (See [SQLITE_VTAB_CONSTRAINT_SUPPORT].) Further options
|
7615
8222
|
** may be added in the future.
|
7616
8223
|
*/
|
7617
|
-
SQLITE_API int
|
8224
|
+
SQLITE_API int sqlite3_vtab_config(sqlite3*, int op, ...);
|
7618
8225
|
|
7619
8226
|
/*
|
7620
8227
|
** CAPI3REF: Virtual Table Configuration Options
|
@@ -7667,7 +8274,7 @@ SQLITE_API int SQLITE_CDECL sqlite3_vtab_config(sqlite3*, int op, ...);
|
|
7667
8274
|
** of the SQL statement that triggered the call to the [xUpdate] method of the
|
7668
8275
|
** [virtual table].
|
7669
8276
|
*/
|
7670
|
-
SQLITE_API int
|
8277
|
+
SQLITE_API int sqlite3_vtab_on_conflict(sqlite3 *);
|
7671
8278
|
|
7672
8279
|
/*
|
7673
8280
|
** CAPI3REF: Conflict resolution modes
|
@@ -7772,7 +8379,7 @@ SQLITE_API int SQLITE_STDCALL sqlite3_vtab_on_conflict(sqlite3 *);
|
|
7772
8379
|
**
|
7773
8380
|
** See also: [sqlite3_stmt_scanstatus_reset()]
|
7774
8381
|
*/
|
7775
|
-
SQLITE_API int
|
8382
|
+
SQLITE_API int sqlite3_stmt_scanstatus(
|
7776
8383
|
sqlite3_stmt *pStmt, /* Prepared statement for which info desired */
|
7777
8384
|
int idx, /* Index of loop to report on */
|
7778
8385
|
int iScanStatusOp, /* Information desired. SQLITE_SCANSTAT_* */
|
@@ -7788,8 +8395,332 @@ SQLITE_API int SQLITE_STDCALL sqlite3_stmt_scanstatus(
|
|
7788
8395
|
** This API is only available if the library is built with pre-processor
|
7789
8396
|
** symbol [SQLITE_ENABLE_STMT_SCANSTATUS] defined.
|
7790
8397
|
*/
|
7791
|
-
SQLITE_API void
|
8398
|
+
SQLITE_API void sqlite3_stmt_scanstatus_reset(sqlite3_stmt*);
|
8399
|
+
|
8400
|
+
/*
|
8401
|
+
** CAPI3REF: Flush caches to disk mid-transaction
|
8402
|
+
**
|
8403
|
+
** ^If a write-transaction is open on [database connection] D when the
|
8404
|
+
** [sqlite3_db_cacheflush(D)] interface invoked, any dirty
|
8405
|
+
** pages in the pager-cache that are not currently in use are written out
|
8406
|
+
** to disk. A dirty page may be in use if a database cursor created by an
|
8407
|
+
** active SQL statement is reading from it, or if it is page 1 of a database
|
8408
|
+
** file (page 1 is always "in use"). ^The [sqlite3_db_cacheflush(D)]
|
8409
|
+
** interface flushes caches for all schemas - "main", "temp", and
|
8410
|
+
** any [attached] databases.
|
8411
|
+
**
|
8412
|
+
** ^If this function needs to obtain extra database locks before dirty pages
|
8413
|
+
** can be flushed to disk, it does so. ^If those locks cannot be obtained
|
8414
|
+
** immediately and there is a busy-handler callback configured, it is invoked
|
8415
|
+
** in the usual manner. ^If the required lock still cannot be obtained, then
|
8416
|
+
** the database is skipped and an attempt made to flush any dirty pages
|
8417
|
+
** belonging to the next (if any) database. ^If any databases are skipped
|
8418
|
+
** because locks cannot be obtained, but no other error occurs, this
|
8419
|
+
** function returns SQLITE_BUSY.
|
8420
|
+
**
|
8421
|
+
** ^If any other error occurs while flushing dirty pages to disk (for
|
8422
|
+
** example an IO error or out-of-memory condition), then processing is
|
8423
|
+
** abandoned and an SQLite [error code] is returned to the caller immediately.
|
8424
|
+
**
|
8425
|
+
** ^Otherwise, if no error occurs, [sqlite3_db_cacheflush()] returns SQLITE_OK.
|
8426
|
+
**
|
8427
|
+
** ^This function does not set the database handle error code or message
|
8428
|
+
** returned by the [sqlite3_errcode()] and [sqlite3_errmsg()] functions.
|
8429
|
+
*/
|
8430
|
+
SQLITE_API int sqlite3_db_cacheflush(sqlite3*);
|
8431
|
+
|
8432
|
+
/*
|
8433
|
+
** CAPI3REF: The pre-update hook.
|
8434
|
+
**
|
8435
|
+
** ^These interfaces are only available if SQLite is compiled using the
|
8436
|
+
** [SQLITE_ENABLE_PREUPDATE_HOOK] compile-time option.
|
8437
|
+
**
|
8438
|
+
** ^The [sqlite3_preupdate_hook()] interface registers a callback function
|
8439
|
+
** that is invoked prior to each [INSERT], [UPDATE], and [DELETE] operation
|
8440
|
+
** on a database table.
|
8441
|
+
** ^At most one preupdate hook may be registered at a time on a single
|
8442
|
+
** [database connection]; each call to [sqlite3_preupdate_hook()] overrides
|
8443
|
+
** the previous setting.
|
8444
|
+
** ^The preupdate hook is disabled by invoking [sqlite3_preupdate_hook()]
|
8445
|
+
** with a NULL pointer as the second parameter.
|
8446
|
+
** ^The third parameter to [sqlite3_preupdate_hook()] is passed through as
|
8447
|
+
** the first parameter to callbacks.
|
8448
|
+
**
|
8449
|
+
** ^The preupdate hook only fires for changes to real database tables; the
|
8450
|
+
** preupdate hook is not invoked for changes to [virtual tables] or to
|
8451
|
+
** system tables like sqlite_master or sqlite_stat1.
|
8452
|
+
**
|
8453
|
+
** ^The second parameter to the preupdate callback is a pointer to
|
8454
|
+
** the [database connection] that registered the preupdate hook.
|
8455
|
+
** ^The third parameter to the preupdate callback is one of the constants
|
8456
|
+
** [SQLITE_INSERT], [SQLITE_DELETE], or [SQLITE_UPDATE] to identify the
|
8457
|
+
** kind of update operation that is about to occur.
|
8458
|
+
** ^(The fourth parameter to the preupdate callback is the name of the
|
8459
|
+
** database within the database connection that is being modified. This
|
8460
|
+
** will be "main" for the main database or "temp" for TEMP tables or
|
8461
|
+
** the name given after the AS keyword in the [ATTACH] statement for attached
|
8462
|
+
** databases.)^
|
8463
|
+
** ^The fifth parameter to the preupdate callback is the name of the
|
8464
|
+
** table that is being modified.
|
8465
|
+
**
|
8466
|
+
** For an UPDATE or DELETE operation on a [rowid table], the sixth
|
8467
|
+
** parameter passed to the preupdate callback is the initial [rowid] of the
|
8468
|
+
** row being modified or deleted. For an INSERT operation on a rowid table,
|
8469
|
+
** or any operation on a WITHOUT ROWID table, the value of the sixth
|
8470
|
+
** parameter is undefined. For an INSERT or UPDATE on a rowid table the
|
8471
|
+
** seventh parameter is the final rowid value of the row being inserted
|
8472
|
+
** or updated. The value of the seventh parameter passed to the callback
|
8473
|
+
** function is not defined for operations on WITHOUT ROWID tables, or for
|
8474
|
+
** INSERT operations on rowid tables.
|
8475
|
+
**
|
8476
|
+
** The [sqlite3_preupdate_old()], [sqlite3_preupdate_new()],
|
8477
|
+
** [sqlite3_preupdate_count()], and [sqlite3_preupdate_depth()] interfaces
|
8478
|
+
** provide additional information about a preupdate event. These routines
|
8479
|
+
** may only be called from within a preupdate callback. Invoking any of
|
8480
|
+
** these routines from outside of a preupdate callback or with a
|
8481
|
+
** [database connection] pointer that is different from the one supplied
|
8482
|
+
** to the preupdate callback results in undefined and probably undesirable
|
8483
|
+
** behavior.
|
8484
|
+
**
|
8485
|
+
** ^The [sqlite3_preupdate_count(D)] interface returns the number of columns
|
8486
|
+
** in the row that is being inserted, updated, or deleted.
|
8487
|
+
**
|
8488
|
+
** ^The [sqlite3_preupdate_old(D,N,P)] interface writes into P a pointer to
|
8489
|
+
** a [protected sqlite3_value] that contains the value of the Nth column of
|
8490
|
+
** the table row before it is updated. The N parameter must be between 0
|
8491
|
+
** and one less than the number of columns or the behavior will be
|
8492
|
+
** undefined. This must only be used within SQLITE_UPDATE and SQLITE_DELETE
|
8493
|
+
** preupdate callbacks; if it is used by an SQLITE_INSERT callback then the
|
8494
|
+
** behavior is undefined. The [sqlite3_value] that P points to
|
8495
|
+
** will be destroyed when the preupdate callback returns.
|
8496
|
+
**
|
8497
|
+
** ^The [sqlite3_preupdate_new(D,N,P)] interface writes into P a pointer to
|
8498
|
+
** a [protected sqlite3_value] that contains the value of the Nth column of
|
8499
|
+
** the table row after it is updated. The N parameter must be between 0
|
8500
|
+
** and one less than the number of columns or the behavior will be
|
8501
|
+
** undefined. This must only be used within SQLITE_INSERT and SQLITE_UPDATE
|
8502
|
+
** preupdate callbacks; if it is used by an SQLITE_DELETE callback then the
|
8503
|
+
** behavior is undefined. The [sqlite3_value] that P points to
|
8504
|
+
** will be destroyed when the preupdate callback returns.
|
8505
|
+
**
|
8506
|
+
** ^The [sqlite3_preupdate_depth(D)] interface returns 0 if the preupdate
|
8507
|
+
** callback was invoked as a result of a direct insert, update, or delete
|
8508
|
+
** operation; or 1 for inserts, updates, or deletes invoked by top-level
|
8509
|
+
** triggers; or 2 for changes resulting from triggers called by top-level
|
8510
|
+
** triggers; and so forth.
|
8511
|
+
**
|
8512
|
+
** See also: [sqlite3_update_hook()]
|
8513
|
+
*/
|
8514
|
+
#if defined(SQLITE_ENABLE_PREUPDATE_HOOK)
|
8515
|
+
SQLITE_API void *sqlite3_preupdate_hook(
|
8516
|
+
sqlite3 *db,
|
8517
|
+
void(*xPreUpdate)(
|
8518
|
+
void *pCtx, /* Copy of third arg to preupdate_hook() */
|
8519
|
+
sqlite3 *db, /* Database handle */
|
8520
|
+
int op, /* SQLITE_UPDATE, DELETE or INSERT */
|
8521
|
+
char const *zDb, /* Database name */
|
8522
|
+
char const *zName, /* Table name */
|
8523
|
+
sqlite3_int64 iKey1, /* Rowid of row about to be deleted/updated */
|
8524
|
+
sqlite3_int64 iKey2 /* New rowid value (for a rowid UPDATE) */
|
8525
|
+
),
|
8526
|
+
void*
|
8527
|
+
);
|
8528
|
+
SQLITE_API int sqlite3_preupdate_old(sqlite3 *, int, sqlite3_value **);
|
8529
|
+
SQLITE_API int sqlite3_preupdate_count(sqlite3 *);
|
8530
|
+
SQLITE_API int sqlite3_preupdate_depth(sqlite3 *);
|
8531
|
+
SQLITE_API int sqlite3_preupdate_new(sqlite3 *, int, sqlite3_value **);
|
8532
|
+
#endif
|
8533
|
+
|
8534
|
+
/*
|
8535
|
+
** CAPI3REF: Low-level system error code
|
8536
|
+
**
|
8537
|
+
** ^Attempt to return the underlying operating system error code or error
|
8538
|
+
** number that caused the most recent I/O error or failure to open a file.
|
8539
|
+
** The return value is OS-dependent. For example, on unix systems, after
|
8540
|
+
** [sqlite3_open_v2()] returns [SQLITE_CANTOPEN], this interface could be
|
8541
|
+
** called to get back the underlying "errno" that caused the problem, such
|
8542
|
+
** as ENOSPC, EAUTH, EISDIR, and so forth.
|
8543
|
+
*/
|
8544
|
+
SQLITE_API int sqlite3_system_errno(sqlite3*);
|
8545
|
+
|
8546
|
+
/*
|
8547
|
+
** CAPI3REF: Database Snapshot
|
8548
|
+
** KEYWORDS: {snapshot} {sqlite3_snapshot}
|
8549
|
+
** EXPERIMENTAL
|
8550
|
+
**
|
8551
|
+
** An instance of the snapshot object records the state of a [WAL mode]
|
8552
|
+
** database for some specific point in history.
|
8553
|
+
**
|
8554
|
+
** In [WAL mode], multiple [database connections] that are open on the
|
8555
|
+
** same database file can each be reading a different historical version
|
8556
|
+
** of the database file. When a [database connection] begins a read
|
8557
|
+
** transaction, that connection sees an unchanging copy of the database
|
8558
|
+
** as it existed for the point in time when the transaction first started.
|
8559
|
+
** Subsequent changes to the database from other connections are not seen
|
8560
|
+
** by the reader until a new read transaction is started.
|
8561
|
+
**
|
8562
|
+
** The sqlite3_snapshot object records state information about an historical
|
8563
|
+
** version of the database file so that it is possible to later open a new read
|
8564
|
+
** transaction that sees that historical version of the database rather than
|
8565
|
+
** the most recent version.
|
8566
|
+
**
|
8567
|
+
** The constructor for this object is [sqlite3_snapshot_get()]. The
|
8568
|
+
** [sqlite3_snapshot_open()] method causes a fresh read transaction to refer
|
8569
|
+
** to an historical snapshot (if possible). The destructor for
|
8570
|
+
** sqlite3_snapshot objects is [sqlite3_snapshot_free()].
|
8571
|
+
*/
|
8572
|
+
typedef struct sqlite3_snapshot {
|
8573
|
+
unsigned char hidden[48];
|
8574
|
+
} sqlite3_snapshot;
|
8575
|
+
|
8576
|
+
/*
|
8577
|
+
** CAPI3REF: Record A Database Snapshot
|
8578
|
+
** EXPERIMENTAL
|
8579
|
+
**
|
8580
|
+
** ^The [sqlite3_snapshot_get(D,S,P)] interface attempts to make a
|
8581
|
+
** new [sqlite3_snapshot] object that records the current state of
|
8582
|
+
** schema S in database connection D. ^On success, the
|
8583
|
+
** [sqlite3_snapshot_get(D,S,P)] interface writes a pointer to the newly
|
8584
|
+
** created [sqlite3_snapshot] object into *P and returns SQLITE_OK.
|
8585
|
+
** If there is not already a read-transaction open on schema S when
|
8586
|
+
** this function is called, one is opened automatically.
|
8587
|
+
**
|
8588
|
+
** The following must be true for this function to succeed. If any of
|
8589
|
+
** the following statements are false when sqlite3_snapshot_get() is
|
8590
|
+
** called, SQLITE_ERROR is returned. The final value of *P is undefined
|
8591
|
+
** in this case.
|
8592
|
+
**
|
8593
|
+
** <ul>
|
8594
|
+
** <li> The database handle must be in [autocommit mode].
|
8595
|
+
**
|
8596
|
+
** <li> Schema S of [database connection] D must be a [WAL mode] database.
|
8597
|
+
**
|
8598
|
+
** <li> There must not be a write transaction open on schema S of database
|
8599
|
+
** connection D.
|
8600
|
+
**
|
8601
|
+
** <li> One or more transactions must have been written to the current wal
|
8602
|
+
** file since it was created on disk (by any connection). This means
|
8603
|
+
** that a snapshot cannot be taken on a wal mode database with no wal
|
8604
|
+
** file immediately after it is first opened. At least one transaction
|
8605
|
+
** must be written to it first.
|
8606
|
+
** </ul>
|
8607
|
+
**
|
8608
|
+
** This function may also return SQLITE_NOMEM. If it is called with the
|
8609
|
+
** database handle in autocommit mode but fails for some other reason,
|
8610
|
+
** whether or not a read transaction is opened on schema S is undefined.
|
8611
|
+
**
|
8612
|
+
** The [sqlite3_snapshot] object returned from a successful call to
|
8613
|
+
** [sqlite3_snapshot_get()] must be freed using [sqlite3_snapshot_free()]
|
8614
|
+
** to avoid a memory leak.
|
8615
|
+
**
|
8616
|
+
** The [sqlite3_snapshot_get()] interface is only available when the
|
8617
|
+
** SQLITE_ENABLE_SNAPSHOT compile-time option is used.
|
8618
|
+
*/
|
8619
|
+
SQLITE_API SQLITE_EXPERIMENTAL int sqlite3_snapshot_get(
|
8620
|
+
sqlite3 *db,
|
8621
|
+
const char *zSchema,
|
8622
|
+
sqlite3_snapshot **ppSnapshot
|
8623
|
+
);
|
8624
|
+
|
8625
|
+
/*
|
8626
|
+
** CAPI3REF: Start a read transaction on an historical snapshot
|
8627
|
+
** EXPERIMENTAL
|
8628
|
+
**
|
8629
|
+
** ^The [sqlite3_snapshot_open(D,S,P)] interface starts a
|
8630
|
+
** read transaction for schema S of
|
8631
|
+
** [database connection] D such that the read transaction
|
8632
|
+
** refers to historical [snapshot] P, rather than the most
|
8633
|
+
** recent change to the database.
|
8634
|
+
** ^The [sqlite3_snapshot_open()] interface returns SQLITE_OK on success
|
8635
|
+
** or an appropriate [error code] if it fails.
|
8636
|
+
**
|
8637
|
+
** ^In order to succeed, a call to [sqlite3_snapshot_open(D,S,P)] must be
|
8638
|
+
** the first operation following the [BEGIN] that takes the schema S
|
8639
|
+
** out of [autocommit mode].
|
8640
|
+
** ^In other words, schema S must not currently be in
|
8641
|
+
** a transaction for [sqlite3_snapshot_open(D,S,P)] to work, but the
|
8642
|
+
** database connection D must be out of [autocommit mode].
|
8643
|
+
** ^A [snapshot] will fail to open if it has been overwritten by a
|
8644
|
+
** [checkpoint].
|
8645
|
+
** ^(A call to [sqlite3_snapshot_open(D,S,P)] will fail if the
|
8646
|
+
** database connection D does not know that the database file for
|
8647
|
+
** schema S is in [WAL mode]. A database connection might not know
|
8648
|
+
** that the database file is in [WAL mode] if there has been no prior
|
8649
|
+
** I/O on that database connection, or if the database entered [WAL mode]
|
8650
|
+
** after the most recent I/O on the database connection.)^
|
8651
|
+
** (Hint: Run "[PRAGMA application_id]" against a newly opened
|
8652
|
+
** database connection in order to make it ready to use snapshots.)
|
8653
|
+
**
|
8654
|
+
** The [sqlite3_snapshot_open()] interface is only available when the
|
8655
|
+
** SQLITE_ENABLE_SNAPSHOT compile-time option is used.
|
8656
|
+
*/
|
8657
|
+
SQLITE_API SQLITE_EXPERIMENTAL int sqlite3_snapshot_open(
|
8658
|
+
sqlite3 *db,
|
8659
|
+
const char *zSchema,
|
8660
|
+
sqlite3_snapshot *pSnapshot
|
8661
|
+
);
|
8662
|
+
|
8663
|
+
/*
|
8664
|
+
** CAPI3REF: Destroy a snapshot
|
8665
|
+
** EXPERIMENTAL
|
8666
|
+
**
|
8667
|
+
** ^The [sqlite3_snapshot_free(P)] interface destroys [sqlite3_snapshot] P.
|
8668
|
+
** The application must eventually free every [sqlite3_snapshot] object
|
8669
|
+
** using this routine to avoid a memory leak.
|
8670
|
+
**
|
8671
|
+
** The [sqlite3_snapshot_free()] interface is only available when the
|
8672
|
+
** SQLITE_ENABLE_SNAPSHOT compile-time option is used.
|
8673
|
+
*/
|
8674
|
+
SQLITE_API SQLITE_EXPERIMENTAL void sqlite3_snapshot_free(sqlite3_snapshot*);
|
8675
|
+
|
8676
|
+
/*
|
8677
|
+
** CAPI3REF: Compare the ages of two snapshot handles.
|
8678
|
+
** EXPERIMENTAL
|
8679
|
+
**
|
8680
|
+
** The sqlite3_snapshot_cmp(P1, P2) interface is used to compare the ages
|
8681
|
+
** of two valid snapshot handles.
|
8682
|
+
**
|
8683
|
+
** If the two snapshot handles are not associated with the same database
|
8684
|
+
** file, the result of the comparison is undefined.
|
8685
|
+
**
|
8686
|
+
** Additionally, the result of the comparison is only valid if both of the
|
8687
|
+
** snapshot handles were obtained by calling sqlite3_snapshot_get() since the
|
8688
|
+
** last time the wal file was deleted. The wal file is deleted when the
|
8689
|
+
** database is changed back to rollback mode or when the number of database
|
8690
|
+
** clients drops to zero. If either snapshot handle was obtained before the
|
8691
|
+
** wal file was last deleted, the value returned by this function
|
8692
|
+
** is undefined.
|
8693
|
+
**
|
8694
|
+
** Otherwise, this API returns a negative value if P1 refers to an older
|
8695
|
+
** snapshot than P2, zero if the two handles refer to the same database
|
8696
|
+
** snapshot, and a positive value if P1 is a newer snapshot than P2.
|
8697
|
+
*/
|
8698
|
+
SQLITE_API SQLITE_EXPERIMENTAL int sqlite3_snapshot_cmp(
|
8699
|
+
sqlite3_snapshot *p1,
|
8700
|
+
sqlite3_snapshot *p2
|
8701
|
+
);
|
7792
8702
|
|
8703
|
+
/*
|
8704
|
+
** CAPI3REF: Recover snapshots from a wal file
|
8705
|
+
** EXPERIMENTAL
|
8706
|
+
**
|
8707
|
+
** If all connections disconnect from a database file but do not perform
|
8708
|
+
** a checkpoint, the existing wal file is opened along with the database
|
8709
|
+
** file the next time the database is opened. At this point it is only
|
8710
|
+
** possible to successfully call sqlite3_snapshot_open() to open the most
|
8711
|
+
** recent snapshot of the database (the one at the head of the wal file),
|
8712
|
+
** even though the wal file may contain other valid snapshots for which
|
8713
|
+
** clients have sqlite3_snapshot handles.
|
8714
|
+
**
|
8715
|
+
** This function attempts to scan the wal file associated with database zDb
|
8716
|
+
** of database handle db and make all valid snapshots available to
|
8717
|
+
** sqlite3_snapshot_open(). It is an error if there is already a read
|
8718
|
+
** transaction open on the database, or if the database is not a wal mode
|
8719
|
+
** database.
|
8720
|
+
**
|
8721
|
+
** SQLITE_OK is returned if successful, or an SQLite error code otherwise.
|
8722
|
+
*/
|
8723
|
+
SQLITE_API SQLITE_EXPERIMENTAL int sqlite3_snapshot_recover(sqlite3 *db, const char *zDb);
|
7793
8724
|
|
7794
8725
|
/*
|
7795
8726
|
** Undo the hack that converts floating point types to integer for
|
@@ -7802,8 +8733,9 @@ SQLITE_API void SQLITE_STDCALL sqlite3_stmt_scanstatus_reset(sqlite3_stmt*);
|
|
7802
8733
|
#ifdef __cplusplus
|
7803
8734
|
} /* End of the 'extern "C"' block */
|
7804
8735
|
#endif
|
7805
|
-
#endif /*
|
8736
|
+
#endif /* SQLITE3_H */
|
7806
8737
|
|
8738
|
+
/******** Begin file sqlite3rtree.h *********/
|
7807
8739
|
/*
|
7808
8740
|
** 2010 August 30
|
7809
8741
|
**
|
@@ -7843,7 +8775,7 @@ typedef struct sqlite3_rtree_query_info sqlite3_rtree_query_info;
|
|
7843
8775
|
**
|
7844
8776
|
** SELECT ... FROM <rtree> WHERE <rtree col> MATCH $zGeom(... params ...)
|
7845
8777
|
*/
|
7846
|
-
SQLITE_API int
|
8778
|
+
SQLITE_API int sqlite3_rtree_geometry_callback(
|
7847
8779
|
sqlite3 *db,
|
7848
8780
|
const char *zGeom,
|
7849
8781
|
int (*xGeom)(sqlite3_rtree_geometry*, int, sqlite3_rtree_dbl*,int*),
|
@@ -7869,7 +8801,7 @@ struct sqlite3_rtree_geometry {
|
|
7869
8801
|
**
|
7870
8802
|
** SELECT ... FROM <rtree> WHERE <rtree col> MATCH $zQueryFunc(... params ...)
|
7871
8803
|
*/
|
7872
|
-
SQLITE_API int
|
8804
|
+
SQLITE_API int sqlite3_rtree_query_callback(
|
7873
8805
|
sqlite3 *db,
|
7874
8806
|
const char *zQueryFunc,
|
7875
8807
|
int (*xQueryFunc)(sqlite3_rtree_query_info*),
|
@@ -7921,6 +8853,1298 @@ struct sqlite3_rtree_query_info {
|
|
7921
8853
|
|
7922
8854
|
#endif /* ifndef _SQLITE3RTREE_H_ */
|
7923
8855
|
|
8856
|
+
/******** End of sqlite3rtree.h *********/
|
8857
|
+
/******** Begin file sqlite3session.h *********/
|
8858
|
+
|
8859
|
+
#if !defined(__SQLITESESSION_H_) && defined(SQLITE_ENABLE_SESSION)
|
8860
|
+
#define __SQLITESESSION_H_ 1
|
8861
|
+
|
8862
|
+
/*
|
8863
|
+
** Make sure we can call this stuff from C++.
|
8864
|
+
*/
|
8865
|
+
#ifdef __cplusplus
|
8866
|
+
extern "C" {
|
8867
|
+
#endif
|
8868
|
+
|
8869
|
+
|
8870
|
+
/*
|
8871
|
+
** CAPI3REF: Session Object Handle
|
8872
|
+
*/
|
8873
|
+
typedef struct sqlite3_session sqlite3_session;
|
8874
|
+
|
8875
|
+
/*
|
8876
|
+
** CAPI3REF: Changeset Iterator Handle
|
8877
|
+
*/
|
8878
|
+
typedef struct sqlite3_changeset_iter sqlite3_changeset_iter;
|
8879
|
+
|
8880
|
+
/*
|
8881
|
+
** CAPI3REF: Create A New Session Object
|
8882
|
+
**
|
8883
|
+
** Create a new session object attached to database handle db. If successful,
|
8884
|
+
** a pointer to the new object is written to *ppSession and SQLITE_OK is
|
8885
|
+
** returned. If an error occurs, *ppSession is set to NULL and an SQLite
|
8886
|
+
** error code (e.g. SQLITE_NOMEM) is returned.
|
8887
|
+
**
|
8888
|
+
** It is possible to create multiple session objects attached to a single
|
8889
|
+
** database handle.
|
8890
|
+
**
|
8891
|
+
** Session objects created using this function should be deleted using the
|
8892
|
+
** [sqlite3session_delete()] function before the database handle that they
|
8893
|
+
** are attached to is itself closed. If the database handle is closed before
|
8894
|
+
** the session object is deleted, then the results of calling any session
|
8895
|
+
** module function, including [sqlite3session_delete()] on the session object
|
8896
|
+
** are undefined.
|
8897
|
+
**
|
8898
|
+
** Because the session module uses the [sqlite3_preupdate_hook()] API, it
|
8899
|
+
** is not possible for an application to register a pre-update hook on a
|
8900
|
+
** database handle that has one or more session objects attached. Nor is
|
8901
|
+
** it possible to create a session object attached to a database handle for
|
8902
|
+
** which a pre-update hook is already defined. The results of attempting
|
8903
|
+
** either of these things are undefined.
|
8904
|
+
**
|
8905
|
+
** The session object will be used to create changesets for tables in
|
8906
|
+
** database zDb, where zDb is either "main", or "temp", or the name of an
|
8907
|
+
** attached database. It is not an error if database zDb is not attached
|
8908
|
+
** to the database when the session object is created.
|
8909
|
+
*/
|
8910
|
+
SQLITE_API int sqlite3session_create(
|
8911
|
+
sqlite3 *db, /* Database handle */
|
8912
|
+
const char *zDb, /* Name of db (e.g. "main") */
|
8913
|
+
sqlite3_session **ppSession /* OUT: New session object */
|
8914
|
+
);
|
8915
|
+
|
8916
|
+
/*
|
8917
|
+
** CAPI3REF: Delete A Session Object
|
8918
|
+
**
|
8919
|
+
** Delete a session object previously allocated using
|
8920
|
+
** [sqlite3session_create()]. Once a session object has been deleted, the
|
8921
|
+
** results of attempting to use pSession with any other session module
|
8922
|
+
** function are undefined.
|
8923
|
+
**
|
8924
|
+
** Session objects must be deleted before the database handle to which they
|
8925
|
+
** are attached is closed. Refer to the documentation for
|
8926
|
+
** [sqlite3session_create()] for details.
|
8927
|
+
*/
|
8928
|
+
SQLITE_API void sqlite3session_delete(sqlite3_session *pSession);
|
8929
|
+
|
8930
|
+
|
8931
|
+
/*
|
8932
|
+
** CAPI3REF: Enable Or Disable A Session Object
|
8933
|
+
**
|
8934
|
+
** Enable or disable the recording of changes by a session object. When
|
8935
|
+
** enabled, a session object records changes made to the database. When
|
8936
|
+
** disabled - it does not. A newly created session object is enabled.
|
8937
|
+
** Refer to the documentation for [sqlite3session_changeset()] for further
|
8938
|
+
** details regarding how enabling and disabling a session object affects
|
8939
|
+
** the eventual changesets.
|
8940
|
+
**
|
8941
|
+
** Passing zero to this function disables the session. Passing a value
|
8942
|
+
** greater than zero enables it. Passing a value less than zero is a
|
8943
|
+
** no-op, and may be used to query the current state of the session.
|
8944
|
+
**
|
8945
|
+
** The return value indicates the final state of the session object: 0 if
|
8946
|
+
** the session is disabled, or 1 if it is enabled.
|
8947
|
+
*/
|
8948
|
+
SQLITE_API int sqlite3session_enable(sqlite3_session *pSession, int bEnable);
|
8949
|
+
|
8950
|
+
/*
|
8951
|
+
** CAPI3REF: Set Or Clear the Indirect Change Flag
|
8952
|
+
**
|
8953
|
+
** Each change recorded by a session object is marked as either direct or
|
8954
|
+
** indirect. A change is marked as indirect if either:
|
8955
|
+
**
|
8956
|
+
** <ul>
|
8957
|
+
** <li> The session object "indirect" flag is set when the change is
|
8958
|
+
** made, or
|
8959
|
+
** <li> The change is made by an SQL trigger or foreign key action
|
8960
|
+
** instead of directly as a result of a users SQL statement.
|
8961
|
+
** </ul>
|
8962
|
+
**
|
8963
|
+
** If a single row is affected by more than one operation within a session,
|
8964
|
+
** then the change is considered indirect if all operations meet the criteria
|
8965
|
+
** for an indirect change above, or direct otherwise.
|
8966
|
+
**
|
8967
|
+
** This function is used to set, clear or query the session object indirect
|
8968
|
+
** flag. If the second argument passed to this function is zero, then the
|
8969
|
+
** indirect flag is cleared. If it is greater than zero, the indirect flag
|
8970
|
+
** is set. Passing a value less than zero does not modify the current value
|
8971
|
+
** of the indirect flag, and may be used to query the current state of the
|
8972
|
+
** indirect flag for the specified session object.
|
8973
|
+
**
|
8974
|
+
** The return value indicates the final state of the indirect flag: 0 if
|
8975
|
+
** it is clear, or 1 if it is set.
|
8976
|
+
*/
|
8977
|
+
SQLITE_API int sqlite3session_indirect(sqlite3_session *pSession, int bIndirect);
|
8978
|
+
|
8979
|
+
/*
|
8980
|
+
** CAPI3REF: Attach A Table To A Session Object
|
8981
|
+
**
|
8982
|
+
** If argument zTab is not NULL, then it is the name of a table to attach
|
8983
|
+
** to the session object passed as the first argument. All subsequent changes
|
8984
|
+
** made to the table while the session object is enabled will be recorded. See
|
8985
|
+
** documentation for [sqlite3session_changeset()] for further details.
|
8986
|
+
**
|
8987
|
+
** Or, if argument zTab is NULL, then changes are recorded for all tables
|
8988
|
+
** in the database. If additional tables are added to the database (by
|
8989
|
+
** executing "CREATE TABLE" statements) after this call is made, changes for
|
8990
|
+
** the new tables are also recorded.
|
8991
|
+
**
|
8992
|
+
** Changes can only be recorded for tables that have a PRIMARY KEY explicitly
|
8993
|
+
** defined as part of their CREATE TABLE statement. It does not matter if the
|
8994
|
+
** PRIMARY KEY is an "INTEGER PRIMARY KEY" (rowid alias) or not. The PRIMARY
|
8995
|
+
** KEY may consist of a single column, or may be a composite key.
|
8996
|
+
**
|
8997
|
+
** It is not an error if the named table does not exist in the database. Nor
|
8998
|
+
** is it an error if the named table does not have a PRIMARY KEY. However,
|
8999
|
+
** no changes will be recorded in either of these scenarios.
|
9000
|
+
**
|
9001
|
+
** Changes are not recorded for individual rows that have NULL values stored
|
9002
|
+
** in one or more of their PRIMARY KEY columns.
|
9003
|
+
**
|
9004
|
+
** SQLITE_OK is returned if the call completes without error. Or, if an error
|
9005
|
+
** occurs, an SQLite error code (e.g. SQLITE_NOMEM) is returned.
|
9006
|
+
*/
|
9007
|
+
SQLITE_API int sqlite3session_attach(
|
9008
|
+
sqlite3_session *pSession, /* Session object */
|
9009
|
+
const char *zTab /* Table name */
|
9010
|
+
);
|
9011
|
+
|
9012
|
+
/*
|
9013
|
+
** CAPI3REF: Set a table filter on a Session Object.
|
9014
|
+
**
|
9015
|
+
** The second argument (xFilter) is the "filter callback". For changes to rows
|
9016
|
+
** in tables that are not attached to the Session object, the filter is called
|
9017
|
+
** to determine whether changes to the table's rows should be tracked or not.
|
9018
|
+
** If xFilter returns 0, changes is not tracked. Note that once a table is
|
9019
|
+
** attached, xFilter will not be called again.
|
9020
|
+
*/
|
9021
|
+
SQLITE_API void sqlite3session_table_filter(
|
9022
|
+
sqlite3_session *pSession, /* Session object */
|
9023
|
+
int(*xFilter)(
|
9024
|
+
void *pCtx, /* Copy of third arg to _filter_table() */
|
9025
|
+
const char *zTab /* Table name */
|
9026
|
+
),
|
9027
|
+
void *pCtx /* First argument passed to xFilter */
|
9028
|
+
);
|
9029
|
+
|
9030
|
+
/*
|
9031
|
+
** CAPI3REF: Generate A Changeset From A Session Object
|
9032
|
+
**
|
9033
|
+
** Obtain a changeset containing changes to the tables attached to the
|
9034
|
+
** session object passed as the first argument. If successful,
|
9035
|
+
** set *ppChangeset to point to a buffer containing the changeset
|
9036
|
+
** and *pnChangeset to the size of the changeset in bytes before returning
|
9037
|
+
** SQLITE_OK. If an error occurs, set both *ppChangeset and *pnChangeset to
|
9038
|
+
** zero and return an SQLite error code.
|
9039
|
+
**
|
9040
|
+
** A changeset consists of zero or more INSERT, UPDATE and/or DELETE changes,
|
9041
|
+
** each representing a change to a single row of an attached table. An INSERT
|
9042
|
+
** change contains the values of each field of a new database row. A DELETE
|
9043
|
+
** contains the original values of each field of a deleted database row. An
|
9044
|
+
** UPDATE change contains the original values of each field of an updated
|
9045
|
+
** database row along with the updated values for each updated non-primary-key
|
9046
|
+
** column. It is not possible for an UPDATE change to represent a change that
|
9047
|
+
** modifies the values of primary key columns. If such a change is made, it
|
9048
|
+
** is represented in a changeset as a DELETE followed by an INSERT.
|
9049
|
+
**
|
9050
|
+
** Changes are not recorded for rows that have NULL values stored in one or
|
9051
|
+
** more of their PRIMARY KEY columns. If such a row is inserted or deleted,
|
9052
|
+
** no corresponding change is present in the changesets returned by this
|
9053
|
+
** function. If an existing row with one or more NULL values stored in
|
9054
|
+
** PRIMARY KEY columns is updated so that all PRIMARY KEY columns are non-NULL,
|
9055
|
+
** only an INSERT is appears in the changeset. Similarly, if an existing row
|
9056
|
+
** with non-NULL PRIMARY KEY values is updated so that one or more of its
|
9057
|
+
** PRIMARY KEY columns are set to NULL, the resulting changeset contains a
|
9058
|
+
** DELETE change only.
|
9059
|
+
**
|
9060
|
+
** The contents of a changeset may be traversed using an iterator created
|
9061
|
+
** using the [sqlite3changeset_start()] API. A changeset may be applied to
|
9062
|
+
** a database with a compatible schema using the [sqlite3changeset_apply()]
|
9063
|
+
** API.
|
9064
|
+
**
|
9065
|
+
** Within a changeset generated by this function, all changes related to a
|
9066
|
+
** single table are grouped together. In other words, when iterating through
|
9067
|
+
** a changeset or when applying a changeset to a database, all changes related
|
9068
|
+
** to a single table are processed before moving on to the next table. Tables
|
9069
|
+
** are sorted in the same order in which they were attached (or auto-attached)
|
9070
|
+
** to the sqlite3_session object. The order in which the changes related to
|
9071
|
+
** a single table are stored is undefined.
|
9072
|
+
**
|
9073
|
+
** Following a successful call to this function, it is the responsibility of
|
9074
|
+
** the caller to eventually free the buffer that *ppChangeset points to using
|
9075
|
+
** [sqlite3_free()].
|
9076
|
+
**
|
9077
|
+
** <h3>Changeset Generation</h3>
|
9078
|
+
**
|
9079
|
+
** Once a table has been attached to a session object, the session object
|
9080
|
+
** records the primary key values of all new rows inserted into the table.
|
9081
|
+
** It also records the original primary key and other column values of any
|
9082
|
+
** deleted or updated rows. For each unique primary key value, data is only
|
9083
|
+
** recorded once - the first time a row with said primary key is inserted,
|
9084
|
+
** updated or deleted in the lifetime of the session.
|
9085
|
+
**
|
9086
|
+
** There is one exception to the previous paragraph: when a row is inserted,
|
9087
|
+
** updated or deleted, if one or more of its primary key columns contain a
|
9088
|
+
** NULL value, no record of the change is made.
|
9089
|
+
**
|
9090
|
+
** The session object therefore accumulates two types of records - those
|
9091
|
+
** that consist of primary key values only (created when the user inserts
|
9092
|
+
** a new record) and those that consist of the primary key values and the
|
9093
|
+
** original values of other table columns (created when the users deletes
|
9094
|
+
** or updates a record).
|
9095
|
+
**
|
9096
|
+
** When this function is called, the requested changeset is created using
|
9097
|
+
** both the accumulated records and the current contents of the database
|
9098
|
+
** file. Specifically:
|
9099
|
+
**
|
9100
|
+
** <ul>
|
9101
|
+
** <li> For each record generated by an insert, the database is queried
|
9102
|
+
** for a row with a matching primary key. If one is found, an INSERT
|
9103
|
+
** change is added to the changeset. If no such row is found, no change
|
9104
|
+
** is added to the changeset.
|
9105
|
+
**
|
9106
|
+
** <li> For each record generated by an update or delete, the database is
|
9107
|
+
** queried for a row with a matching primary key. If such a row is
|
9108
|
+
** found and one or more of the non-primary key fields have been
|
9109
|
+
** modified from their original values, an UPDATE change is added to
|
9110
|
+
** the changeset. Or, if no such row is found in the table, a DELETE
|
9111
|
+
** change is added to the changeset. If there is a row with a matching
|
9112
|
+
** primary key in the database, but all fields contain their original
|
9113
|
+
** values, no change is added to the changeset.
|
9114
|
+
** </ul>
|
9115
|
+
**
|
9116
|
+
** This means, amongst other things, that if a row is inserted and then later
|
9117
|
+
** deleted while a session object is active, neither the insert nor the delete
|
9118
|
+
** will be present in the changeset. Or if a row is deleted and then later a
|
9119
|
+
** row with the same primary key values inserted while a session object is
|
9120
|
+
** active, the resulting changeset will contain an UPDATE change instead of
|
9121
|
+
** a DELETE and an INSERT.
|
9122
|
+
**
|
9123
|
+
** When a session object is disabled (see the [sqlite3session_enable()] API),
|
9124
|
+
** it does not accumulate records when rows are inserted, updated or deleted.
|
9125
|
+
** This may appear to have some counter-intuitive effects if a single row
|
9126
|
+
** is written to more than once during a session. For example, if a row
|
9127
|
+
** is inserted while a session object is enabled, then later deleted while
|
9128
|
+
** the same session object is disabled, no INSERT record will appear in the
|
9129
|
+
** changeset, even though the delete took place while the session was disabled.
|
9130
|
+
** Or, if one field of a row is updated while a session is disabled, and
|
9131
|
+
** another field of the same row is updated while the session is enabled, the
|
9132
|
+
** resulting changeset will contain an UPDATE change that updates both fields.
|
9133
|
+
*/
|
9134
|
+
SQLITE_API int sqlite3session_changeset(
|
9135
|
+
sqlite3_session *pSession, /* Session object */
|
9136
|
+
int *pnChangeset, /* OUT: Size of buffer at *ppChangeset */
|
9137
|
+
void **ppChangeset /* OUT: Buffer containing changeset */
|
9138
|
+
);
|
9139
|
+
|
9140
|
+
/*
|
9141
|
+
** CAPI3REF: Load The Difference Between Tables Into A Session
|
9142
|
+
**
|
9143
|
+
** If it is not already attached to the session object passed as the first
|
9144
|
+
** argument, this function attaches table zTbl in the same manner as the
|
9145
|
+
** [sqlite3session_attach()] function. If zTbl does not exist, or if it
|
9146
|
+
** does not have a primary key, this function is a no-op (but does not return
|
9147
|
+
** an error).
|
9148
|
+
**
|
9149
|
+
** Argument zFromDb must be the name of a database ("main", "temp" etc.)
|
9150
|
+
** attached to the same database handle as the session object that contains
|
9151
|
+
** a table compatible with the table attached to the session by this function.
|
9152
|
+
** A table is considered compatible if it:
|
9153
|
+
**
|
9154
|
+
** <ul>
|
9155
|
+
** <li> Has the same name,
|
9156
|
+
** <li> Has the same set of columns declared in the same order, and
|
9157
|
+
** <li> Has the same PRIMARY KEY definition.
|
9158
|
+
** </ul>
|
9159
|
+
**
|
9160
|
+
** If the tables are not compatible, SQLITE_SCHEMA is returned. If the tables
|
9161
|
+
** are compatible but do not have any PRIMARY KEY columns, it is not an error
|
9162
|
+
** but no changes are added to the session object. As with other session
|
9163
|
+
** APIs, tables without PRIMARY KEYs are simply ignored.
|
9164
|
+
**
|
9165
|
+
** This function adds a set of changes to the session object that could be
|
9166
|
+
** used to update the table in database zFrom (call this the "from-table")
|
9167
|
+
** so that its content is the same as the table attached to the session
|
9168
|
+
** object (call this the "to-table"). Specifically:
|
9169
|
+
**
|
9170
|
+
** <ul>
|
9171
|
+
** <li> For each row (primary key) that exists in the to-table but not in
|
9172
|
+
** the from-table, an INSERT record is added to the session object.
|
9173
|
+
**
|
9174
|
+
** <li> For each row (primary key) that exists in the to-table but not in
|
9175
|
+
** the from-table, a DELETE record is added to the session object.
|
9176
|
+
**
|
9177
|
+
** <li> For each row (primary key) that exists in both tables, but features
|
9178
|
+
** different non-PK values in each, an UPDATE record is added to the
|
9179
|
+
** session.
|
9180
|
+
** </ul>
|
9181
|
+
**
|
9182
|
+
** To clarify, if this function is called and then a changeset constructed
|
9183
|
+
** using [sqlite3session_changeset()], then after applying that changeset to
|
9184
|
+
** database zFrom the contents of the two compatible tables would be
|
9185
|
+
** identical.
|
9186
|
+
**
|
9187
|
+
** It an error if database zFrom does not exist or does not contain the
|
9188
|
+
** required compatible table.
|
9189
|
+
**
|
9190
|
+
** If the operation successful, SQLITE_OK is returned. Otherwise, an SQLite
|
9191
|
+
** error code. In this case, if argument pzErrMsg is not NULL, *pzErrMsg
|
9192
|
+
** may be set to point to a buffer containing an English language error
|
9193
|
+
** message. It is the responsibility of the caller to free this buffer using
|
9194
|
+
** sqlite3_free().
|
9195
|
+
*/
|
9196
|
+
SQLITE_API int sqlite3session_diff(
|
9197
|
+
sqlite3_session *pSession,
|
9198
|
+
const char *zFromDb,
|
9199
|
+
const char *zTbl,
|
9200
|
+
char **pzErrMsg
|
9201
|
+
);
|
9202
|
+
|
9203
|
+
|
9204
|
+
/*
|
9205
|
+
** CAPI3REF: Generate A Patchset From A Session Object
|
9206
|
+
**
|
9207
|
+
** The differences between a patchset and a changeset are that:
|
9208
|
+
**
|
9209
|
+
** <ul>
|
9210
|
+
** <li> DELETE records consist of the primary key fields only. The
|
9211
|
+
** original values of other fields are omitted.
|
9212
|
+
** <li> The original values of any modified fields are omitted from
|
9213
|
+
** UPDATE records.
|
9214
|
+
** </ul>
|
9215
|
+
**
|
9216
|
+
** A patchset blob may be used with up to date versions of all
|
9217
|
+
** sqlite3changeset_xxx API functions except for sqlite3changeset_invert(),
|
9218
|
+
** which returns SQLITE_CORRUPT if it is passed a patchset. Similarly,
|
9219
|
+
** attempting to use a patchset blob with old versions of the
|
9220
|
+
** sqlite3changeset_xxx APIs also provokes an SQLITE_CORRUPT error.
|
9221
|
+
**
|
9222
|
+
** Because the non-primary key "old.*" fields are omitted, no
|
9223
|
+
** SQLITE_CHANGESET_DATA conflicts can be detected or reported if a patchset
|
9224
|
+
** is passed to the sqlite3changeset_apply() API. Other conflict types work
|
9225
|
+
** in the same way as for changesets.
|
9226
|
+
**
|
9227
|
+
** Changes within a patchset are ordered in the same way as for changesets
|
9228
|
+
** generated by the sqlite3session_changeset() function (i.e. all changes for
|
9229
|
+
** a single table are grouped together, tables appear in the order in which
|
9230
|
+
** they were attached to the session object).
|
9231
|
+
*/
|
9232
|
+
SQLITE_API int sqlite3session_patchset(
|
9233
|
+
sqlite3_session *pSession, /* Session object */
|
9234
|
+
int *pnPatchset, /* OUT: Size of buffer at *ppPatchset */
|
9235
|
+
void **ppPatchset /* OUT: Buffer containing patchset */
|
9236
|
+
);
|
9237
|
+
|
9238
|
+
/*
|
9239
|
+
** CAPI3REF: Test if a changeset has recorded any changes.
|
9240
|
+
**
|
9241
|
+
** Return non-zero if no changes to attached tables have been recorded by
|
9242
|
+
** the session object passed as the first argument. Otherwise, if one or
|
9243
|
+
** more changes have been recorded, return zero.
|
9244
|
+
**
|
9245
|
+
** Even if this function returns zero, it is possible that calling
|
9246
|
+
** [sqlite3session_changeset()] on the session handle may still return a
|
9247
|
+
** changeset that contains no changes. This can happen when a row in
|
9248
|
+
** an attached table is modified and then later on the original values
|
9249
|
+
** are restored. However, if this function returns non-zero, then it is
|
9250
|
+
** guaranteed that a call to sqlite3session_changeset() will return a
|
9251
|
+
** changeset containing zero changes.
|
9252
|
+
*/
|
9253
|
+
SQLITE_API int sqlite3session_isempty(sqlite3_session *pSession);
|
9254
|
+
|
9255
|
+
/*
|
9256
|
+
** CAPI3REF: Create An Iterator To Traverse A Changeset
|
9257
|
+
**
|
9258
|
+
** Create an iterator used to iterate through the contents of a changeset.
|
9259
|
+
** If successful, *pp is set to point to the iterator handle and SQLITE_OK
|
9260
|
+
** is returned. Otherwise, if an error occurs, *pp is set to zero and an
|
9261
|
+
** SQLite error code is returned.
|
9262
|
+
**
|
9263
|
+
** The following functions can be used to advance and query a changeset
|
9264
|
+
** iterator created by this function:
|
9265
|
+
**
|
9266
|
+
** <ul>
|
9267
|
+
** <li> [sqlite3changeset_next()]
|
9268
|
+
** <li> [sqlite3changeset_op()]
|
9269
|
+
** <li> [sqlite3changeset_new()]
|
9270
|
+
** <li> [sqlite3changeset_old()]
|
9271
|
+
** </ul>
|
9272
|
+
**
|
9273
|
+
** It is the responsibility of the caller to eventually destroy the iterator
|
9274
|
+
** by passing it to [sqlite3changeset_finalize()]. The buffer containing the
|
9275
|
+
** changeset (pChangeset) must remain valid until after the iterator is
|
9276
|
+
** destroyed.
|
9277
|
+
**
|
9278
|
+
** Assuming the changeset blob was created by one of the
|
9279
|
+
** [sqlite3session_changeset()], [sqlite3changeset_concat()] or
|
9280
|
+
** [sqlite3changeset_invert()] functions, all changes within the changeset
|
9281
|
+
** that apply to a single table are grouped together. This means that when
|
9282
|
+
** an application iterates through a changeset using an iterator created by
|
9283
|
+
** this function, all changes that relate to a single table are visited
|
9284
|
+
** consecutively. There is no chance that the iterator will visit a change
|
9285
|
+
** the applies to table X, then one for table Y, and then later on visit
|
9286
|
+
** another change for table X.
|
9287
|
+
*/
|
9288
|
+
SQLITE_API int sqlite3changeset_start(
|
9289
|
+
sqlite3_changeset_iter **pp, /* OUT: New changeset iterator handle */
|
9290
|
+
int nChangeset, /* Size of changeset blob in bytes */
|
9291
|
+
void *pChangeset /* Pointer to blob containing changeset */
|
9292
|
+
);
|
9293
|
+
|
9294
|
+
|
9295
|
+
/*
|
9296
|
+
** CAPI3REF: Advance A Changeset Iterator
|
9297
|
+
**
|
9298
|
+
** This function may only be used with iterators created by function
|
9299
|
+
** [sqlite3changeset_start()]. If it is called on an iterator passed to
|
9300
|
+
** a conflict-handler callback by [sqlite3changeset_apply()], SQLITE_MISUSE
|
9301
|
+
** is returned and the call has no effect.
|
9302
|
+
**
|
9303
|
+
** Immediately after an iterator is created by sqlite3changeset_start(), it
|
9304
|
+
** does not point to any change in the changeset. Assuming the changeset
|
9305
|
+
** is not empty, the first call to this function advances the iterator to
|
9306
|
+
** point to the first change in the changeset. Each subsequent call advances
|
9307
|
+
** the iterator to point to the next change in the changeset (if any). If
|
9308
|
+
** no error occurs and the iterator points to a valid change after a call
|
9309
|
+
** to sqlite3changeset_next() has advanced it, SQLITE_ROW is returned.
|
9310
|
+
** Otherwise, if all changes in the changeset have already been visited,
|
9311
|
+
** SQLITE_DONE is returned.
|
9312
|
+
**
|
9313
|
+
** If an error occurs, an SQLite error code is returned. Possible error
|
9314
|
+
** codes include SQLITE_CORRUPT (if the changeset buffer is corrupt) or
|
9315
|
+
** SQLITE_NOMEM.
|
9316
|
+
*/
|
9317
|
+
SQLITE_API int sqlite3changeset_next(sqlite3_changeset_iter *pIter);
|
9318
|
+
|
9319
|
+
/*
|
9320
|
+
** CAPI3REF: Obtain The Current Operation From A Changeset Iterator
|
9321
|
+
**
|
9322
|
+
** The pIter argument passed to this function may either be an iterator
|
9323
|
+
** passed to a conflict-handler by [sqlite3changeset_apply()], or an iterator
|
9324
|
+
** created by [sqlite3changeset_start()]. In the latter case, the most recent
|
9325
|
+
** call to [sqlite3changeset_next()] must have returned [SQLITE_ROW]. If this
|
9326
|
+
** is not the case, this function returns [SQLITE_MISUSE].
|
9327
|
+
**
|
9328
|
+
** If argument pzTab is not NULL, then *pzTab is set to point to a
|
9329
|
+
** nul-terminated utf-8 encoded string containing the name of the table
|
9330
|
+
** affected by the current change. The buffer remains valid until either
|
9331
|
+
** sqlite3changeset_next() is called on the iterator or until the
|
9332
|
+
** conflict-handler function returns. If pnCol is not NULL, then *pnCol is
|
9333
|
+
** set to the number of columns in the table affected by the change. If
|
9334
|
+
** pbIncorrect is not NULL, then *pbIndirect is set to true (1) if the change
|
9335
|
+
** is an indirect change, or false (0) otherwise. See the documentation for
|
9336
|
+
** [sqlite3session_indirect()] for a description of direct and indirect
|
9337
|
+
** changes. Finally, if pOp is not NULL, then *pOp is set to one of
|
9338
|
+
** [SQLITE_INSERT], [SQLITE_DELETE] or [SQLITE_UPDATE], depending on the
|
9339
|
+
** type of change that the iterator currently points to.
|
9340
|
+
**
|
9341
|
+
** If no error occurs, SQLITE_OK is returned. If an error does occur, an
|
9342
|
+
** SQLite error code is returned. The values of the output variables may not
|
9343
|
+
** be trusted in this case.
|
9344
|
+
*/
|
9345
|
+
SQLITE_API int sqlite3changeset_op(
|
9346
|
+
sqlite3_changeset_iter *pIter, /* Iterator object */
|
9347
|
+
const char **pzTab, /* OUT: Pointer to table name */
|
9348
|
+
int *pnCol, /* OUT: Number of columns in table */
|
9349
|
+
int *pOp, /* OUT: SQLITE_INSERT, DELETE or UPDATE */
|
9350
|
+
int *pbIndirect /* OUT: True for an 'indirect' change */
|
9351
|
+
);
|
9352
|
+
|
9353
|
+
/*
|
9354
|
+
** CAPI3REF: Obtain The Primary Key Definition Of A Table
|
9355
|
+
**
|
9356
|
+
** For each modified table, a changeset includes the following:
|
9357
|
+
**
|
9358
|
+
** <ul>
|
9359
|
+
** <li> The number of columns in the table, and
|
9360
|
+
** <li> Which of those columns make up the tables PRIMARY KEY.
|
9361
|
+
** </ul>
|
9362
|
+
**
|
9363
|
+
** This function is used to find which columns comprise the PRIMARY KEY of
|
9364
|
+
** the table modified by the change that iterator pIter currently points to.
|
9365
|
+
** If successful, *pabPK is set to point to an array of nCol entries, where
|
9366
|
+
** nCol is the number of columns in the table. Elements of *pabPK are set to
|
9367
|
+
** 0x01 if the corresponding column is part of the tables primary key, or
|
9368
|
+
** 0x00 if it is not.
|
9369
|
+
**
|
9370
|
+
** If argument pnCol is not NULL, then *pnCol is set to the number of columns
|
9371
|
+
** in the table.
|
9372
|
+
**
|
9373
|
+
** If this function is called when the iterator does not point to a valid
|
9374
|
+
** entry, SQLITE_MISUSE is returned and the output variables zeroed. Otherwise,
|
9375
|
+
** SQLITE_OK is returned and the output variables populated as described
|
9376
|
+
** above.
|
9377
|
+
*/
|
9378
|
+
SQLITE_API int sqlite3changeset_pk(
|
9379
|
+
sqlite3_changeset_iter *pIter, /* Iterator object */
|
9380
|
+
unsigned char **pabPK, /* OUT: Array of boolean - true for PK cols */
|
9381
|
+
int *pnCol /* OUT: Number of entries in output array */
|
9382
|
+
);
|
9383
|
+
|
9384
|
+
/*
|
9385
|
+
** CAPI3REF: Obtain old.* Values From A Changeset Iterator
|
9386
|
+
**
|
9387
|
+
** The pIter argument passed to this function may either be an iterator
|
9388
|
+
** passed to a conflict-handler by [sqlite3changeset_apply()], or an iterator
|
9389
|
+
** created by [sqlite3changeset_start()]. In the latter case, the most recent
|
9390
|
+
** call to [sqlite3changeset_next()] must have returned SQLITE_ROW.
|
9391
|
+
** Furthermore, it may only be called if the type of change that the iterator
|
9392
|
+
** currently points to is either [SQLITE_DELETE] or [SQLITE_UPDATE]. Otherwise,
|
9393
|
+
** this function returns [SQLITE_MISUSE] and sets *ppValue to NULL.
|
9394
|
+
**
|
9395
|
+
** Argument iVal must be greater than or equal to 0, and less than the number
|
9396
|
+
** of columns in the table affected by the current change. Otherwise,
|
9397
|
+
** [SQLITE_RANGE] is returned and *ppValue is set to NULL.
|
9398
|
+
**
|
9399
|
+
** If successful, this function sets *ppValue to point to a protected
|
9400
|
+
** sqlite3_value object containing the iVal'th value from the vector of
|
9401
|
+
** original row values stored as part of the UPDATE or DELETE change and
|
9402
|
+
** returns SQLITE_OK. The name of the function comes from the fact that this
|
9403
|
+
** is similar to the "old.*" columns available to update or delete triggers.
|
9404
|
+
**
|
9405
|
+
** If some other error occurs (e.g. an OOM condition), an SQLite error code
|
9406
|
+
** is returned and *ppValue is set to NULL.
|
9407
|
+
*/
|
9408
|
+
SQLITE_API int sqlite3changeset_old(
|
9409
|
+
sqlite3_changeset_iter *pIter, /* Changeset iterator */
|
9410
|
+
int iVal, /* Column number */
|
9411
|
+
sqlite3_value **ppValue /* OUT: Old value (or NULL pointer) */
|
9412
|
+
);
|
9413
|
+
|
9414
|
+
/*
|
9415
|
+
** CAPI3REF: Obtain new.* Values From A Changeset Iterator
|
9416
|
+
**
|
9417
|
+
** The pIter argument passed to this function may either be an iterator
|
9418
|
+
** passed to a conflict-handler by [sqlite3changeset_apply()], or an iterator
|
9419
|
+
** created by [sqlite3changeset_start()]. In the latter case, the most recent
|
9420
|
+
** call to [sqlite3changeset_next()] must have returned SQLITE_ROW.
|
9421
|
+
** Furthermore, it may only be called if the type of change that the iterator
|
9422
|
+
** currently points to is either [SQLITE_UPDATE] or [SQLITE_INSERT]. Otherwise,
|
9423
|
+
** this function returns [SQLITE_MISUSE] and sets *ppValue to NULL.
|
9424
|
+
**
|
9425
|
+
** Argument iVal must be greater than or equal to 0, and less than the number
|
9426
|
+
** of columns in the table affected by the current change. Otherwise,
|
9427
|
+
** [SQLITE_RANGE] is returned and *ppValue is set to NULL.
|
9428
|
+
**
|
9429
|
+
** If successful, this function sets *ppValue to point to a protected
|
9430
|
+
** sqlite3_value object containing the iVal'th value from the vector of
|
9431
|
+
** new row values stored as part of the UPDATE or INSERT change and
|
9432
|
+
** returns SQLITE_OK. If the change is an UPDATE and does not include
|
9433
|
+
** a new value for the requested column, *ppValue is set to NULL and
|
9434
|
+
** SQLITE_OK returned. The name of the function comes from the fact that
|
9435
|
+
** this is similar to the "new.*" columns available to update or delete
|
9436
|
+
** triggers.
|
9437
|
+
**
|
9438
|
+
** If some other error occurs (e.g. an OOM condition), an SQLite error code
|
9439
|
+
** is returned and *ppValue is set to NULL.
|
9440
|
+
*/
|
9441
|
+
SQLITE_API int sqlite3changeset_new(
|
9442
|
+
sqlite3_changeset_iter *pIter, /* Changeset iterator */
|
9443
|
+
int iVal, /* Column number */
|
9444
|
+
sqlite3_value **ppValue /* OUT: New value (or NULL pointer) */
|
9445
|
+
);
|
9446
|
+
|
9447
|
+
/*
|
9448
|
+
** CAPI3REF: Obtain Conflicting Row Values From A Changeset Iterator
|
9449
|
+
**
|
9450
|
+
** This function should only be used with iterator objects passed to a
|
9451
|
+
** conflict-handler callback by [sqlite3changeset_apply()] with either
|
9452
|
+
** [SQLITE_CHANGESET_DATA] or [SQLITE_CHANGESET_CONFLICT]. If this function
|
9453
|
+
** is called on any other iterator, [SQLITE_MISUSE] is returned and *ppValue
|
9454
|
+
** is set to NULL.
|
9455
|
+
**
|
9456
|
+
** Argument iVal must be greater than or equal to 0, and less than the number
|
9457
|
+
** of columns in the table affected by the current change. Otherwise,
|
9458
|
+
** [SQLITE_RANGE] is returned and *ppValue is set to NULL.
|
9459
|
+
**
|
9460
|
+
** If successful, this function sets *ppValue to point to a protected
|
9461
|
+
** sqlite3_value object containing the iVal'th value from the
|
9462
|
+
** "conflicting row" associated with the current conflict-handler callback
|
9463
|
+
** and returns SQLITE_OK.
|
9464
|
+
**
|
9465
|
+
** If some other error occurs (e.g. an OOM condition), an SQLite error code
|
9466
|
+
** is returned and *ppValue is set to NULL.
|
9467
|
+
*/
|
9468
|
+
SQLITE_API int sqlite3changeset_conflict(
|
9469
|
+
sqlite3_changeset_iter *pIter, /* Changeset iterator */
|
9470
|
+
int iVal, /* Column number */
|
9471
|
+
sqlite3_value **ppValue /* OUT: Value from conflicting row */
|
9472
|
+
);
|
9473
|
+
|
9474
|
+
/*
|
9475
|
+
** CAPI3REF: Determine The Number Of Foreign Key Constraint Violations
|
9476
|
+
**
|
9477
|
+
** This function may only be called with an iterator passed to an
|
9478
|
+
** SQLITE_CHANGESET_FOREIGN_KEY conflict handler callback. In this case
|
9479
|
+
** it sets the output variable to the total number of known foreign key
|
9480
|
+
** violations in the destination database and returns SQLITE_OK.
|
9481
|
+
**
|
9482
|
+
** In all other cases this function returns SQLITE_MISUSE.
|
9483
|
+
*/
|
9484
|
+
SQLITE_API int sqlite3changeset_fk_conflicts(
|
9485
|
+
sqlite3_changeset_iter *pIter, /* Changeset iterator */
|
9486
|
+
int *pnOut /* OUT: Number of FK violations */
|
9487
|
+
);
|
9488
|
+
|
9489
|
+
|
9490
|
+
/*
|
9491
|
+
** CAPI3REF: Finalize A Changeset Iterator
|
9492
|
+
**
|
9493
|
+
** This function is used to finalize an iterator allocated with
|
9494
|
+
** [sqlite3changeset_start()].
|
9495
|
+
**
|
9496
|
+
** This function should only be called on iterators created using the
|
9497
|
+
** [sqlite3changeset_start()] function. If an application calls this
|
9498
|
+
** function with an iterator passed to a conflict-handler by
|
9499
|
+
** [sqlite3changeset_apply()], [SQLITE_MISUSE] is immediately returned and the
|
9500
|
+
** call has no effect.
|
9501
|
+
**
|
9502
|
+
** If an error was encountered within a call to an sqlite3changeset_xxx()
|
9503
|
+
** function (for example an [SQLITE_CORRUPT] in [sqlite3changeset_next()] or an
|
9504
|
+
** [SQLITE_NOMEM] in [sqlite3changeset_new()]) then an error code corresponding
|
9505
|
+
** to that error is returned by this function. Otherwise, SQLITE_OK is
|
9506
|
+
** returned. This is to allow the following pattern (pseudo-code):
|
9507
|
+
**
|
9508
|
+
** sqlite3changeset_start();
|
9509
|
+
** while( SQLITE_ROW==sqlite3changeset_next() ){
|
9510
|
+
** // Do something with change.
|
9511
|
+
** }
|
9512
|
+
** rc = sqlite3changeset_finalize();
|
9513
|
+
** if( rc!=SQLITE_OK ){
|
9514
|
+
** // An error has occurred
|
9515
|
+
** }
|
9516
|
+
*/
|
9517
|
+
SQLITE_API int sqlite3changeset_finalize(sqlite3_changeset_iter *pIter);
|
9518
|
+
|
9519
|
+
/*
|
9520
|
+
** CAPI3REF: Invert A Changeset
|
9521
|
+
**
|
9522
|
+
** This function is used to "invert" a changeset object. Applying an inverted
|
9523
|
+
** changeset to a database reverses the effects of applying the uninverted
|
9524
|
+
** changeset. Specifically:
|
9525
|
+
**
|
9526
|
+
** <ul>
|
9527
|
+
** <li> Each DELETE change is changed to an INSERT, and
|
9528
|
+
** <li> Each INSERT change is changed to a DELETE, and
|
9529
|
+
** <li> For each UPDATE change, the old.* and new.* values are exchanged.
|
9530
|
+
** </ul>
|
9531
|
+
**
|
9532
|
+
** This function does not change the order in which changes appear within
|
9533
|
+
** the changeset. It merely reverses the sense of each individual change.
|
9534
|
+
**
|
9535
|
+
** If successful, a pointer to a buffer containing the inverted changeset
|
9536
|
+
** is stored in *ppOut, the size of the same buffer is stored in *pnOut, and
|
9537
|
+
** SQLITE_OK is returned. If an error occurs, both *pnOut and *ppOut are
|
9538
|
+
** zeroed and an SQLite error code returned.
|
9539
|
+
**
|
9540
|
+
** It is the responsibility of the caller to eventually call sqlite3_free()
|
9541
|
+
** on the *ppOut pointer to free the buffer allocation following a successful
|
9542
|
+
** call to this function.
|
9543
|
+
**
|
9544
|
+
** WARNING/TODO: This function currently assumes that the input is a valid
|
9545
|
+
** changeset. If it is not, the results are undefined.
|
9546
|
+
*/
|
9547
|
+
SQLITE_API int sqlite3changeset_invert(
|
9548
|
+
int nIn, const void *pIn, /* Input changeset */
|
9549
|
+
int *pnOut, void **ppOut /* OUT: Inverse of input */
|
9550
|
+
);
|
9551
|
+
|
9552
|
+
/*
|
9553
|
+
** CAPI3REF: Concatenate Two Changeset Objects
|
9554
|
+
**
|
9555
|
+
** This function is used to concatenate two changesets, A and B, into a
|
9556
|
+
** single changeset. The result is a changeset equivalent to applying
|
9557
|
+
** changeset A followed by changeset B.
|
9558
|
+
**
|
9559
|
+
** This function combines the two input changesets using an
|
9560
|
+
** sqlite3_changegroup object. Calling it produces similar results as the
|
9561
|
+
** following code fragment:
|
9562
|
+
**
|
9563
|
+
** sqlite3_changegroup *pGrp;
|
9564
|
+
** rc = sqlite3_changegroup_new(&pGrp);
|
9565
|
+
** if( rc==SQLITE_OK ) rc = sqlite3changegroup_add(pGrp, nA, pA);
|
9566
|
+
** if( rc==SQLITE_OK ) rc = sqlite3changegroup_add(pGrp, nB, pB);
|
9567
|
+
** if( rc==SQLITE_OK ){
|
9568
|
+
** rc = sqlite3changegroup_output(pGrp, pnOut, ppOut);
|
9569
|
+
** }else{
|
9570
|
+
** *ppOut = 0;
|
9571
|
+
** *pnOut = 0;
|
9572
|
+
** }
|
9573
|
+
**
|
9574
|
+
** Refer to the sqlite3_changegroup documentation below for details.
|
9575
|
+
*/
|
9576
|
+
SQLITE_API int sqlite3changeset_concat(
|
9577
|
+
int nA, /* Number of bytes in buffer pA */
|
9578
|
+
void *pA, /* Pointer to buffer containing changeset A */
|
9579
|
+
int nB, /* Number of bytes in buffer pB */
|
9580
|
+
void *pB, /* Pointer to buffer containing changeset B */
|
9581
|
+
int *pnOut, /* OUT: Number of bytes in output changeset */
|
9582
|
+
void **ppOut /* OUT: Buffer containing output changeset */
|
9583
|
+
);
|
9584
|
+
|
9585
|
+
|
9586
|
+
/*
|
9587
|
+
** CAPI3REF: Changegroup Handle
|
9588
|
+
*/
|
9589
|
+
typedef struct sqlite3_changegroup sqlite3_changegroup;
|
9590
|
+
|
9591
|
+
/*
|
9592
|
+
** CAPI3REF: Create A New Changegroup Object
|
9593
|
+
**
|
9594
|
+
** An sqlite3_changegroup object is used to combine two or more changesets
|
9595
|
+
** (or patchsets) into a single changeset (or patchset). A single changegroup
|
9596
|
+
** object may combine changesets or patchsets, but not both. The output is
|
9597
|
+
** always in the same format as the input.
|
9598
|
+
**
|
9599
|
+
** If successful, this function returns SQLITE_OK and populates (*pp) with
|
9600
|
+
** a pointer to a new sqlite3_changegroup object before returning. The caller
|
9601
|
+
** should eventually free the returned object using a call to
|
9602
|
+
** sqlite3changegroup_delete(). If an error occurs, an SQLite error code
|
9603
|
+
** (i.e. SQLITE_NOMEM) is returned and *pp is set to NULL.
|
9604
|
+
**
|
9605
|
+
** The usual usage pattern for an sqlite3_changegroup object is as follows:
|
9606
|
+
**
|
9607
|
+
** <ul>
|
9608
|
+
** <li> It is created using a call to sqlite3changegroup_new().
|
9609
|
+
**
|
9610
|
+
** <li> Zero or more changesets (or patchsets) are added to the object
|
9611
|
+
** by calling sqlite3changegroup_add().
|
9612
|
+
**
|
9613
|
+
** <li> The result of combining all input changesets together is obtained
|
9614
|
+
** by the application via a call to sqlite3changegroup_output().
|
9615
|
+
**
|
9616
|
+
** <li> The object is deleted using a call to sqlite3changegroup_delete().
|
9617
|
+
** </ul>
|
9618
|
+
**
|
9619
|
+
** Any number of calls to add() and output() may be made between the calls to
|
9620
|
+
** new() and delete(), and in any order.
|
9621
|
+
**
|
9622
|
+
** As well as the regular sqlite3changegroup_add() and
|
9623
|
+
** sqlite3changegroup_output() functions, also available are the streaming
|
9624
|
+
** versions sqlite3changegroup_add_strm() and sqlite3changegroup_output_strm().
|
9625
|
+
*/
|
9626
|
+
SQLITE_API int sqlite3changegroup_new(sqlite3_changegroup **pp);
|
9627
|
+
|
9628
|
+
/*
|
9629
|
+
** CAPI3REF: Add A Changeset To A Changegroup
|
9630
|
+
**
|
9631
|
+
** Add all changes within the changeset (or patchset) in buffer pData (size
|
9632
|
+
** nData bytes) to the changegroup.
|
9633
|
+
**
|
9634
|
+
** If the buffer contains a patchset, then all prior calls to this function
|
9635
|
+
** on the same changegroup object must also have specified patchsets. Or, if
|
9636
|
+
** the buffer contains a changeset, so must have the earlier calls to this
|
9637
|
+
** function. Otherwise, SQLITE_ERROR is returned and no changes are added
|
9638
|
+
** to the changegroup.
|
9639
|
+
**
|
9640
|
+
** Rows within the changeset and changegroup are identified by the values in
|
9641
|
+
** their PRIMARY KEY columns. A change in the changeset is considered to
|
9642
|
+
** apply to the same row as a change already present in the changegroup if
|
9643
|
+
** the two rows have the same primary key.
|
9644
|
+
**
|
9645
|
+
** Changes to rows that do not already appear in the changegroup are
|
9646
|
+
** simply copied into it. Or, if both the new changeset and the changegroup
|
9647
|
+
** contain changes that apply to a single row, the final contents of the
|
9648
|
+
** changegroup depends on the type of each change, as follows:
|
9649
|
+
**
|
9650
|
+
** <table border=1 style="margin-left:8ex;margin-right:8ex">
|
9651
|
+
** <tr><th style="white-space:pre">Existing Change </th>
|
9652
|
+
** <th style="white-space:pre">New Change </th>
|
9653
|
+
** <th>Output Change
|
9654
|
+
** <tr><td>INSERT <td>INSERT <td>
|
9655
|
+
** The new change is ignored. This case does not occur if the new
|
9656
|
+
** changeset was recorded immediately after the changesets already
|
9657
|
+
** added to the changegroup.
|
9658
|
+
** <tr><td>INSERT <td>UPDATE <td>
|
9659
|
+
** The INSERT change remains in the changegroup. The values in the
|
9660
|
+
** INSERT change are modified as if the row was inserted by the
|
9661
|
+
** existing change and then updated according to the new change.
|
9662
|
+
** <tr><td>INSERT <td>DELETE <td>
|
9663
|
+
** The existing INSERT is removed from the changegroup. The DELETE is
|
9664
|
+
** not added.
|
9665
|
+
** <tr><td>UPDATE <td>INSERT <td>
|
9666
|
+
** The new change is ignored. This case does not occur if the new
|
9667
|
+
** changeset was recorded immediately after the changesets already
|
9668
|
+
** added to the changegroup.
|
9669
|
+
** <tr><td>UPDATE <td>UPDATE <td>
|
9670
|
+
** The existing UPDATE remains within the changegroup. It is amended
|
9671
|
+
** so that the accompanying values are as if the row was updated once
|
9672
|
+
** by the existing change and then again by the new change.
|
9673
|
+
** <tr><td>UPDATE <td>DELETE <td>
|
9674
|
+
** The existing UPDATE is replaced by the new DELETE within the
|
9675
|
+
** changegroup.
|
9676
|
+
** <tr><td>DELETE <td>INSERT <td>
|
9677
|
+
** If one or more of the column values in the row inserted by the
|
9678
|
+
** new change differ from those in the row deleted by the existing
|
9679
|
+
** change, the existing DELETE is replaced by an UPDATE within the
|
9680
|
+
** changegroup. Otherwise, if the inserted row is exactly the same
|
9681
|
+
** as the deleted row, the existing DELETE is simply discarded.
|
9682
|
+
** <tr><td>DELETE <td>UPDATE <td>
|
9683
|
+
** The new change is ignored. This case does not occur if the new
|
9684
|
+
** changeset was recorded immediately after the changesets already
|
9685
|
+
** added to the changegroup.
|
9686
|
+
** <tr><td>DELETE <td>DELETE <td>
|
9687
|
+
** The new change is ignored. This case does not occur if the new
|
9688
|
+
** changeset was recorded immediately after the changesets already
|
9689
|
+
** added to the changegroup.
|
9690
|
+
** </table>
|
9691
|
+
**
|
9692
|
+
** If the new changeset contains changes to a table that is already present
|
9693
|
+
** in the changegroup, then the number of columns and the position of the
|
9694
|
+
** primary key columns for the table must be consistent. If this is not the
|
9695
|
+
** case, this function fails with SQLITE_SCHEMA. If the input changeset
|
9696
|
+
** appears to be corrupt and the corruption is detected, SQLITE_CORRUPT is
|
9697
|
+
** returned. Or, if an out-of-memory condition occurs during processing, this
|
9698
|
+
** function returns SQLITE_NOMEM. In all cases, if an error occurs the
|
9699
|
+
** final contents of the changegroup is undefined.
|
9700
|
+
**
|
9701
|
+
** If no error occurs, SQLITE_OK is returned.
|
9702
|
+
*/
|
9703
|
+
SQLITE_API int sqlite3changegroup_add(sqlite3_changegroup*, int nData, void *pData);
|
9704
|
+
|
9705
|
+
/*
|
9706
|
+
** CAPI3REF: Obtain A Composite Changeset From A Changegroup
|
9707
|
+
**
|
9708
|
+
** Obtain a buffer containing a changeset (or patchset) representing the
|
9709
|
+
** current contents of the changegroup. If the inputs to the changegroup
|
9710
|
+
** were themselves changesets, the output is a changeset. Or, if the
|
9711
|
+
** inputs were patchsets, the output is also a patchset.
|
9712
|
+
**
|
9713
|
+
** As with the output of the sqlite3session_changeset() and
|
9714
|
+
** sqlite3session_patchset() functions, all changes related to a single
|
9715
|
+
** table are grouped together in the output of this function. Tables appear
|
9716
|
+
** in the same order as for the very first changeset added to the changegroup.
|
9717
|
+
** If the second or subsequent changesets added to the changegroup contain
|
9718
|
+
** changes for tables that do not appear in the first changeset, they are
|
9719
|
+
** appended onto the end of the output changeset, again in the order in
|
9720
|
+
** which they are first encountered.
|
9721
|
+
**
|
9722
|
+
** If an error occurs, an SQLite error code is returned and the output
|
9723
|
+
** variables (*pnData) and (*ppData) are set to 0. Otherwise, SQLITE_OK
|
9724
|
+
** is returned and the output variables are set to the size of and a
|
9725
|
+
** pointer to the output buffer, respectively. In this case it is the
|
9726
|
+
** responsibility of the caller to eventually free the buffer using a
|
9727
|
+
** call to sqlite3_free().
|
9728
|
+
*/
|
9729
|
+
SQLITE_API int sqlite3changegroup_output(
|
9730
|
+
sqlite3_changegroup*,
|
9731
|
+
int *pnData, /* OUT: Size of output buffer in bytes */
|
9732
|
+
void **ppData /* OUT: Pointer to output buffer */
|
9733
|
+
);
|
9734
|
+
|
9735
|
+
/*
|
9736
|
+
** CAPI3REF: Delete A Changegroup Object
|
9737
|
+
*/
|
9738
|
+
SQLITE_API void sqlite3changegroup_delete(sqlite3_changegroup*);
|
9739
|
+
|
9740
|
+
/*
|
9741
|
+
** CAPI3REF: Apply A Changeset To A Database
|
9742
|
+
**
|
9743
|
+
** Apply a changeset to a database. This function attempts to update the
|
9744
|
+
** "main" database attached to handle db with the changes found in the
|
9745
|
+
** changeset passed via the second and third arguments.
|
9746
|
+
**
|
9747
|
+
** The fourth argument (xFilter) passed to this function is the "filter
|
9748
|
+
** callback". If it is not NULL, then for each table affected by at least one
|
9749
|
+
** change in the changeset, the filter callback is invoked with
|
9750
|
+
** the table name as the second argument, and a copy of the context pointer
|
9751
|
+
** passed as the sixth argument to this function as the first. If the "filter
|
9752
|
+
** callback" returns zero, then no attempt is made to apply any changes to
|
9753
|
+
** the table. Otherwise, if the return value is non-zero or the xFilter
|
9754
|
+
** argument to this function is NULL, all changes related to the table are
|
9755
|
+
** attempted.
|
9756
|
+
**
|
9757
|
+
** For each table that is not excluded by the filter callback, this function
|
9758
|
+
** tests that the target database contains a compatible table. A table is
|
9759
|
+
** considered compatible if all of the following are true:
|
9760
|
+
**
|
9761
|
+
** <ul>
|
9762
|
+
** <li> The table has the same name as the name recorded in the
|
9763
|
+
** changeset, and
|
9764
|
+
** <li> The table has at least as many columns as recorded in the
|
9765
|
+
** changeset, and
|
9766
|
+
** <li> The table has primary key columns in the same position as
|
9767
|
+
** recorded in the changeset.
|
9768
|
+
** </ul>
|
9769
|
+
**
|
9770
|
+
** If there is no compatible table, it is not an error, but none of the
|
9771
|
+
** changes associated with the table are applied. A warning message is issued
|
9772
|
+
** via the sqlite3_log() mechanism with the error code SQLITE_SCHEMA. At most
|
9773
|
+
** one such warning is issued for each table in the changeset.
|
9774
|
+
**
|
9775
|
+
** For each change for which there is a compatible table, an attempt is made
|
9776
|
+
** to modify the table contents according to the UPDATE, INSERT or DELETE
|
9777
|
+
** change. If a change cannot be applied cleanly, the conflict handler
|
9778
|
+
** function passed as the fifth argument to sqlite3changeset_apply() may be
|
9779
|
+
** invoked. A description of exactly when the conflict handler is invoked for
|
9780
|
+
** each type of change is below.
|
9781
|
+
**
|
9782
|
+
** Unlike the xFilter argument, xConflict may not be passed NULL. The results
|
9783
|
+
** of passing anything other than a valid function pointer as the xConflict
|
9784
|
+
** argument are undefined.
|
9785
|
+
**
|
9786
|
+
** Each time the conflict handler function is invoked, it must return one
|
9787
|
+
** of [SQLITE_CHANGESET_OMIT], [SQLITE_CHANGESET_ABORT] or
|
9788
|
+
** [SQLITE_CHANGESET_REPLACE]. SQLITE_CHANGESET_REPLACE may only be returned
|
9789
|
+
** if the second argument passed to the conflict handler is either
|
9790
|
+
** SQLITE_CHANGESET_DATA or SQLITE_CHANGESET_CONFLICT. If the conflict-handler
|
9791
|
+
** returns an illegal value, any changes already made are rolled back and
|
9792
|
+
** the call to sqlite3changeset_apply() returns SQLITE_MISUSE. Different
|
9793
|
+
** actions are taken by sqlite3changeset_apply() depending on the value
|
9794
|
+
** returned by each invocation of the conflict-handler function. Refer to
|
9795
|
+
** the documentation for the three
|
9796
|
+
** [SQLITE_CHANGESET_OMIT|available return values] for details.
|
9797
|
+
**
|
9798
|
+
** <dl>
|
9799
|
+
** <dt>DELETE Changes<dd>
|
9800
|
+
** For each DELETE change, this function checks if the target database
|
9801
|
+
** contains a row with the same primary key value (or values) as the
|
9802
|
+
** original row values stored in the changeset. If it does, and the values
|
9803
|
+
** stored in all non-primary key columns also match the values stored in
|
9804
|
+
** the changeset the row is deleted from the target database.
|
9805
|
+
**
|
9806
|
+
** If a row with matching primary key values is found, but one or more of
|
9807
|
+
** the non-primary key fields contains a value different from the original
|
9808
|
+
** row value stored in the changeset, the conflict-handler function is
|
9809
|
+
** invoked with [SQLITE_CHANGESET_DATA] as the second argument. If the
|
9810
|
+
** database table has more columns than are recorded in the changeset,
|
9811
|
+
** only the values of those non-primary key fields are compared against
|
9812
|
+
** the current database contents - any trailing database table columns
|
9813
|
+
** are ignored.
|
9814
|
+
**
|
9815
|
+
** If no row with matching primary key values is found in the database,
|
9816
|
+
** the conflict-handler function is invoked with [SQLITE_CHANGESET_NOTFOUND]
|
9817
|
+
** passed as the second argument.
|
9818
|
+
**
|
9819
|
+
** If the DELETE operation is attempted, but SQLite returns SQLITE_CONSTRAINT
|
9820
|
+
** (which can only happen if a foreign key constraint is violated), the
|
9821
|
+
** conflict-handler function is invoked with [SQLITE_CHANGESET_CONSTRAINT]
|
9822
|
+
** passed as the second argument. This includes the case where the DELETE
|
9823
|
+
** operation is attempted because an earlier call to the conflict handler
|
9824
|
+
** function returned [SQLITE_CHANGESET_REPLACE].
|
9825
|
+
**
|
9826
|
+
** <dt>INSERT Changes<dd>
|
9827
|
+
** For each INSERT change, an attempt is made to insert the new row into
|
9828
|
+
** the database. If the changeset row contains fewer fields than the
|
9829
|
+
** database table, the trailing fields are populated with their default
|
9830
|
+
** values.
|
9831
|
+
**
|
9832
|
+
** If the attempt to insert the row fails because the database already
|
9833
|
+
** contains a row with the same primary key values, the conflict handler
|
9834
|
+
** function is invoked with the second argument set to
|
9835
|
+
** [SQLITE_CHANGESET_CONFLICT].
|
9836
|
+
**
|
9837
|
+
** If the attempt to insert the row fails because of some other constraint
|
9838
|
+
** violation (e.g. NOT NULL or UNIQUE), the conflict handler function is
|
9839
|
+
** invoked with the second argument set to [SQLITE_CHANGESET_CONSTRAINT].
|
9840
|
+
** This includes the case where the INSERT operation is re-attempted because
|
9841
|
+
** an earlier call to the conflict handler function returned
|
9842
|
+
** [SQLITE_CHANGESET_REPLACE].
|
9843
|
+
**
|
9844
|
+
** <dt>UPDATE Changes<dd>
|
9845
|
+
** For each UPDATE change, this function checks if the target database
|
9846
|
+
** contains a row with the same primary key value (or values) as the
|
9847
|
+
** original row values stored in the changeset. If it does, and the values
|
9848
|
+
** stored in all modified non-primary key columns also match the values
|
9849
|
+
** stored in the changeset the row is updated within the target database.
|
9850
|
+
**
|
9851
|
+
** If a row with matching primary key values is found, but one or more of
|
9852
|
+
** the modified non-primary key fields contains a value different from an
|
9853
|
+
** original row value stored in the changeset, the conflict-handler function
|
9854
|
+
** is invoked with [SQLITE_CHANGESET_DATA] as the second argument. Since
|
9855
|
+
** UPDATE changes only contain values for non-primary key fields that are
|
9856
|
+
** to be modified, only those fields need to match the original values to
|
9857
|
+
** avoid the SQLITE_CHANGESET_DATA conflict-handler callback.
|
9858
|
+
**
|
9859
|
+
** If no row with matching primary key values is found in the database,
|
9860
|
+
** the conflict-handler function is invoked with [SQLITE_CHANGESET_NOTFOUND]
|
9861
|
+
** passed as the second argument.
|
9862
|
+
**
|
9863
|
+
** If the UPDATE operation is attempted, but SQLite returns
|
9864
|
+
** SQLITE_CONSTRAINT, the conflict-handler function is invoked with
|
9865
|
+
** [SQLITE_CHANGESET_CONSTRAINT] passed as the second argument.
|
9866
|
+
** This includes the case where the UPDATE operation is attempted after
|
9867
|
+
** an earlier call to the conflict handler function returned
|
9868
|
+
** [SQLITE_CHANGESET_REPLACE].
|
9869
|
+
** </dl>
|
9870
|
+
**
|
9871
|
+
** It is safe to execute SQL statements, including those that write to the
|
9872
|
+
** table that the callback related to, from within the xConflict callback.
|
9873
|
+
** This can be used to further customize the applications conflict
|
9874
|
+
** resolution strategy.
|
9875
|
+
**
|
9876
|
+
** All changes made by this function are enclosed in a savepoint transaction.
|
9877
|
+
** If any other error (aside from a constraint failure when attempting to
|
9878
|
+
** write to the target database) occurs, then the savepoint transaction is
|
9879
|
+
** rolled back, restoring the target database to its original state, and an
|
9880
|
+
** SQLite error code returned.
|
9881
|
+
*/
|
9882
|
+
SQLITE_API int sqlite3changeset_apply(
|
9883
|
+
sqlite3 *db, /* Apply change to "main" db of this handle */
|
9884
|
+
int nChangeset, /* Size of changeset in bytes */
|
9885
|
+
void *pChangeset, /* Changeset blob */
|
9886
|
+
int(*xFilter)(
|
9887
|
+
void *pCtx, /* Copy of sixth arg to _apply() */
|
9888
|
+
const char *zTab /* Table name */
|
9889
|
+
),
|
9890
|
+
int(*xConflict)(
|
9891
|
+
void *pCtx, /* Copy of sixth arg to _apply() */
|
9892
|
+
int eConflict, /* DATA, MISSING, CONFLICT, CONSTRAINT */
|
9893
|
+
sqlite3_changeset_iter *p /* Handle describing change and conflict */
|
9894
|
+
),
|
9895
|
+
void *pCtx /* First argument passed to xConflict */
|
9896
|
+
);
|
9897
|
+
|
9898
|
+
/*
|
9899
|
+
** CAPI3REF: Constants Passed To The Conflict Handler
|
9900
|
+
**
|
9901
|
+
** Values that may be passed as the second argument to a conflict-handler.
|
9902
|
+
**
|
9903
|
+
** <dl>
|
9904
|
+
** <dt>SQLITE_CHANGESET_DATA<dd>
|
9905
|
+
** The conflict handler is invoked with CHANGESET_DATA as the second argument
|
9906
|
+
** when processing a DELETE or UPDATE change if a row with the required
|
9907
|
+
** PRIMARY KEY fields is present in the database, but one or more other
|
9908
|
+
** (non primary-key) fields modified by the update do not contain the
|
9909
|
+
** expected "before" values.
|
9910
|
+
**
|
9911
|
+
** The conflicting row, in this case, is the database row with the matching
|
9912
|
+
** primary key.
|
9913
|
+
**
|
9914
|
+
** <dt>SQLITE_CHANGESET_NOTFOUND<dd>
|
9915
|
+
** The conflict handler is invoked with CHANGESET_NOTFOUND as the second
|
9916
|
+
** argument when processing a DELETE or UPDATE change if a row with the
|
9917
|
+
** required PRIMARY KEY fields is not present in the database.
|
9918
|
+
**
|
9919
|
+
** There is no conflicting row in this case. The results of invoking the
|
9920
|
+
** sqlite3changeset_conflict() API are undefined.
|
9921
|
+
**
|
9922
|
+
** <dt>SQLITE_CHANGESET_CONFLICT<dd>
|
9923
|
+
** CHANGESET_CONFLICT is passed as the second argument to the conflict
|
9924
|
+
** handler while processing an INSERT change if the operation would result
|
9925
|
+
** in duplicate primary key values.
|
9926
|
+
**
|
9927
|
+
** The conflicting row in this case is the database row with the matching
|
9928
|
+
** primary key.
|
9929
|
+
**
|
9930
|
+
** <dt>SQLITE_CHANGESET_FOREIGN_KEY<dd>
|
9931
|
+
** If foreign key handling is enabled, and applying a changeset leaves the
|
9932
|
+
** database in a state containing foreign key violations, the conflict
|
9933
|
+
** handler is invoked with CHANGESET_FOREIGN_KEY as the second argument
|
9934
|
+
** exactly once before the changeset is committed. If the conflict handler
|
9935
|
+
** returns CHANGESET_OMIT, the changes, including those that caused the
|
9936
|
+
** foreign key constraint violation, are committed. Or, if it returns
|
9937
|
+
** CHANGESET_ABORT, the changeset is rolled back.
|
9938
|
+
**
|
9939
|
+
** No current or conflicting row information is provided. The only function
|
9940
|
+
** it is possible to call on the supplied sqlite3_changeset_iter handle
|
9941
|
+
** is sqlite3changeset_fk_conflicts().
|
9942
|
+
**
|
9943
|
+
** <dt>SQLITE_CHANGESET_CONSTRAINT<dd>
|
9944
|
+
** If any other constraint violation occurs while applying a change (i.e.
|
9945
|
+
** a UNIQUE, CHECK or NOT NULL constraint), the conflict handler is
|
9946
|
+
** invoked with CHANGESET_CONSTRAINT as the second argument.
|
9947
|
+
**
|
9948
|
+
** There is no conflicting row in this case. The results of invoking the
|
9949
|
+
** sqlite3changeset_conflict() API are undefined.
|
9950
|
+
**
|
9951
|
+
** </dl>
|
9952
|
+
*/
|
9953
|
+
#define SQLITE_CHANGESET_DATA 1
|
9954
|
+
#define SQLITE_CHANGESET_NOTFOUND 2
|
9955
|
+
#define SQLITE_CHANGESET_CONFLICT 3
|
9956
|
+
#define SQLITE_CHANGESET_CONSTRAINT 4
|
9957
|
+
#define SQLITE_CHANGESET_FOREIGN_KEY 5
|
9958
|
+
|
9959
|
+
/*
|
9960
|
+
** CAPI3REF: Constants Returned By The Conflict Handler
|
9961
|
+
**
|
9962
|
+
** A conflict handler callback must return one of the following three values.
|
9963
|
+
**
|
9964
|
+
** <dl>
|
9965
|
+
** <dt>SQLITE_CHANGESET_OMIT<dd>
|
9966
|
+
** If a conflict handler returns this value no special action is taken. The
|
9967
|
+
** change that caused the conflict is not applied. The session module
|
9968
|
+
** continues to the next change in the changeset.
|
9969
|
+
**
|
9970
|
+
** <dt>SQLITE_CHANGESET_REPLACE<dd>
|
9971
|
+
** This value may only be returned if the second argument to the conflict
|
9972
|
+
** handler was SQLITE_CHANGESET_DATA or SQLITE_CHANGESET_CONFLICT. If this
|
9973
|
+
** is not the case, any changes applied so far are rolled back and the
|
9974
|
+
** call to sqlite3changeset_apply() returns SQLITE_MISUSE.
|
9975
|
+
**
|
9976
|
+
** If CHANGESET_REPLACE is returned by an SQLITE_CHANGESET_DATA conflict
|
9977
|
+
** handler, then the conflicting row is either updated or deleted, depending
|
9978
|
+
** on the type of change.
|
9979
|
+
**
|
9980
|
+
** If CHANGESET_REPLACE is returned by an SQLITE_CHANGESET_CONFLICT conflict
|
9981
|
+
** handler, then the conflicting row is removed from the database and a
|
9982
|
+
** second attempt to apply the change is made. If this second attempt fails,
|
9983
|
+
** the original row is restored to the database before continuing.
|
9984
|
+
**
|
9985
|
+
** <dt>SQLITE_CHANGESET_ABORT<dd>
|
9986
|
+
** If this value is returned, any changes applied so far are rolled back
|
9987
|
+
** and the call to sqlite3changeset_apply() returns SQLITE_ABORT.
|
9988
|
+
** </dl>
|
9989
|
+
*/
|
9990
|
+
#define SQLITE_CHANGESET_OMIT 0
|
9991
|
+
#define SQLITE_CHANGESET_REPLACE 1
|
9992
|
+
#define SQLITE_CHANGESET_ABORT 2
|
9993
|
+
|
9994
|
+
/*
|
9995
|
+
** CAPI3REF: Streaming Versions of API functions.
|
9996
|
+
**
|
9997
|
+
** The six streaming API xxx_strm() functions serve similar purposes to the
|
9998
|
+
** corresponding non-streaming API functions:
|
9999
|
+
**
|
10000
|
+
** <table border=1 style="margin-left:8ex;margin-right:8ex">
|
10001
|
+
** <tr><th>Streaming function<th>Non-streaming equivalent</th>
|
10002
|
+
** <tr><td>sqlite3changeset_apply_strm<td>[sqlite3changeset_apply]
|
10003
|
+
** <tr><td>sqlite3changeset_concat_strm<td>[sqlite3changeset_concat]
|
10004
|
+
** <tr><td>sqlite3changeset_invert_strm<td>[sqlite3changeset_invert]
|
10005
|
+
** <tr><td>sqlite3changeset_start_strm<td>[sqlite3changeset_start]
|
10006
|
+
** <tr><td>sqlite3session_changeset_strm<td>[sqlite3session_changeset]
|
10007
|
+
** <tr><td>sqlite3session_patchset_strm<td>[sqlite3session_patchset]
|
10008
|
+
** </table>
|
10009
|
+
**
|
10010
|
+
** Non-streaming functions that accept changesets (or patchsets) as input
|
10011
|
+
** require that the entire changeset be stored in a single buffer in memory.
|
10012
|
+
** Similarly, those that return a changeset or patchset do so by returning
|
10013
|
+
** a pointer to a single large buffer allocated using sqlite3_malloc().
|
10014
|
+
** Normally this is convenient. However, if an application running in a
|
10015
|
+
** low-memory environment is required to handle very large changesets, the
|
10016
|
+
** large contiguous memory allocations required can become onerous.
|
10017
|
+
**
|
10018
|
+
** In order to avoid this problem, instead of a single large buffer, input
|
10019
|
+
** is passed to a streaming API functions by way of a callback function that
|
10020
|
+
** the sessions module invokes to incrementally request input data as it is
|
10021
|
+
** required. In all cases, a pair of API function parameters such as
|
10022
|
+
**
|
10023
|
+
** <pre>
|
10024
|
+
** int nChangeset,
|
10025
|
+
** void *pChangeset,
|
10026
|
+
** </pre>
|
10027
|
+
**
|
10028
|
+
** Is replaced by:
|
10029
|
+
**
|
10030
|
+
** <pre>
|
10031
|
+
** int (*xInput)(void *pIn, void *pData, int *pnData),
|
10032
|
+
** void *pIn,
|
10033
|
+
** </pre>
|
10034
|
+
**
|
10035
|
+
** Each time the xInput callback is invoked by the sessions module, the first
|
10036
|
+
** argument passed is a copy of the supplied pIn context pointer. The second
|
10037
|
+
** argument, pData, points to a buffer (*pnData) bytes in size. Assuming no
|
10038
|
+
** error occurs the xInput method should copy up to (*pnData) bytes of data
|
10039
|
+
** into the buffer and set (*pnData) to the actual number of bytes copied
|
10040
|
+
** before returning SQLITE_OK. If the input is completely exhausted, (*pnData)
|
10041
|
+
** should be set to zero to indicate this. Or, if an error occurs, an SQLite
|
10042
|
+
** error code should be returned. In all cases, if an xInput callback returns
|
10043
|
+
** an error, all processing is abandoned and the streaming API function
|
10044
|
+
** returns a copy of the error code to the caller.
|
10045
|
+
**
|
10046
|
+
** In the case of sqlite3changeset_start_strm(), the xInput callback may be
|
10047
|
+
** invoked by the sessions module at any point during the lifetime of the
|
10048
|
+
** iterator. If such an xInput callback returns an error, the iterator enters
|
10049
|
+
** an error state, whereby all subsequent calls to iterator functions
|
10050
|
+
** immediately fail with the same error code as returned by xInput.
|
10051
|
+
**
|
10052
|
+
** Similarly, streaming API functions that return changesets (or patchsets)
|
10053
|
+
** return them in chunks by way of a callback function instead of via a
|
10054
|
+
** pointer to a single large buffer. In this case, a pair of parameters such
|
10055
|
+
** as:
|
10056
|
+
**
|
10057
|
+
** <pre>
|
10058
|
+
** int *pnChangeset,
|
10059
|
+
** void **ppChangeset,
|
10060
|
+
** </pre>
|
10061
|
+
**
|
10062
|
+
** Is replaced by:
|
10063
|
+
**
|
10064
|
+
** <pre>
|
10065
|
+
** int (*xOutput)(void *pOut, const void *pData, int nData),
|
10066
|
+
** void *pOut
|
10067
|
+
** </pre>
|
10068
|
+
**
|
10069
|
+
** The xOutput callback is invoked zero or more times to return data to
|
10070
|
+
** the application. The first parameter passed to each call is a copy of the
|
10071
|
+
** pOut pointer supplied by the application. The second parameter, pData,
|
10072
|
+
** points to a buffer nData bytes in size containing the chunk of output
|
10073
|
+
** data being returned. If the xOutput callback successfully processes the
|
10074
|
+
** supplied data, it should return SQLITE_OK to indicate success. Otherwise,
|
10075
|
+
** it should return some other SQLite error code. In this case processing
|
10076
|
+
** is immediately abandoned and the streaming API function returns a copy
|
10077
|
+
** of the xOutput error code to the application.
|
10078
|
+
**
|
10079
|
+
** The sessions module never invokes an xOutput callback with the third
|
10080
|
+
** parameter set to a value less than or equal to zero. Other than this,
|
10081
|
+
** no guarantees are made as to the size of the chunks of data returned.
|
10082
|
+
*/
|
10083
|
+
SQLITE_API int sqlite3changeset_apply_strm(
|
10084
|
+
sqlite3 *db, /* Apply change to "main" db of this handle */
|
10085
|
+
int (*xInput)(void *pIn, void *pData, int *pnData), /* Input function */
|
10086
|
+
void *pIn, /* First arg for xInput */
|
10087
|
+
int(*xFilter)(
|
10088
|
+
void *pCtx, /* Copy of sixth arg to _apply() */
|
10089
|
+
const char *zTab /* Table name */
|
10090
|
+
),
|
10091
|
+
int(*xConflict)(
|
10092
|
+
void *pCtx, /* Copy of sixth arg to _apply() */
|
10093
|
+
int eConflict, /* DATA, MISSING, CONFLICT, CONSTRAINT */
|
10094
|
+
sqlite3_changeset_iter *p /* Handle describing change and conflict */
|
10095
|
+
),
|
10096
|
+
void *pCtx /* First argument passed to xConflict */
|
10097
|
+
);
|
10098
|
+
SQLITE_API int sqlite3changeset_concat_strm(
|
10099
|
+
int (*xInputA)(void *pIn, void *pData, int *pnData),
|
10100
|
+
void *pInA,
|
10101
|
+
int (*xInputB)(void *pIn, void *pData, int *pnData),
|
10102
|
+
void *pInB,
|
10103
|
+
int (*xOutput)(void *pOut, const void *pData, int nData),
|
10104
|
+
void *pOut
|
10105
|
+
);
|
10106
|
+
SQLITE_API int sqlite3changeset_invert_strm(
|
10107
|
+
int (*xInput)(void *pIn, void *pData, int *pnData),
|
10108
|
+
void *pIn,
|
10109
|
+
int (*xOutput)(void *pOut, const void *pData, int nData),
|
10110
|
+
void *pOut
|
10111
|
+
);
|
10112
|
+
SQLITE_API int sqlite3changeset_start_strm(
|
10113
|
+
sqlite3_changeset_iter **pp,
|
10114
|
+
int (*xInput)(void *pIn, void *pData, int *pnData),
|
10115
|
+
void *pIn
|
10116
|
+
);
|
10117
|
+
SQLITE_API int sqlite3session_changeset_strm(
|
10118
|
+
sqlite3_session *pSession,
|
10119
|
+
int (*xOutput)(void *pOut, const void *pData, int nData),
|
10120
|
+
void *pOut
|
10121
|
+
);
|
10122
|
+
SQLITE_API int sqlite3session_patchset_strm(
|
10123
|
+
sqlite3_session *pSession,
|
10124
|
+
int (*xOutput)(void *pOut, const void *pData, int nData),
|
10125
|
+
void *pOut
|
10126
|
+
);
|
10127
|
+
SQLITE_API int sqlite3changegroup_add_strm(sqlite3_changegroup*,
|
10128
|
+
int (*xInput)(void *pIn, void *pData, int *pnData),
|
10129
|
+
void *pIn
|
10130
|
+
);
|
10131
|
+
SQLITE_API int sqlite3changegroup_output_strm(sqlite3_changegroup*,
|
10132
|
+
int (*xOutput)(void *pOut, const void *pData, int nData),
|
10133
|
+
void *pOut
|
10134
|
+
);
|
10135
|
+
|
10136
|
+
|
10137
|
+
/*
|
10138
|
+
** Make sure we can call this stuff from C++.
|
10139
|
+
*/
|
10140
|
+
#ifdef __cplusplus
|
10141
|
+
}
|
10142
|
+
#endif
|
10143
|
+
|
10144
|
+
#endif /* !defined(__SQLITESESSION_H_) && defined(SQLITE_ENABLE_SESSION) */
|
10145
|
+
|
10146
|
+
/******** End of sqlite3session.h *********/
|
10147
|
+
/******** Begin file fts5.h *********/
|
7924
10148
|
/*
|
7925
10149
|
** 2014 May 31
|
7926
10150
|
**
|
@@ -8006,6 +10230,9 @@ struct Fts5PhraseIter {
|
|
8006
10230
|
** an OOM condition or IO error), an appropriate SQLite error code is
|
8007
10231
|
** returned.
|
8008
10232
|
**
|
10233
|
+
** This function may be quite inefficient if used with an FTS5 table
|
10234
|
+
** created with the "columnsize=0" option.
|
10235
|
+
**
|
8009
10236
|
** xColumnText:
|
8010
10237
|
** This function attempts to retrieve the text of column iCol of the
|
8011
10238
|
** current document. If successful, (*pz) is set to point to a buffer
|
@@ -8026,15 +10253,29 @@ struct Fts5PhraseIter {
|
|
8026
10253
|
** the query within the current row. Return SQLITE_OK if successful, or
|
8027
10254
|
** an error code (i.e. SQLITE_NOMEM) if an error occurs.
|
8028
10255
|
**
|
10256
|
+
** This API can be quite slow if used with an FTS5 table created with the
|
10257
|
+
** "detail=none" or "detail=column" option. If the FTS5 table is created
|
10258
|
+
** with either "detail=none" or "detail=column" and "content=" option
|
10259
|
+
** (i.e. if it is a contentless table), then this API always returns 0.
|
10260
|
+
**
|
8029
10261
|
** xInst:
|
8030
10262
|
** Query for the details of phrase match iIdx within the current row.
|
8031
10263
|
** Phrase matches are numbered starting from zero, so the iIdx argument
|
8032
10264
|
** should be greater than or equal to zero and smaller than the value
|
8033
10265
|
** output by xInstCount().
|
8034
10266
|
**
|
10267
|
+
** Usually, output parameter *piPhrase is set to the phrase number, *piCol
|
10268
|
+
** to the column in which it occurs and *piOff the token offset of the
|
10269
|
+
** first token of the phrase. The exception is if the table was created
|
10270
|
+
** with the offsets=0 option specified. In this case *piOff is always
|
10271
|
+
** set to -1.
|
10272
|
+
**
|
8035
10273
|
** Returns SQLITE_OK if successful, or an error code (i.e. SQLITE_NOMEM)
|
8036
10274
|
** if an error occurs.
|
8037
10275
|
**
|
10276
|
+
** This API can be quite slow if used with an FTS5 table created with the
|
10277
|
+
** "detail=none" or "detail=column" option.
|
10278
|
+
**
|
8038
10279
|
** xRowid:
|
8039
10280
|
** Returns the rowid of the current row.
|
8040
10281
|
**
|
@@ -8048,11 +10289,13 @@ struct Fts5PhraseIter {
|
|
8048
10289
|
** ... FROM ftstable WHERE ftstable MATCH $p ORDER BY rowid
|
8049
10290
|
**
|
8050
10291
|
** with $p set to a phrase equivalent to the phrase iPhrase of the
|
8051
|
-
** current query is executed.
|
8052
|
-
**
|
8053
|
-
**
|
8054
|
-
**
|
8055
|
-
**
|
10292
|
+
** current query is executed. Any column filter that applies to
|
10293
|
+
** phrase iPhrase of the current query is included in $p. For each
|
10294
|
+
** row visited, the callback function passed as the fourth argument
|
10295
|
+
** is invoked. The context and API objects passed to the callback
|
10296
|
+
** function may be used to access the properties of each matched row.
|
10297
|
+
** Invoking Api.xUserData() returns a copy of the pointer passed as
|
10298
|
+
** the third argument to pUserData.
|
8056
10299
|
**
|
8057
10300
|
** If the callback function returns any value other than SQLITE_OK, the
|
8058
10301
|
** query is abandoned and the xQueryPhrase function returns immediately.
|
@@ -8118,7 +10361,7 @@ struct Fts5PhraseIter {
|
|
8118
10361
|
** Fts5PhraseIter iter;
|
8119
10362
|
** int iCol, iOff;
|
8120
10363
|
** for(pApi->xPhraseFirst(pFts, iPhrase, &iter, &iCol, &iOff);
|
8121
|
-
**
|
10364
|
+
** iCol>=0;
|
8122
10365
|
** pApi->xPhraseNext(pFts, &iter, &iCol, &iOff)
|
8123
10366
|
** ){
|
8124
10367
|
** // An instance of phrase iPhrase at offset iOff of column iCol
|
@@ -8126,13 +10369,51 @@ struct Fts5PhraseIter {
|
|
8126
10369
|
**
|
8127
10370
|
** The Fts5PhraseIter structure is defined above. Applications should not
|
8128
10371
|
** modify this structure directly - it should only be used as shown above
|
8129
|
-
** with the xPhraseFirst() and xPhraseNext() API methods
|
10372
|
+
** with the xPhraseFirst() and xPhraseNext() API methods (and by
|
10373
|
+
** xPhraseFirstColumn() and xPhraseNextColumn() as illustrated below).
|
10374
|
+
**
|
10375
|
+
** This API can be quite slow if used with an FTS5 table created with the
|
10376
|
+
** "detail=none" or "detail=column" option. If the FTS5 table is created
|
10377
|
+
** with either "detail=none" or "detail=column" and "content=" option
|
10378
|
+
** (i.e. if it is a contentless table), then this API always iterates
|
10379
|
+
** through an empty set (all calls to xPhraseFirst() set iCol to -1).
|
8130
10380
|
**
|
8131
10381
|
** xPhraseNext()
|
8132
10382
|
** See xPhraseFirst above.
|
10383
|
+
**
|
10384
|
+
** xPhraseFirstColumn()
|
10385
|
+
** This function and xPhraseNextColumn() are similar to the xPhraseFirst()
|
10386
|
+
** and xPhraseNext() APIs described above. The difference is that instead
|
10387
|
+
** of iterating through all instances of a phrase in the current row, these
|
10388
|
+
** APIs are used to iterate through the set of columns in the current row
|
10389
|
+
** that contain one or more instances of a specified phrase. For example:
|
10390
|
+
**
|
10391
|
+
** Fts5PhraseIter iter;
|
10392
|
+
** int iCol;
|
10393
|
+
** for(pApi->xPhraseFirstColumn(pFts, iPhrase, &iter, &iCol);
|
10394
|
+
** iCol>=0;
|
10395
|
+
** pApi->xPhraseNextColumn(pFts, &iter, &iCol)
|
10396
|
+
** ){
|
10397
|
+
** // Column iCol contains at least one instance of phrase iPhrase
|
10398
|
+
** }
|
10399
|
+
**
|
10400
|
+
** This API can be quite slow if used with an FTS5 table created with the
|
10401
|
+
** "detail=none" option. If the FTS5 table is created with either
|
10402
|
+
** "detail=none" "content=" option (i.e. if it is a contentless table),
|
10403
|
+
** then this API always iterates through an empty set (all calls to
|
10404
|
+
** xPhraseFirstColumn() set iCol to -1).
|
10405
|
+
**
|
10406
|
+
** The information accessed using this API and its companion
|
10407
|
+
** xPhraseFirstColumn() may also be obtained using xPhraseFirst/xPhraseNext
|
10408
|
+
** (or xInst/xInstCount). The chief advantage of this API is that it is
|
10409
|
+
** significantly more efficient than those alternatives when used with
|
10410
|
+
** "detail=column" tables.
|
10411
|
+
**
|
10412
|
+
** xPhraseNextColumn()
|
10413
|
+
** See xPhraseFirstColumn above.
|
8133
10414
|
*/
|
8134
10415
|
struct Fts5ExtensionApi {
|
8135
|
-
int iVersion; /* Currently always set to
|
10416
|
+
int iVersion; /* Currently always set to 3 */
|
8136
10417
|
|
8137
10418
|
void *(*xUserData)(Fts5Context*);
|
8138
10419
|
|
@@ -8162,8 +10443,11 @@ struct Fts5ExtensionApi {
|
|
8162
10443
|
int (*xSetAuxdata)(Fts5Context*, void *pAux, void(*xDelete)(void*));
|
8163
10444
|
void *(*xGetAuxdata)(Fts5Context*, int bClear);
|
8164
10445
|
|
8165
|
-
|
10446
|
+
int (*xPhraseFirst)(Fts5Context*, int iPhrase, Fts5PhraseIter*, int*, int*);
|
8166
10447
|
void (*xPhraseNext)(Fts5Context*, Fts5PhraseIter*, int *piCol, int *piOff);
|
10448
|
+
|
10449
|
+
int (*xPhraseFirstColumn)(Fts5Context*, int iPhrase, Fts5PhraseIter*, int*);
|
10450
|
+
void (*xPhraseNextColumn)(Fts5Context*, Fts5PhraseIter*, int *piCol);
|
8167
10451
|
};
|
8168
10452
|
|
8169
10453
|
/*
|
@@ -8180,7 +10464,7 @@ struct Fts5ExtensionApi {
|
|
8180
10464
|
** behaviour. The structure methods are expected to function as follows:
|
8181
10465
|
**
|
8182
10466
|
** xCreate:
|
8183
|
-
** This function is used to allocate and
|
10467
|
+
** This function is used to allocate and initialize a tokenizer instance.
|
8184
10468
|
** A tokenizer instance is required to actually tokenize text.
|
8185
10469
|
**
|
8186
10470
|
** The first argument passed to this function is a copy of the (void*)
|
@@ -8440,4 +10724,4 @@ struct fts5_api {
|
|
8440
10724
|
|
8441
10725
|
#endif /* _FTS5_H */
|
8442
10726
|
|
8443
|
-
|
10727
|
+
/******** End of fts5.h *********/
|