thinkPHP--多数据库交互通信
发布:smiling 来源: PHP粉丝网 添加日期:2014-04-12 16:52:06 浏览: 评论:0
下面是数据库备份的例子,从一个数据库中取数据复制到另一个数据库中.
1,在config.php中配置实用的数据库信息
- //源数据库
- "DB_DSN1" => "mysql://用户名:密码@数据库地址:端口/数据库名称",
- //目标数据库
- "DB_DSN2" => "mysql://用户名:密码@数据库地址:端口/数据库名称",
- //例如:
- "DB_DSN1" => "mysql://user:123@127.0.0.1:3306/db1",
2,使用方法
1) 从config.php取配置信息
$dsn1=C('DB_DSN1');
$dsn2=C("DB_DSN2");
2) 定义模型
$model=new Model();
$model->db("1",$dsn1);//将模型默认定义为dsn1
3) 定义需要查询的源数据表
$table=$model->db("1")->table('查询的表名称');
$data=$table->where(查询条件)->select();
4) 将源数据库数据存入目标数据表
- foreach($data as $val){
- $model->db("2",$dsn2)->query("SET FOREIGN_KEY_CHECKS=0;");
- //保存
- $rev=$model->db("2",$dsn2)->table($table)->where($mWhere)->save($val);
- //添加
- //$rev=$model->db("2",$dsn2)->table($table)->add($val);
- }
- //上面的的操作将数据库又指向了目标数据库
- //还可以使用这样的查询$model->db("2",$dsn2)->query("SET FOREIGN_KEY_CHECKS=0;");
通过上面的4步可以使不同的数据库来回的切换.
Tags: thinkPHP 数据库 交互通信
- 上一篇:thinkphp的缓存技术
- 下一篇:在thinkphp3中如何处理cookie数组
相关文章
- ·ThinkPHP中自定义错误页面和提示页面 (2013-11-15)
- ·ThinkPHP中Ajax返回(2013-11-15)
- ·ThinkPHP中处理表单中注意(2013-11-15)
- ·ThinkPHP中I(),U(),$this->post()等函数(2013-11-15)
- ·ThinkPHP中公共函数路径和配置项路径的映射(2013-11-15)
- ·ThinkPHP中公共配置文件和各自项目中的配置文件组合(2013-11-15)
- ·ThinkPHP在控制器里的javascript代码不能执行解决方法(2013-11-29)
- ·ThinkPHP3.0略缩图不能保存到子目录(2013-12-03)
- ·thinkphp的循环结构(2014-01-10)
- ·thinkphp特殊标签使用(2014-01-10)
- ·thinkphp模板输出汇总(2014-01-10)
- ·thinkphp模板的赋值与替换(2014-01-10)
- ·thinkphp连贯操作(2014-01-10)
- ·thinkphp区间查询、统计查询、SQL直接查询(2014-01-10)
- ·thinkphp的普通查询与表达式查询(2014-01-10)
- ·RBAC类在ThinkPHP中的四种使用方法(2014-01-10)
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)