| SQLITE3_LIMIT(3) | Library Functions Manual | SQLITE3_LIMIT(3) | 
sqlite3_limit —
sqlite3_limit(sqlite3*,
  int id, int newVal);
If the new limit is a negative number, the limit is unchanged. For each limit category SQLITE_LIMIT_<i>NAME</i> there is a hard upper bound set at compile-time by a C preprocessor macro called SQLITE_MAX_<i>NAME</i>. (The "_LIMIT_" in the name is changed to "_MAX_".) Attempts to increase a limit above its hard upper bound are silently truncated to the hard upper bound.
Regardless of whether or not the limit was changed, the sqlite3_limit() interface returns the prior value of the limit. Hence, to find the current value of a limit without changing it, simply invoke this interface with the third parameter set to -1.
Run-time limits are intended for use in applications that manage both their own internal database and also databases that are controlled by untrusted external sources. An example application might be a web browser that has its own databases for storing history and separate databases controlled by JavaScript applications downloaded off the Internet. The internal databases can be given the large, default limits. Databases managed by external sources can be given much smaller limits designed to prevent a denial of service attack. Developers might also want to use the sqlite3_set_authorizer() interface to further control untrusted SQL. The size of the database created by an untrusted script can be contained using the max_page_count PRAGMA.
New run-time limit categories may be added in future releases.
| December 19, 2018 | NetBSD 9.2 |