首页 后端开发 php教程 ThinkPHP3.1新特性之多数据库操作更加完善_php实例

ThinkPHP3.1新特性之多数据库操作更加完善_php实例

May 17, 2016 am 08:41 AM
新特性

通常情况下,如果一个应用只是操作同一个数据库(或者分布式数据库)的话,你只需要在项目配置文件中定义数据库连接信息即可。这里说的多数据库操作一般指的是在一个应用中会操作不同的数据库(包括同类型的和不同类型的数据库),甚至包括动态切换多数据库的情况。

对于早期版本的ThinkPHP来说,切换数据库需要使用高级模型,而现在的3.1版本则可以更加轻松的解决了。

新版对多数据的支持有下面几种方式,开发人员可以根据实际情况选择合适的方式操作:

1.模型定义数据库

如果只是简单的跨库操作,并且只是个别模型类的话,你可以直接在模型类中定义dbName属性即可:

protected $dbName = 'top';

登录后复制

实例化的时候,记得要使用D方法,例如:

$User = D('User');

登录后复制

这种方式定义的前提是当前数据库用户账户有操作top数据库的权限。

2.模型定义数据库连接

如果你的跨库操作需要使用不同的数据库连接账号或者需要连接不同类型的数据库,可以直接在模型类里面定义connection属性,在操作该模型类的时候,就会自动连接到指定的数据库。例如:

protected $connection = 'mysql://root:1234@localhost:3306/thinkphp';

登录后复制

或者使用数组方式定义:

protected $connection = array(
  'db_type' => 'mysql',
  'db_user' => 'root',
  'db_pwd'  => '1234',
  'db_host' => 'localhost',
  'db_port' => '3306',
  'db_name' => 'thinkphp'
 );

登录后复制

如果我们已经在配置文件中配置了额外的数据库连接信息,例如:

  //数据库配置1
  'DB_CONFIG1' = array(
    'db_type' => 'mysql',
    'db_user' => 'root',
    'db_pwd'  => '1234',
    'db_host' => 'localhost',
    'db_port' => '3306',
    'db_name' => 'thinkphp'
  ),
  //数据库配置2
  'DB_CONFIG2' => 'mysql://root:1234@localhost:3306/thinkphp';

登录后复制

那么,我们可以把模型类的属性定义改为:

//调用配置文件中的数据库配置1
 protected $connection = 'DB_CONFIG1';

登录后复制

或者:

//调用配置文件中的数据库配置2
 protected $connection = 'DB_CONFIG2';

登录后复制

这种方式的优点可以支持不同数据库类型,也就是说可以和当前的项目配置文件中的数据库类型不同,缺点是必须使用D方法实例化,而且不能动态设定。

3.模型实例化指定连接

新版支持在实例化模型的时候指定数据库连接,例如:

$User = new Model('User','think_','mysql://root:1234@localhost/thinkphp'); 

登录后复制

或者使用M方法实例化:

$User = M('User','think_','mysql://root:1234@localhost/thinkphp'); 

登录后复制

M方法的第二个参数是数据表的前缀,如果留空表示采用项目配置的数据表前缀,第三个参数则是当前实例化需要的数据库连接信息。

同样的道理,在实例化中传入的数据库连接信息也可以采用配置名称的方式,例如:

$User = M('User','think_','DB_CONFIG2'); 

登录后复制

如果当前操作不需要切换数据库连接,只是需要切换数据库,则可以采用:

$User = M('top.User','think_'); 

登录后复制

表示实例化top数据库的think_user数据表。如果你的数据表没有前缀,可以使用

$User = M('top.User',null); 

登录后复制

表示实例化top数据库的user表。

4.动态切换连接

系统还提供了更灵活的动态操作,可以使用模型类提供的db方法进行多数据库连接和切换操作,用法:

Model->db("数据库编号","数据库配置");

登录后复制

数据库编号用数字格式,对于已经调用过的数据库连接,是不需要再传入数据库连接信息的,系统会自动记录。对于初始化的数据库连接,内部的数据库编号是0,因此为了避免冲突,请不要再次定义数据库编号为0的数据库配置。

数据库配置的定义方式和模型定义connection属性一样,支持数组、字符串以及调用配置参数三种格式。

Db方法调用后返回当前的模型实例,直接可以继续进行模型的其他操作,所以该方法可以在查询的过程中动态切换,例如:

$this->db(1,"mysql://root:123456@localhost:3306/test")->query("查询SQL");

登录后复制

该方法添加了一个编号为1的数据库连接,并自动切换到当前的数据库连接。

当第二次切换到相同的数据库的时候,就不需要传入数据库连接信息了,可以直接使用:

$this->db(1)->query("查询SQL");

登录后复制

在没有再次进行数据库切换之前,当前的所有操作都是针对db(1)所设置的数据库。
如果需要切换到默认的数据库连接,只需要调用:

$this->db(0);

登录后复制

如果我们已经在项目配置中定义了其他的数据库连接信息,我们就可以直接在db方法中调用配置进行连接了:

$this->db(1,"DB_CONFIG1")->query("查询SQL");
$this->db(2,"DB_CONFIG2")->query("查询SQL");

登录后复制

如果切换数据库之后,数据表和当前不一致的话,可以使用table方法指定要操作的数据表:

$this->db(1)->table("top_user")->find();

登录后复制

如果要返回当前的数据库连接,可以直接调用空的db方法即可,例如:

$db = $this->db();
登录后复制
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

PHP 8.3发布:新特性一览 PHP 8.3发布:新特性一览 Nov 27, 2023 pm 12:52 PM

PHP8.3发布:新特性一览随着技术的不断发展和需求的不断变化,编程语言也在不断更新和改进。作为一种广泛应用于网络开发的脚本语言,PHP一直在不断进步,为开发者提供更强大和高效的工具。最近发布的PHP8.3版本带来了许多期待已久的新特性和改进,下面让我们来看一下这些新特性的一览。非空属性的初始化在过去的PHP版本中,如果一个类的属性没有被明确赋值,它的值

学习PHP8的新特性,深入理解最新技术的指南 学习PHP8的新特性,深入理解最新技术的指南 Dec 23, 2023 pm 01:16 PM

深入解析PHP8的新特性,助您掌握最新技术随着时间的推移,PHP编程语言一直在不断演进和改进。最近发布的PHP8版本为开发者提供了许多令人兴奋的新特性和改进,为我们的开发工作带来了更多便利和效率。在本文中,我们将深入解析PHP8的新特性,并提供具体的代码示例,旨在帮助您更好地掌握这些最新的技术。JIT编译器PHP8引入了JIT(Just-In-Time)编

php8有什么新特性 php8有什么新特性 Sep 25, 2023 pm 01:34 PM

php8新特性有JIT 编译器、类型推导、命名参数、联合类型、属性、错误处理改进、异步编程支持、新的标准库函数和匿名类的扩展等。详细介绍:1、JIT编译器,PHP8引入了JIT编译器,这是一个重要的性能改进,JIT编译器可以对一些高频执行的代码进行实时编译和优化,从而提高运行速度;2、类型推导,PHP8引入了类型推导功能,允许开发者在声明变量时自动推导出变量的类型等等。

Go语言新特性解读:让编程更高效 Go语言新特性解读:让编程更高效 Mar 10, 2024 pm 12:27 PM

【Go语言新特性解读:让编程更高效,需要具体代码示例】近年来,Go语言在软件开发领域备受关注,其简洁、高效的设计理念吸引了越来越多的开发者。作为一种静态类型的编程语言,Go语言不断推出新的特性以提高开发效率,简化代码编写过程。本文将深入解读Go语言最新的特性,探讨如何通过具体的代码示例来体验这些新特性带来的便利。模块化开发(GoModules)Go语言从1

CSS3的新特性一览:如何使用CSS3实现过渡效果 CSS3的新特性一览:如何使用CSS3实现过渡效果 Sep 09, 2023 am 11:27 AM

CSS3的新特性一览:如何使用CSS3实现过渡效果CSS3作为CSS的最新版本,在众多新特性中,最有趣和实用的应该是过渡效果(transition)。过渡效果可以让我们的页面在交互时更加平滑、漂亮,给用户带来良好的视觉体验。本文将介绍CSS3过渡效果的基本用法,并附带相应的代码示例。transition-property属性:指定需要过渡的CSS属性过渡效果

PHP8.1引入的新的Redis扩展 PHP8.1引入的新的Redis扩展 Jul 07, 2023 pm 09:41 PM

PHP8.1引入的新的Redis扩展随着互联网的快速发展,大量的数据需要进行存储和处理。为了提高数据处理的效率和性能,缓存成为了一个不可或缺的部分。而在PHP开发中,Redis作为一种高性能的键值对存储系统,被广泛应用于缓存和数据存储的场景。为了进一步提升Redis在PHP中的使用体验,PHP8.1引入了新的Redis扩展,本文将介绍这一扩展的新增功能,并给

CSS3的新特性一览:如何应用CSS3动画效果 CSS3的新特性一览:如何应用CSS3动画效果 Sep 09, 2023 am 09:15 AM

CSS3的新特性一览:如何应用CSS3动画效果引言:随着互联网的发展,CSS3逐渐取代了CSS2成为前端开发中最常用的样式语言。CSS3提供了许多新的特性,其中最受欢迎的是动画效果。通过使用CSS3动画,可以为网页添加令人惊艳的交互效果,提高用户体验。本文将介绍一些CSS3常用的动画特性,并提供相关的代码示例。一、过渡动画(TransitionAnimat

CSS3的新特性一览:如何使用CSS3实现水平居中布局 CSS3的新特性一览:如何使用CSS3实现水平居中布局 Sep 09, 2023 pm 04:09 PM

CSS3的新特性一览:如何使用CSS3实现水平居中布局在网页设计和布局中,水平居中布局是一项常见的需求。过去,我们经常使用复杂的JavaScript或CSS技巧实现此目的。然而,CSS3引入了一些新的特性,使得水平居中布局更加简单和灵活。本文将介绍一些CSS3的新特性,并提供一些代码示例,演示如何使用CSS3实现水平居中布局。一、使用flexbox布局fle

See all articles