PHP下CodeIgniter框架链接读取MS Access数据库文件

cI用的是3.0版本,测试用的access为.mdb文件,php要读取Access数据库有两种驱动,一种的odbc,一种是pdo_odbc,两种均可以连接,可是通常会更推荐pdo_odbc,php

要想php中能使用odbc,则必须安装相关驱动,能够在phpinfo中查看:html

一、odbcmysql

二、pdo_odbclinux

若是没有,请自行搜索安装,win下比较简单,linux下就比较麻烦了,lanmp3.1集成环境下能够看写的这篇文章。如下内容只适用用windows场景下,由于后来才知道linux下只有pdo_odbc是不行的,还须要access相关的驱动。git

CI框架中加载另外一中数据库的方法有两种,参考手册中的介绍,因此下面也说下两种方式:github

一、配置文件中静态加载:sql

//config/database.php文件中
//默认的mysql数据库
$db['default'] = array(
    'dsn' => '',
    'hostname' => '127.0.0.1',
    'username' => 'xxx',
    'password' => 'xxx',
//    'hostname' => 'localhost',
//    'username' => 'root',
//    'password' => 'admin',
    'database' => 'xxx',
    'dbdriver' => 'mysqli',
    'dbprefix' => 'ecs_',
    'pconnect' => FALSE,
    'db_debug' => TRUE,
    'cache_on' => FALSE,
    'cachedir' => '',
    'char_set' => 'utf8',
    'dbcollat' => 'utf8_general_ci',
    'swap_pre' => '',
    'encrypt' => FALSE,
    'compress' => FALSE,
    'stricton' => FALSE,
    'failover' => array(),
    'save_queries' => TRUE
);
//access数据库(这个是用的odbc驱动)
$db['access']['hostname'] = "DRIVER={Microsoft Access Driver (*.mdb)}; DBQ=D:/public/Database1.mdb";//你本身的数据库路径
//$db['access']['hostname'] = "pdo:DRIVER={Microsoft Access Driver (*.mdb)}; DBQ=D:/public/Database1.mdb";//这里用odbc而不是pdo_odbc驱动,
$db['access']['username'] = "";
$db['access']['password'] = "";
//$db['access']['database'] = "D:/public/Database1.mdb";//测试有没有都没有影响
$db['access']['dbdriver'] = "odbc";
//$db['access']['dbdriver'] = "pdo";//这里用odbc而不是pdo_odbc驱动,
$db['access']['dbprefix'] = "";
$db['access']['pconnect'] = TRUE;
$db['access']['db_debug'] = TRUE;
$db['access']['cache_on'] = FALSE;
$db['access']['cachedir'] = "";
$db['access']['char_set'] = "utf8";
$db['access']['dbcollat'] = "utf8_general_ci";
$db['access']['swap_pre'] = '';
$db['access']['autoinit'] = TRUE;
$db['access']['stricton'] = FALSE;

使用时:数据库

//读取access中数据
$access_db = $this->load->database('access', TRUE);
$access_db->select('*')->get('user')->result_array();
//读取mysql中的数据
$mysql_db = $this->load->database('default', TRUE);
$mysql_db->select('*')->get('user')->result_array();
//或者仍是原先的mysql查询
$this->db->select('*')->get('user')->result_array();

二、动态加载配置,因为access文件数据库名称可能随时变更,因此放在config/database.php文件中就不合适了因此须要随时加载切换windows

//直接在controller中(这个是用的pdo_odbc驱动)
$dbname = 'D:/public/Database1.mdb';//名称随时能够改变
$access['hostname'] = "odbc:DRIVER={Microsoft Access Driver (*.mdb)}; DBQ={$dbname}";
//$access['hostname'] = "DRIVER={Microsoft Access Driver (*.mdb)}; //这里不用odbc而是用pdo_odbcDBQ={$dbname}";
$access['username'] = "";
$access['password'] = "";
$access['database'] = $dbname;//测试有没有都没影响
$access['dbdriver'] = "pdo";
//$access['dbdriver'] = "odbc";//这里不用odbc而是用pdo_odbc
$access['dbprefix'] = "";
$access['pconnect'] = TRUE;
$access['db_debug'] = TRUE;
$access['cache_on'] = FALSE;
$access['cachedir'] = "";
$access['char_set'] = "utf8";
$access['dbcollat'] = "utf8_general_ci";
$access['swap_pre'] = '';
$access['autoinit'] = TRUE;
$access['stricton'] = FALSE;
//加载
$access_db = $this->load->database($access, true);
//读取access数据
$access_db->select('*')->get('user')->result_array();
//而mysql数据库仍然能够这样:
$this->db->select('*')->get('user')->result_array();

上面例子中虽然用的结构化查询,后面简称AR查询,可是实际上测试用AR来查询access数据库有不少的限制,以及与mysql语法的不少区别:数组

一、AR查询可使用,可是有数组形式的都无效,value值为字符串的都识别为空字符串,包含insert,update方法,以及where的数组形式(where的字符串等其它形式可使用)
二、AR查询中的like()方法不支持,用sql查询能够,但须要注意的是access原生语句是用*来匹配,但因为php用的pdo或odbc来连接,因此仍是用%来匹配
三、AR查询中的select_sum()、select_svg()等方法都不能用,主要缘由access中别名不能是本来名称,可是能够select('sum(id) as abc'),一样别名不要和原有名称一致
四、顺便发现row_array()或者result_array()的一个问题,即别名与另外一个想获取的字段重名时,此方法只能取出一个字段,而真正的mysql,access语句会产生两个同名字段,因此别名必定不要与要查询的其它字段名相同
五、access不支持limit语句,能够在select中用top n的形式获取
六、insert若是用原生access sql语句,必须加上into,即"insert into ..."
七、查询和写入中文时须要转码mb_convert_encoding($v,'utf-8','gbk')或者iconv('gbk', 'utf-8', $v),推荐第一种,但确保mb函数有按照

暂时发现上方的不一样,其他join、group by,order_by等方法都与mysql一致。

可是AR这么多限制,还不如直接用原生sql语句来写。可是原生sql语句中防注入等须要注意(CI中的$this->db->escape($title)方法测试不起做用),因此建议用pdo_odbc驱动,用pdo中的方法:

//PDO查询
$sql="SELECT * FROM user WHERE user_name=:user_name";
$pdoStatement=$access_db->conn_id->prepare($sql);//注意conn_id
$user_name='abc';
$pdoStatement->bindValue(':user_name',$user_name);
$pdoStatement->execute();
$result=$pdoStatement->fetchAll(PDO::FETCH_ASSOC);

能够封装成相关的类来方便访问,github上搜下会不少,参照写就能够(也能够参照原先本身写的这个,这个是读取mysql数据库的,并且很不完善)。

既然上方用pdo的原生语法,本身封装类,那其实也能够不用CI的数据库配置导入等,直接用原生php方法链接便可:

$db = new PDO("odbc:DRIVER={Microsoft Access Driver (*.mdb)}; DBQ=$dbName; Uid=; Pwd=;");

能够参照这篇文章

以上就是PHP链接Access数据库相关,刚接触,应该还有不少坑在前方。