Skip to content

Latest commit

 

History

History
51 lines (37 loc) · 2.55 KB

fSQLTranslation.wiki

File metadata and controls

51 lines (37 loc) · 2.55 KB

Table of Contents

fSQLTranslation

<<css mode="next" class="sidebar"></css>> (((

Class Resources <<toc></toc>>

 - '''<a href="/docs/fSQLTranslation">Class Documentation</a>'''
 - <a href="/api/fSQLTranslation">API Reference</a>
 - <a href="https://github.com/flourishlib/flourish-classes/blob/master/fSQLTranslation.php" target="_blank">Source Code</a>

<<toc></toc>>

Database Classes <<toc></toc>>

 - fDatabase
 - fNoRowsException
 - fResult
 - fSQLException
 - '''fSQLTranslation'''
 - fSQLSchemaTranslation
 - fSchema
 - fStatement
 - fUnbufferedResult

)))

The fSQLTranslation class is an internal class used by fDatabase for translating Flourish SQL into the dialect of SQL supported by the current database. To take advantage of the features of this class, be sure to call `translatedQuery()` instead of `query()`.

For more information about `translatedQuery()` and `query()`, please see the Queries section of the fDatabase page.

Debugging

The method ::enableDebugging(), accepts a single boolean parameter to turn debugging on or off. This method is automatically passed the same value as fDatabase::enableDebugging() when that is called.

When debugging is enabled, the class will print the original and translated queries, allowing developers to track down translation issues.

Caching

Part of the functionality that fSQLTranslation provides is to provide a way to get national character data (NCHAR, NVARCHAR and NTEXT columns) out of Microsoft SQL Server. Most of the MSSQL extensions for PHP do not properly retrieve national character data since it is encoded in UCS-2, which contains `NULL` bytes. fSQLTranslation translates the SQL query to request data from such columns as binary data, which allows `NULL` bytes, and then changes the encoding to UTF-8 before being returned to the developer.

Part of this process is to retrieve a list of all national character columns. The ::enableCaching() method accepts an instance of the fCache class, and will save the appropriate database schema information so it does not need to be fetched on each page load.

The method ::clearCache() will clear out the cached information, which would be useful when the database schema changes.

When using the Flourish ORM, the fORM class provides some useful caching functionality that will automatically clear the cache when database errors occur.