1

我最近又开始使用 php(上次好像是 7 年前),一些朋友推荐我使用 codeigniter 框架。

我尝试使用 odbc 驱动程序连接到 MSSQL 2008 R2 中的数据库服务器,使用 x64 php 版本而不是 x64 IIS。这是原因之一,因为我没有使用微软提供的php原生驱动程序,另一个是因为生产环境将在CentOS中,顺便说一句,使用该驱动程序没有任何意义....

切中要害:尝试使用活动记录/odbc 配置连接到数据库会引发此错误

A Database Error Occurred
--------------------------
Error Number: 01000
[Microsoft][SQL Server Native Client 10.0][SQL Server]Executing SQL directly; no cursor.
SELECT * FROM (WebUsers)
Filename: C:\projects\php\test\system\database\DB_driver.php
Line Number: 330

我只执行一个简单的查询来检索表。

$query = $this->db->get('WebUsers');
return $query->result_array();

这些是我的连接设置:

$db['default']['hostname'] = 'Driver={SQL Server Native Client 10.0};Server=localhost;Database=XXXXXXXXX;';
$db['default']['username'] = 'WWWWWW';
$db['default']['password'] = 'YYYYYY';
$db['default']['database'] = 'XXXXXXXXX';
$db['default']['dbdriver'] = 'odbc';
$db['default']['dbprefix'] = '';
$db['default']['pconnect'] = FALSE;
$db['default']['db_debug'] = TRUE;
$db['default']['cache_on'] = FALSE;
$db['default']['cachedir'] = '';
$db['default']['char_set'] = 'utf8';
$db['default']['dbcollat'] = 'utf8_general_ci';
$db['default']['swap_pre'] = '';
$db['default']['autoinit'] = TRUE;
$db['default']['stricton'] = FALSE;

不知道如何解决

4

2 回答 2

3

我认为这是 CI 中的一个老错误。您必须在/system/database/drivers/odbc/odbc_driver.php中修改函数_form_tables()

function _from_tables($tables)
{
    if ( ! is_array($tables))
    {
        return strstr($tables, ',') ? '('.$tables.')' : $tables;
    }
    else
    {
        return count($tables) > 1 ? '('.implode(', ', $tables).')' : end($tables);
    }
}

希望这会奏效。

于 2012-06-11T18:32:49.947 回答
0
$this->db->query($sql);     

而不是上面的查询使用波纹管方法在codeigniter中执行过程

 $this->db->simple_query($sql);
于 2014-06-09T11:09:23.377 回答