tp3.2怎样使用数据库文件(tp32手册)

程序开发 13
本篇文章给大家谈谈tp3.2怎样使用数据库文件,以及tp32手册对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。 Think3.2.3怎么配置多个数据库连接 Think3.2.3配置多个数据库连接方法:一、全局配置定义常用的配置方式是在应用配置文件或者模块配置文件中添加下面的配置参数://数据库配置信息'DB_TYPE' = 'mysql', // 数据库类型

本篇文章给大家谈谈tp3.2怎样使用数据库文件,以及tp32手册对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。

Think3.2.3怎么配置多个数据库连接

Think3.2.3配置多个数据库连接方法:

一、全局配置定义

常用的配置方式是在应用配置文件或者模块配置文件中添加下面的配置参数:

//数据库配置信息

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

'DB_HOST' = 'localhost', // 服务器地址

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

'DB_USER' = 'root', // 用户名

'DB_PWD' = '123456', // 密码

'DB_PORT' = 3306, // 端口

'DB_PREFIX' = 'think_', // 数据库表前缀

'DB_CHARSET'= 'utf8', // 字符集

数据库的类型由DB_TYPE参数设置。

下面是目前支持的数据库设置:

DB_TYPE设置 支持的数据库类型

mysql或mysqli mysql

pgsql pgsql

sqlite sqlite

mssql 或sqlsrv sqlserver

oracle oracle

ibase ibase

mongo mongo

PDO PDO支持的所有数据库

如果DB_TYPE使用PDO类型的话,数据库类型则由DB_DSN配置决定。

或者采用如下配置

'DB_DSN' = 'mysql://root:123456@localhost:3306/thinkphp#utf8'

使用DB_DSN方式定义可以简化配置参数,DSN参数格式为:

数据库类型://用户名:密码@数据库地址:数据库端口/数据库名#字符集

字符集设置需要3.2.1版本以上有效,字符集如果没有设置的话,默认为utf8。

如果两种配置参数同时存在的话,DB_DSN配置参数优先。

注意:如果要设置分布式数据库,暂时不支持DB_DSN方式配置。

如果采用PDO驱动的话,则必须首先配置DB_TYPE为pdo,然后还需要单独配置其他参数,例如:

//PDO连接方式

'DB_TYPE' = 'pdo', // 数据库类型

'DB_USER' = 'root', // 用户名

'DB_PWD' = '', // 密码

'DB_PREFIX' = 'think_', // 数据库表前缀

'DB_DSN' = 'mysql:host=localhost;dbname=thinkphp;charset=utf8'

注意:PDO方式的DB_DSN配置格式有所区别,根据不同的数据库类型设置有所不同,具体可以参考PHP手册。

配置文件定义的数据库连接信息一般是系统默认采用的,因为一般一个应用的数据库访问配置是相同的。该方法系统在连接数据库的时候会自动获取,无需手动连接。

可以对每个模块定义不同的数据库连接信息,如果开启了调试模式的话,还可以在不同的应用状态的配置文件里面定义独立的数据库配置信息。

二、模型类定义

如果在某个模型类里面定义了connection属性的话,则实例化该自定义模型的时候会采用定义的数据库连接信息,而不是配置文件中设置的默认连接信息,通常用于某些数据表位于当前数据库连接之外的其它数据库,例如:

//在模型里单独设置数据库连接信息

namespace HomeModel;

use ThinkModel;

class UserModel extends Model{

protected $connection = array(

'db_type' = 'mysql',

'db_user' = 'root',

'db_pwd' = '1234',

'db_host' = 'localhost',

'db_port' = '3306',

'db_name' = 'thinkphp',

'db_charset' = 'utf8',

);

}

也可以采用DSN方式定义,例如:

//在模型里单独设置数据库连接信息

namespace HomeModel;

use ThinkModel;

class UserModel extends Model{

//或者使用DSN定义

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

}

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

//数据库配置1

'DB_CONFIG1' = array(

'db_type' = 'mysql',

'db_user' = 'root',

'db_pwd' = '1234',

'db_host' = 'localhost',

'db_port' = '3306',

'db_name' = 'thinkphp',

'db_charset'= 'utf8',

),

//数据库配置2

'DB_CONFIG2' = 'mysql://root:1234@localhost:3306/thinkphp#utf8';

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

//在模型里单独设置数据库连接信息

namespace HomeModel;

use ThinkModel;

class UserModel extends Model{

//调用配置文件中的数据库配置1

protected $connection = 'DB_CONFIG1';

}

//在模型里单独设置数据库连接信息

namespace HomeModel;

use ThinkModel;

class InfoModel extends Model{

//调用配置文件中的数据库配置1

protected $connection = 'DB_CONFIG2';

}

三、实例化定义

除了在模型定义的时候指定数据库连接信息外,我们还可以在实例化的时候指定数据库连接信息,例如: 如果采用的是M方法实例化模型的话,也可以支持传入不同的数据库连接信息,例如:

$User = M('User','other_','mysql://root:1234@localhost/demo#utf8');

表示实例化User模型,连接的是demo数据库的other_user表,采用的连接信息是第三个参数配置的。如果我们在项目配置文件中已经配置了DB_CONFIG2的话,也可以采用:

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

需要注意的是,ThinkPHP的数据库连接的惰性的,所以并不是在实例化的时候就连接数据库,而是在有实际的数据操作的时候才会去连接数据库(额外的情况是,在系统第一次实例化模型的时候,会自动连接数据库获取相关模型类对应的数据表的字段信息)。

tp3.2在不开启pdo的情况下该怎么连接mysql数据库

PDO扩展为PHP访问数据库定义了一个轻量级的、一致性的接口,它提供了一个数据访问抽象层,这样,无论使用什么数据库,都可以通过一致的函数执行查询和获取数据。

在一些PHP管理系统需要开启PDO和PDO_MySQL扩展,方法很简单:

1、找到php.ini文件

2、打开后,搜索 extension=php_pdo.dll 和 extension=php_pdo_mysql.dll ,去掉前面“;”的注释。

最终这两行配置内容如下:

extension=php_pdo.dll

extension=php_pdo_mysql.dll

重新启动apache或者iis后,在phpinfo函数中查看,是否开启。

thinkphp3.2怎么连接数据库配置

return array(

//'配置项'='配置值'

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

'DB_HOST' = ' ', // 服务器地址

'DB_NAME' = ' ', // 数据库名

'DB_USER' = ' ', // 用户名

'DB_PWD' = '', // 密码

'DB_PORT' = ' ', // 端口

'DB_PREFIX' = ' ', // 数据库表前缀

'DB_CHARSET' = 'utf8', //编码

)

thinkphp3.2.3怎么插入数据库

ThinkPHP的数据写入操作使用add方法,使用示例如下:

$User = M("User"); // 实例化User对象

$data['name'] = 'ThinkPHP';

$data['email'] = 'ThinkPHP@gmail.com';

$User-add($data);

如果是Mysql数据库的话,还可以支持在数据插入时允许更新操作:

add($data='',$options=array(),$replace=false)

其中add方法增加$replace参数(是否添加数据时允许覆盖),true表示覆盖,默认为false

或者使用data方法连贯操作

$User = M("User"); // 实例化User对象

$User-data($data)-add();

如果在add之前已经创建数据对象的话(例如使用了create或者data方法),add方法就不需要再传入数据了。 使用create方法的例子:

$User = M("User"); // 实例化User对象

// 根据表单提交的POST数据创建数据对象

if($User-create()){

$result = $User-add(); // 写入数据到数据库

if($result){

// 如果主键是自动增长型 成功后返回值就是最新插入的值

$insertId = $result;

}

}

更多问题可以去php中文网问答社区提问,大神在线帮你解决,希望对你有帮助

php框架thinkphp3.2怎么读取数据库内容

先找到config.php文件,如图:

然后打开配置文件并在其中配置数据库的信息,如下代码:

?php

return array(

//'配置项'='配置值'

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

'DB_HOST'               =  '127.0.0.1', // 服务器地址

'DB_NAME'               =  'tpshow',          // 数据库名

'DB_USER'               =  'root',      // 用户名

'DB_PWD'                =  'root',          // 密码

'DB_PORT'               =  '3306',        // 端口

'DB_PREFIX'             =  'tp_'    // 数据库表前缀

);

然后在应用的Home的Controller中,如下图的文件

?php

namespace HomeController;

use ThinkController;

class IndexController extends Controller {

    public function index(){

        $db = M("show"); // 实例化show对象

    $data = $db-find();//读取一条数据

    dump($data);//打印数据

    }

}

thinkPHP3.2使用phpexcel导入文件到数据库

这是我写过的,绝对能用,不行你再找我!!

?php

if($_POST[sub]){

$uptypes=array('application/vnd.ms-excel','application/octet-stream');

$max_file_szie=20*pow(2,20); //上传的文件小于20MB

$destination_folder='../conn/'; //上传文件保存路径

if($_SERVER['REQUEST_METHOD']=='POST'){

if(!is_uploaded_file($_FILES['upfile']['tmp_name'])){

exit("script alert('文件不存在!');history.back();/script");

}

if($max_file_szie$_FILES['upfile']['size']){

exit("script alert('文件太大了!');history.back();/script");

}

if(!in_array($_FILES['upfile']['type'],$uptypes)){

echo '文件类型不符合!'.$_FILES['upfile']['type'];

exit("script alert('文件类型不符合!');history.back();/script");

}

if(!file_exists($destination_folder)){

mkdir($destination_folder);

}

$filename=$_FILES['upfile']['tmp_name'];

$image_size=getimagesize($filename);

$pinfo=pathinfo($_FILES['upfile']['name']); //文件路径信息

$ftype=$pinfo['extension']; //旧文件后缀名

$destination = $destination_folder.$_FILES['upfile']['name']; //新文件名称

if(file_exists($destination)$voerwrie !=true){

exit("script alert('同名文件已经存在了!');history.back();/script");

}

//把上传的文件从临时文件夹移动到指定目录

if(!move_uploaded_file($filename,$destination)){

exit("script alert('移动文件出错了!');history.back();/script");

}

$pinfo=pathinfo($destination);

$fname=$pinfo[basename];

$tpfile=$destination;//上传文件名

//-----------上传成功,导入数据star-----

$dataf=$tpfile;

if(!file_exists($dataf))

{

exit("文件不存在"); //文件不存在

}

$file = fopen("$dataf",'r');

while ($d = fgetcsv($file)) { //每次读取CSV里面的一行内容

//print_r($d); //此为一个数组,要获得每一个数据,访问数组下标即可

$type="`uid`='$d[0]' name='$d[1]'";

$dsql=dbst($tableqz.message2,$type);

if(!$dsql){

$uid=trim($d[0]); //编号

$name=trim($d[1]); //客户名称

$type="(`uid`, `username`, `password`) VALUES (NULL, '$uid', '$name');";

dbin(hh_members,$type);

}

}

fclose($file);

unlink("$dataf");

}

//---上传end

exit("script alert('成功导入了所有数据!');history.back();/script");

}

?

tp3.2怎样使用数据库文件的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于tp32手册、tp3.2怎样使用数据库文件的信息别忘了在本站进行查找喔。

tp3.2怎样使用数据库文件
扫码二维码