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 >=
BETWEEN BETWEEN * AND * 在*和*之间
NOTBETWEEN NOTBETWEEN * AND * 不在*和*之间
IN IN(*,*) 是*中的一个
NOTIN NOTIN(*,*) 不是*中的一个
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--倒序排序
}