php框架配置什么意思,php框架 – thinkPHP 这两种 配置 M 的方法,有什么区别?

//第一种,在 *Model.class.php:

protected $dbName = 'ybdbshop'; //库名,也可以从配置文件,或者 D() 参数设置;

protected $tableName = 'abc'; //不加前缀的表名,也可以从类名设计;

protected $tablePrefix=""; //表前缀;

//第二种:

protected $connection = array

(

'DB_TYPE' => 'mysql',

'DB_USER' => 'root',

'DB_PWD' => '',

'DB_HOST' => 'localhost',

'DB_PORT' => '3306',

'DB_NAME' => 'ybdbcjd', //库名

'DB_CHARSET' => 'UTF8',

);

这俩到底什么区别?

为什么 第一种 我有时候用 不出错,而我把整个项目都复制到 另一台电脑,就不行了?

回复内容:

//第一种,在 *Model.class.php:

protected $dbName = 'ybdbshop'; //库名,也可以从配置文件,或者 D() 参数设置;

protected $tableName = 'abc'; //不加前缀的表名,也可以从类名设计;

protected $tablePrefix=""; //表前缀;

//第二种:

protected $connection = array

(

'DB_TYPE' => 'mysql',

'DB_USER' => 'root',

'DB_PWD' => '',

'DB_HOST' => 'localhost',

'DB_PORT' => '3306',

'DB_NAME' => 'ybdbcjd', //库名

'DB_CHARSET' => 'UTF8',

);

这俩到底什么区别?

为什么 第一种 我有时候用 不出错,而我把整个项目都复制到 另一台电脑,就不行了?

这个问题我刚才已经回答过你了。

class classoneModel extends Model

{

protected $dbName = 'ybdbcjd';

}

中的$dbName是干什么的。

它是用来操作同一个mysql账户下的另外数据库的,如果你的同一个mysql账户中确实有这个数据库,并且有相应权限的话,是可以正确执行的。生成的类似sql语句为:

select * from ybdbcjd.table

这并非thinkphp自身意义上的切换数据库,而是mysql自身的跨数据库操作语法,局限性较大,不建议使用。

是在当前数据库的环境下操作别的数据库。

use db1

select * from db2.table

但是第二种直接修改$connection的意义在于切换了数据库连接。

是在别的数据库下操作别的数据库。

use db2

select * from tablez

区别就在这里。

如果是少量的操作可以跨数据库,否则直接新建数据库连接即可。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值