昆明数据 数据资讯 thinkphp数据库配置文件在哪?

thinkphp数据库配置文件在哪?

一、thinkphp数据库配置文件在哪?

ThinkPHP\Common文件夹中的convention.php中是tp的核心配置文件,不能乱动,如果要想更改里面的配置,在Conf 文件夹里面的config.php可以配置,可以这样写

return array(

'DB_TYPE' => 'mysql',// 数据库类型

'DB_HOST' => '127.0.0.1',// 数据库服务器地址

'DB_NAME' => 'thinkphp',// 数据库名称

'DB_USER' => 'root',// 数据库用户名

'DB_PWD' => '123',// 数据库密码

'DB_PREFIX' => 'tp_',// 数据表前缀

'DB_CHARSET' => 'utf8',// 网站编码

'DB_PORT' => '3306',// 数据库端口

'APP_DEBUG' => false,// 开启调试模式

);

?>

也可以在最外边写,就是与ThinkPHP框架同一目录中写一个config.php文件,格式如同上面的一样,不过在Conf 文件夹里面的config.php中得包含最外边的那个config.php

二、ThinkPHP5.0和ThinkPHP3.2的区别?

URL和路由5.0的URL访问不再支持普通URL模式,路由也不支持正则路由定义,而是全部改为规则路由配合变量规则(正则定义)的方式:主要改进如下:

1.增加路由变量规则;

2.请求对象和响应对象5.0新增了请求对象Request和响应对象Response,Request统一处理请求和获取请求信息,Response对象负责输出客户端或者浏览器响应。

3.废除原来的操作前后置方法;

4.数据库5.0的数据库查询功能增强,原先需要通过模型才能使用的链式查询可以直接通过Db类调用,原来的M函数调用可以改用db函数,例如:3.2版本5.0版本db('User')->where('name','thinkphp')->find();

5.自动验证和自动完成5.0的数据自动验证和自动完成和3.2版本区别较大,5.0的数据验证采用验证器定义并且通过think\Validate类进行统一的验证。自动完成则通过在模型里面定义修改器来完成。

6.异常5.0对错误零容忍,默认情况下会对任何级别的错误抛出异常(但可以在应用公共文件中设置错误级别),并且重新设计了异常页面,展示了详尽的错误信息,便于调试.

三、thinkphp3.2哪种rpc更好?

至于远程调用协议,经过思考,还是选用jsonRPC吧,比较简单方便。

翻了一下thinkphp(是3.2版本)的手册,发现thinkphp还是支持jsonRPC的,这不错啊,不用自己去写了(当然自己写写也不是什么麻烦的事)。

简单地,用thinkphp做客户端,去调用thinkphp服务器端的接口,好用。

四、使用thinkphp3.2,phpexcel怎么导出excel?

目录:C:\xampp\htdocs\gs_apply\ThinkPHP\Library\Vendor\Classes加载phpexcel类的方法:Vendor('Classes.PHPExcel'); $objPHPExcel = new \PHPExcel();

五、引入核心文件ThinkPHP/ThinkPHP.php报错,怎么解决,3.2版本的?

你的php版本是不是该升级了,ThinkPHP是3.2版本要求PHP5.3以上版本。

六、thinkphp3.2验证码检测函数怎么用?

生成验证码下面是最简单的方式生成验证码:$Verify=new\Think\Verify();$Verify->entry();验证码检测functioncheck_verify($code,$id=''){$verify=new\Think\Verify();return$verify->check($code,$id);}

七、ThinkPHP3.2无法加载控制器怎么办?

最直接的错误就是: 比如你URL地址是: ................index/chaxun, 但是你的控制器中 index类 没有 或者找不到 function chaxun() 的方法 至于什么原因导致的

1,检查路径是否正确

2,rewrite规则是否正确或者冲突 3.控制器名有没写错.......

八、thinkphp3.2多文本框多条件模糊查询?

你需要将对应配置进行修改,

ThinkPHP3.2.3升级的若干问题和注意事项(持续更新) - ThinkPHP框架

和数据库交互时,通过参数绑定来实现,可以参考框架文件`ThinkPHP/Library/Think/Db/Driver.class.php`查看具体实现

九、thinkphp怎么加载根目录配置文件?

默认情况就会加载根目录下的配置文件。在ThinkPHP中,一般来说应用的配置文件是自动加载的,加载的顺序是:惯例配置->应用配置->模式配置->调试配置->状态配置->模块配置->扩展配置->动态配置以上是配置文件的加载顺序,因为后面的配置会覆盖之前的同名配置(在没有生效的前提下),所以配置的优先顺序从右到左。

十、thinkphp下MySQL数据库读写分离代码剖析?

当采用原生态的sql语句进行写入操作的时候,要用execute,读操作要用query。

MySQL数据主从同步还是要靠MySQL的机制来实现,所以这个时候MySQL主从同步的延迟问题是需要优化,延迟时间太长不仅影响业务,还影响用户体验。

thinkphp核心类Thinkphp/library/Model.class.php 中,query 方法

调用Thinkphp/library/Think/Db/Driver/Mysql.class.php

/**

* SQL查询

* @access public

* @param string $sql SQL

* @param mixed $parse 是否需要解析SQL

* @return mixed

*/

public function query($sql,$parse=false) {

if(!is_bool($parse) && !is_array($parse)) {

$parse = func_get_args();

array_shift($parse);

}

$sql = $this->parseSql($sql,$parse);

return $this->db->query($sql);

}

调用Thinkphp/library/Think/Db/Driver/Mysql.class.php

/**

* 执行查询 返回数据集

* @access public

* @param string $str sql指令

* @return mixed

*/

public function query($str) {

if(0===stripos($str, 'call')){ // 存储过程查询支持

$this->close();

$this->connected = false;

}

$this->initConnect(false);

if ( !$this->_linkID ) return false;

$this->queryStr = $str;

//释放前次的查询结果

if ( $this->queryID ) { $this->free(); }

N('db_query',1);

// 记录开始执行时间

G('queryStartTime');

$this->queryID = mysql_query($str, $this->_linkID);

$this->debug();

if ( false === $this->queryID ) {

$this->error();

return false;

} else {

$this->numRows = mysql_num_rows($this->queryID);

return $this->getAll();

}

}

上面初始化数据库链接时,initConnect(false),调用Thinkphp/library/Think/Db/Db.class.php,注意false、true代码实现。true表示直接调用主库,false表示调用读写分离的读库。

/**

* 初始化数据库连接

* @access protected

* @param boolean $master 主服务器

* @return void

*/

protected function initConnect($master=true) {

if(1 == C('DB_DEPLOY_TYPE'))

// 采用分布式数据库

$this->_linkID = $this->multiConnect($master);

else

// 默认单数据库

if ( !$this->connected ) $this->_linkID = $this->connect();

}

/**

* 连接分布式服务器

* @access protected

* @param boolean $master 主服务器

* @return void

*/

protected function multiConnect($master=false) {

foreach ($this->config as $key=>$val){

$_config[$key] = explode(',',$val);

}

// 数据库读写是否分离

if(C('DB_RW_SEPARATE')){

// 主从式采用读写分离

if($master)

// 主服务器写入

$r = floor(mt_rand(0,C('DB_MASTER_NUM')-1));

else{

if(is_numeric(C('DB_SLAVE_NO'))) {// 指定服务器读

$r = C('DB_SLAVE_NO');

}else{

// 读操作连接从服务器

本文来自网络,不代表昆明数据立场,转载请注明出处:http://www.kmidc.net/news/18282.html

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注

返回顶部