Heim >Backend-Entwicklung >PHP-Tutorial >php框架 - thinkPHP 这两种 配置 M 的方法,有什么区别?

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

WBOY
WBOYOriginal
2016-07-06 13:53:38976Durchsuche

<code>//第一种,在 *Model.class.php:
protected $dbName = 'ybdbshop';    //库名,也可以从配置文件,或者 D() 参数设置;
protected $tableName = 'abc';    //不加前缀的表名,也可以从类名设计;
protected $tablePrefix="";    //表前缀;
</code>
<code>//第二种:
protected $connection = array
(
    'DB_TYPE' => 'mysql',
    'DB_USER' => 'root',
    'DB_PWD'  => '',
    'DB_HOST' => 'localhost',
    'DB_PORT' => '3306',
    'DB_NAME' => 'ybdbcjd',    //库名
    'DB_CHARSET' =>    'UTF8',
);</code>

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

回复内容:

<code>//第一种,在 *Model.class.php:
protected $dbName = 'ybdbshop';    //库名,也可以从配置文件,或者 D() 参数设置;
protected $tableName = 'abc';    //不加前缀的表名,也可以从类名设计;
protected $tablePrefix="";    //表前缀;
</code>
<code>//第二种:
protected $connection = array
(
    'DB_TYPE' => 'mysql',
    'DB_USER' => 'root',
    'DB_PWD'  => '',
    'DB_HOST' => 'localhost',
    'DB_PORT' => '3306',
    'DB_NAME' => 'ybdbcjd',    //库名
    'DB_CHARSET' =>    'UTF8',
);</code>

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

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

<code class="php">class classoneModel extends Model
{
    protected $dbName = 'ybdbcjd'; 
}</code>

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

<code class="sql">select * from ybdbcjd.table</code>

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

<code class="sql">use db1
select * from db2.table</code>

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

<code class="sql">use db2
select * from tablez</code>

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

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn