200字范文,内容丰富有趣,生活中的好帮手!
200字范文 > thinkphp5.0连接mysql_thinkphp5.0数据库操作

thinkphp5.0连接mysql_thinkphp5.0数据库操作

时间:2019-09-20 18:29:40

相关推荐

thinkphp5.0连接mysql_thinkphp5.0数据库操作

ThinkPHP数据库处理:

1.MySQL的数据库连接

首先配置database.php文件

使用{dump(config('database));}来查看数据库的配置项

使用 {$res = Db::connect(); dump($res);}来查看数据库的连接信息

我们可以在{Db::connect()}中来配置数据库的连接,具体的方法为:

{

Db::connect([

// 数据库类型

'type' => 'mysql',

// 服务器地址

'hostname' => '127.0.0.1',

// 数据库名

'database' => 'habbit',

// 用户名

'username' => 'root',

// 密码

'password' => 'root',

// 端口

'hostport' => '3306',

// 连接dsn

'dsn' => '',

// 数据库连接参数

'params' => [],

// 数据库编码默认采用utf8

'charset' => 'utf8',

]);

}

2.数据库的查询

3.数据库的插入

insert方法:

Db::name('表名(如果配置前缀名,可以省略)') -> insert([

"键" => "值"

]);

insert方法返回的是影响记录的行数

#insertGetId方法:

Db::name('表名(如果配置前缀名,可以省略)') -> insertGetId([

"键" => "值"

]);

insertGetId方法返回的是插入数据的自增id

#insertAll方法(可以一次插入多个数组):

Db::name('表名(如果配置前缀名,可以省略)') -> insertAll(数据);

insertAll方法返回的是插入成功的行数

4.数据的更新

#update方法:

Db::name('表名(如果配置前缀名,可以省略)') -> where(条件) -> update([

"键" => "值"

]);

返回的是被影响的行数。

#setField方法:

Db::name('表名(如果配置前缀名,可以省略)') -> where(条件) -> setField("键","值");

#setInc方法:

Db::name('表名(如果配置前缀名,可以省略)') -> where(条件) ->setInc("键",数值);

返回值为被影响行数,如果方法中不传数值即{setInc("键")},则每次执行,键对应的value会自增一,如果有数值,则每次自增数值

#setDec方法:

Db::name('表名(如果配置前缀名,可以省略)') -> where(条件) ->setDec("键",数值);

和setInc方法相反,setDec为自减。

5.数据的删除:

Db::name('表名(如果配置前缀名,可以省略)') -> where(条件) ->delete();

返回值为被影响行数

Db::name('表名(如果配置前缀名,可以省略)') -> delete("主键");

6.条件构造器

语法:

{where("id","","")}//字符串

{where([])}//数组

{where("id","EXP","in [1,2,3]")}//不会重构sql语句

EQ=

NEQ<>不等于

LT<

ELT<=

GT>

EGT>=

BETWEENBETWEEN * AND *在*和*之间

NOTBETWEENNOTBETWEEN * AND *不在*和*之间

ININ(*,*)是*中的一个

NOTINNOTIN(*,*)不是*中的一个

whereOr方法:

{where(条件1)->whereOr(条件2)}//满足条件1或条件2

7.使用model层来封装方法:

#查询:

get(主键);//查询到对应主键的数据

all(function($query){

$query -> where(条件);

});

Model::where(条件)->select();

Model::where(条件)->value(字段名);//返回一个字符串

#添加:

Model::creat(数据);//插入数据,返回值为model对象

Model::creat(数据,true);//忽略数据库中没有的字段插入

Model::creat(数据,['字段1','字段2',...]);//只允许插入对应字段的数据

model->save();//使用save方法时必须实例化model,返回值为影响行数

model->allowField(true)->save(数据);//插入数据时忽略数据库中没有的字段

model->allowField(['字段1','字段2',...])->save(数据);//只允许插入对应字段的数据

model->saveAll(数据);//使用saveALl方法时必须实例化model,可以批量添加数据,返回值为model对象

其中添加的数据为一个二维数组:

$data = [

[第一条],

[第二条],

[第三条],

.

.

.

];

#更新数据:

Model::update(数组);//修改数据,如果有主键值(自增id),则不需要传递条件(不建议使用)

update(

"id" => 1,

"name" => "123"

);

update(数组,function($query){

$query->where(条件);

});//带有条件的数据更新

Model::where(条件)->update(数组);//更新特定的数据(建议使用)

Model->save(["username"=>"123"],function($query){

$query->where(条件);

});//将符合条件的username改为123(建议使用)

Model->saveAll(数组);//可以用来批量更新,其中传递的数组为二维数组,对应一组数据,其中的一维数组,对应一条数据(不建议使用)

{

$data = [

['id'=>1,'username'=>'123'],

['id'=>2,'username'=>'1234'],

['id'=>3,'username'=>'12345'],

.

.

.

];

}//批量修改id等于1,2,3的usernam

#删除:

destroy(主键);//删除对应主键的数据

destroy(['id'=>1]);//删除id=1的数据

destroy(function($query){

$query-where(条件);

})

Model::where(条件)->delete();

扩展{

limit(5)//输出5条

limit(5,5)//从第5条开始取5条

page(3,5)//第三页的5条数据 用于分页

group()//分组方法

order()//排序方法 DESC--倒序排序

}

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。