ThinkPHP连接数据库的方式汇总

 更新时间:2014年12月05日 14:21:02   投稿:shichen2014  
这篇文章主要介绍了ThinkPHP连接数据库的方式,包括项目配置文件定义、DSN方式传参、数组传参、模型类里定义等,非常具有实用价值,需要的朋友可以参考下

本文实例汇总了ThinkPHP连接数据库的几种常用方式。分享给大家供大家参考。具体如下:

ThinkPHP内置了抽象数据库访问层,把不同的数据库操作封装起来,我们只需要使用公共的Db类进行操作,而无需针对不同的数据库写不同的代码和底层实现,Db类会自动调用相应的数据库适配器来处理,目前的数据库包括Mysql、MsSQL、PgSQL、Sqlite、Oracle、Ibase以及PDO的支持,如果应用需要使用数据库,必须配置数据库连接信息,数据库的配置文件有多种定义方式:

第一种:在项目配置文件里面定义

复制代码 代码如下:
return array( 
'DB_TYPE'=> 'mysql',  
'DB_HOST'=> 'localhost', 
'DB_NAME'=>'thinkphp',  
'DB_USER'=>'root',  
'DB_PWD'=>'',  
'DB_PORT'=>'3306', 
'DB_PREFIX'=>'think_', 
// 其他项目配置参数……… 
);

系统推荐使用该种方式,因为一般一个项目的数据库访问配置是相同的,该方法系统在连接数据库的时候会自动获取,无需手动连接.

可以对每个项目定义不同的数据库连接信息,还可以在调试配置文件(Conf/debug.php)里面定义调试数据库的配置信息,如果在项目配置文件和调试模式配置文件里面同时定义了数据库连接信息,那么在调试模式下面后者生效,部署模式下面前者生效.

第二种 使用DSN方式在初始化Db类的时候传参数

复制代码 代码如下:
$db_dsn = "mysql://username:passwd@localhost:3306/DbName"; 
$db = new Db($db_dsn);

该方式主要用于在控制器里面自己手动连接数据库的情况,或者用于创建多个数据库连接.

第三种 使用数组传参数

复制代码 代码如下:
$DSN = array(  
'dbms'     => 'mysql',   
'username' => 'username',   
'password' => 'password',   
'hostname' => 'localhost',   
'hostport' => '3306',   
'database' => 'dbname'  
); 
$db = new Db($DSN);

该方式也是用于手动连接数据库的情况,或者用于创建多个数据库连接.

第四种 在模型类里面定义

复制代码 代码如下:
protected $connection = array(  
'dbms'     => 'mysql',   
'username' => 'username',   
'password' => 'password',   
'hostname' => 'localhost',   
'hostport' => '3306',   
'database' => 'dbname'  
); 
// 或者使用下面的定义 
protected $connection = "mysql://username:passwd@localhost:3306/DbName";

如果在某个模型类里面定义了connection属性,则在实例化模型对象的时候,会使用该数据库连接信息进行数据库连接,通常用于某些数据表位于当前数据库连接之外的其它数据库.

ThinkPHP并不是在一开始就会连接数据库,而是在有数据查询操作的时候才会去连接数据库,额外的情况是,在系统第一次操作模型的时候,框架会自动连接数据库获取相关模型类的数据字段信息,并缓存下来.

(字段缓存目录:Runtime/Data/_fields)

ThinkPHP支持PDO方式,如果要使用PDO方式连接数据库,可以参考下面的设置.

我们以项目配置文件定义为例来说明:

复制代码 代码如下:
return array( 
'DB_TYPE'=> 'pdo',  
// 注意DSN的配置针对不同的数据库有所区别 请参考PHP手册PDO类库部分 
'DB_DSN'=> 'mysql:host=localhost;dbname=think', 
'DB_USER'=>'root',  
'DB_PWD'=>'',  
'DB_PREFIX'=>'think_', 
// 其他项目配置参数……… 
);

使用PDO方式的时候,要注意检查是否开启相关的PDO模块,DB_DSN参数仅对PDO方式连接才有效.

更多关于thinkPHP相关内容感兴趣的读者可查看本站专题:《ThinkPHP入门教程》及《ThinkPHP常用方法总结

希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。

相关文章

  • ThinkPHP提示错误Fatal error: Allowed memory size的解决方法

    ThinkPHP提示错误Fatal error: Allowed memory size的解决方法

    这篇文章主要介绍了ThinkPHP提示错误Fatal error: Allowed memory size的解决方法,分析了该错误的原因与具体的解决方法,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-02-02
  • ThinkPHP之用户注册登录留言完整实例

    ThinkPHP之用户注册登录留言完整实例

    这篇文章主要介绍了ThinkPHP之用户注册登录留言完整实例,有助于详细了解ThinkPHP的运作流程,需要的朋友可以参考下
    2014-07-07
  • PHP技术开发微信公众平台

    PHP技术开发微信公众平台

    这篇文章主要介绍了微信公众平台的两种模式(编辑模式和开发模式)顾名思义编辑模式就是写普通的功能,开发模式具有更多的功能,下面主要是针对开发模式做介绍,需要的朋友可以参考下
    2015-07-07
  • 我整理的PHP 7.0主要新特性

    我整理的PHP 7.0主要新特性

    截止到目前为止,PHP官方已经发布了php7的RC5版本,预计在11月份左右会发布第一个正式版本!现在来说php7的重大特性肯定已经是定型了,不会再有什么变动了。后续一些版本的迭代主要也就是修修bug,优化之类的。下面就来说话我们一直期待的php7.0新特征吧
    2016-01-01
  • PHP调用API接口实现天气查询功能的示例

    PHP调用API接口实现天气查询功能的示例

    下面小编就为大家带来一篇PHP调用API接口实现天气查询功能的示例。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-09-09
  • 浅谈php fopen下载远程文件的函数

    浅谈php fopen下载远程文件的函数

    下面小编就为大家带来一篇浅谈php fopen下载远程文件的函数。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-11-11
  • php分享朋友圈的实现代码

    php分享朋友圈的实现代码

    这篇文章主要为大家详细介绍了php分享朋友圈的实现代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-02-02
  • Laravel5中Cookie的使用详解

    Laravel5中Cookie的使用详解

    这篇文章主要介绍了Laravel5中Cookie的使用,需要的朋友可以参考下
    2017-05-05
  • 简单PHP上传图片、删除图片实现代码

    简单PHP上传图片、删除图片实现代码

    PHP上传图片、删除图片实现代码,需要的朋友可以参考下。
    2010-05-05
  • PHP将amr音频文件转换为mp3格式的操作细节

    PHP将amr音频文件转换为mp3格式的操作细节

    本文以centos服务器安装ffmpeg为例,给大家详细介绍PHP将amr音频文件转换为mp3格式的操作细节,感兴趣的朋友跟随小编一起看看吧
    2021-07-07

最新评论