Source for file adodb-mssql_n.inc.php
Documentation is available at adodb-mssql_n.inc.php
///////////////////////////////////////////////////////////////////////////
// NOTICE OF COPYRIGHT //
// ADOdb - Database Abstraction Library for PHP //
// http://adodb.sourceforge.net/ //
// Copyright (C) 2000-2008 John Lim (jlim\@natsoft.com.my) //
// All rights reserved. //
// Released under both BSD license and LGPL library license. //
// Whenever there is any discrepancy between the two licenses, //
// the BSD license will take precedence //
// Moodle - Modular Object-Oriented Dynamic Learning Environment //
// Copyright (C) 2001-3001 Martin Dougiamas http://dougiamas.com //
// (C) 2001-3001 Eloy Lafuente (stronk7) http://contiento.com //
// This program is free software; you can redistribute it and/or modify //
// it under the terms of the GNU General Public License as published by //
// the Free Software Foundation; either version 2 of the License, or //
// (at your option) any later version. //
// This program is distributed in the hope that it will be useful, //
// but WITHOUT ANY WARRANTY; without even the implied warranty of //
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the //
// GNU General Public License for more details: //
// http://www.gnu.org/copyleft/gpl.html //
///////////////////////////////////////////////////////////////////////////
* MSSQL Driver with auto-prepended "N" for correct unicode storage
* of SQL literal strings. Intended to be used with MSSQL drivers that
* are sending UCS-2 data to MSSQL (FreeTDS and ODBTP) in order to get
* true cross-db compatibility from the application point of view.
include_once(ADODB_DIR. '/drivers/adodb-mssql.inc.php');
function _query($sql,$inputarr)
* This function will intercept all the literals used in the SQL, prepending the "N" char to them
* in order to allow mssql to store properly data sent in the correct UCS-2 encoding (by freeTDS
* and ODBTP) keeping SQL compatibility at ADOdb level (instead of hacking every project to add
* the "N" notation when working against MSSQL.
* Note that this hack only must be used if ALL the char-based columns in your DB are of type nchar,
/// Check we have some single quote in the query. Exit ok.
/// Check we haven't an odd number of single quotes (this can cause problems below
/// and should be considered one wrong SQL). Exit with debug info.
/// Check we haven't any backslash + single quote combination. It should mean wrong
/// backslashes use (bad magic_quotes_sybase?). Exit with debug info.
$regexp = '/(\\\\' . <a href="../Zikula 1.0.1/_includes---classes---adodb---drivers---adodb-mssql_n.inc.php.html#defineSINGLEQUOTE">SINGLEQUOTE</a> . '[^' . <a href="../Zikula 1.0.1/_includes---classes---adodb---drivers---adodb-mssql_n.inc.php.html#defineSINGLEQUOTE">SINGLEQUOTE</a> . '])/';
/// Remove pairs of single-quotes
$regexp = '/(' . <a href="../Zikula 1.0.1/_includes---classes---adodb---drivers---adodb-mssql_n.inc.php.html#defineSINGLEQUOTE">SINGLEQUOTE</a> . <a href="../Zikula 1.0.1/_includes---classes---adodb---drivers---adodb-mssql_n.inc.php.html#defineSINGLEQUOTE">SINGLEQUOTE</a> . ')/';
$pairs['<@#@#@PAIR-'.$key.'@#@#@>'] = $value;
/// Remove the rest of literals present in the query
$regexp = '/(N?' . <a href="../Zikula 1.0.1/_includes---classes---adodb---drivers---adodb-mssql_n.inc.php.html#defineSINGLEQUOTE">SINGLEQUOTE</a> . '.*?' . <a href="../Zikula 1.0.1/_includes---classes---adodb---drivers---adodb-mssql_n.inc.php.html#defineSINGLEQUOTE">SINGLEQUOTE</a> . ')/is';
foreach (array_unique($list_of_literals[0]) as $key=>$value) {
$literals['<#@#@#LITERAL-'.$key.'#@#@#>'] = $value;
/// Analyse literals to prepend the N char to them if their contents aren't numeric
foreach ($literals as $key=>$value) {
if (!is_numeric(trim($value, <a href="../Zikula 1.0.1/_includes---classes---adodb---drivers---adodb-mssql_n.inc.php.html#defineSINGLEQUOTE">SINGLEQUOTE</a>))) {
/// Non numeric string, prepend our dear N
$literals[$key] = 'N' . trim($value, 'N'); //Trimming potentially existing previous "N"
/// Re-apply literals to the text
/// Any pairs followed by N' must be switched to N' followed by those pairs
/// (or strings beginning with single quotes will fail)
$result = preg_replace("/((<@#@#@PAIR-(\d+)@#@#@>)+)N'/", "N'$1", $result);
/// Re-apply pairs of single-quotes to the text
/// Print transformation if debug = on
if ($result != $sql && $this->debug) {
class ADORecordset_mssql_n extends ADORecordset_mssql {
var $databaseType = "mssql_n";
function <a href="../Zikula 1.0.1/ADORecordset_mssql_n.html">ADORecordset_mssql_n</a>($id,$mode=<a href="../Zikula 1.0.1/ADOConnection.html#var$false">false</a>)
$this->ADORecordset_mssql($id,$mode);
|