| SQLITE3_SQL(3) | Library Functions Manual | SQLITE3_SQL(3) | 
sqlite3_sql,
  sqlite3_expanded_sql,
  sqlite3_normalized_sql —
sqlite3_sql(sqlite3_stmt *pStmt);
char *
  
  sqlite3_expanded_sql(sqlite3_stmt
    *pStmt);
const char *
  
  sqlite3_normalized_sql(sqlite3_stmt
    *pStmt);
For example, if a prepared statement is created using the SQL text "SELECT $abc,:xyz" and if parameter $abc is bound to integer 2345 and parameter :xyz is unbound, then sqlite3_sql() will return the original string, "SELECT $abc,:xyz" but sqlite3_expanded_sql() will return "SELECT 2345,NULL".
The sqlite3_expanded_sql() interface returns NULL if insufficient memory is available to hold the result, or if the result would exceed the the maximum string length determined by the SQLITE_LIMIT_LENGTH.
The SQLITE_TRACE_SIZE_LIMIT compile-time option limits the size of bound parameter expansions. The SQLITE_OMIT_TRACE compile-time option causes sqlite3_expanded_sql() to always return NULL.
The strings returned by sqlite3_sql(P) and sqlite3_normalized_sql(P) are managed by SQLite and are automatically freed when the prepared statement is finalized. The string returned by sqlite3_expanded_sql(P), on the other hand, is obtained from sqlite3_malloc() and must be free by the application by passing it to sqlite3_free().
| December 19, 2018 | NetBSD 9.4 |