thinkphp3.2.3框架动态切换多数据库的方法分析
(编辑:jimmy 日期: 2025/11/6 浏览:3 次 )
本文实例讲述了thinkphp3.2.3框架动态切换多数据库的方法。分享给大家供大家参考,具体如下:
版本说明:
thinkphp3.2.3
新增自定义行为类
文件位置:Application/Common/Behaviors/SwitchDbBehavior.class.php
文件内容:
namespace Common\Behaviors;
class SwitchDbBehavior
{
//私有库id,如何连接公有库则设置为share字符串
private $_privateId = '';
/*
* 行为扩展的执行入口必须是run
* $param 为引用传值,所以实参必须是变量
*/
public function run(&$params)
{
//获取私有库id
$this->_privateId = empty($params) && session('"htmlcode">
/*数据库配置*/
define('DB_WECHAT_HOST','127.0.0.1'); //主机host
define('DB_WECHAT_USER','common'); //用户名
define('DB_WECHAT_PASS','common'); //密码
define('DB_WECHAT_NAME','wechat_'); //私有库前缀
define('DB_WECHAT_SHARE_NAME','wechat_share'); //共有库名
define('DB_WECHAT_PORT','3306'); //端口
define('DB_WECHAT_DEBUG',TRUE); //数据库调试模式 开启后可以记录SQL日志
图中代码验证数据库存在不存在的C('PRIVATEIDS')在文件Application/Common/Conf/dbname.php中配置内容如下:
<"htmlcode">
'LOAD_EXT_CONFIG' => 'constants,systemConfig,dbname',//加载常量配置
在使用自定义行为类的时候要在Application/Common/Conf/中新增tags.php
内容如下:
/*
* 扩展行为类配置文件
* @author:liangxifeng
* @date:2016-08-13
*/
return array(
//应用开始标签位添加切换数据库行为
'action_begin'=>array('Common\\Behaviors\\SwitchDbBehavior'),
);
行为类介绍请点击
扩展行为类详细了解请点击
使用方法
在注册session后或手动加载使用,比如在控制器中:
public function index()
{
//注册session切换数据库
session('privateId',2);
//手动切换数据库为私有库
tag('action_begin',$params='share');
$wechat = D('Wechat');
//查询数据库
$res = $wechat->where('wechat_id=1')->find();
echo "<pre>";
var_dump($res);
exit;
}
更多关于thinkPHP相关内容感兴趣的读者可查看本站专题:《ThinkPHP入门教程》、《thinkPHP模板操作技巧总结》、《ThinkPHP常用方法总结》、《codeigniter入门教程》、《CI(CodeIgniter)框架进阶教程》、《Zend FrameWork框架入门教程》及《PHP模板技术总结》。
希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。
下一篇:php的RSA加密解密算法原理与用法分析
高通和谷歌日前宣布,推出首次面向搭载骁龙的Windows PC的优化版Chrome浏览器。
在对骁龙X Elite参考设计的初步测试中,全新的Chrome浏览器在Speedometer 2.1基准测试中实现了显著的性能提升。
预计在2024年年中之前,搭载骁龙X Elite计算平台的PC将面世。该浏览器的提前问世,有助于骁龙PC问世就获得满血表现。
谷歌高级副总裁Hiroshi Lockheimer表示,此次与高通的合作将有助于确保Chrome用户在当前ARM兼容的PC上获得最佳的浏览体验。
在对骁龙X Elite参考设计的初步测试中,全新的Chrome浏览器在Speedometer 2.1基准测试中实现了显著的性能提升。
预计在2024年年中之前,搭载骁龙X Elite计算平台的PC将面世。该浏览器的提前问世,有助于骁龙PC问世就获得满血表现。
谷歌高级副总裁Hiroshi Lockheimer表示,此次与高通的合作将有助于确保Chrome用户在当前ARM兼容的PC上获得最佳的浏览体验。