数据库操作
Laravel中提供DB facade(原始查找)、查询构造器和Eloquent ORM三种操作数据库方式;
新建数据表与连接数据库
新建一张学生表
数据库配置文件在config/database.php
'mysql' => [
'driver' => 'mysql',
'host' => env('DB_HOST', 'localhost'),
'port' => env('DB_PORT', '3306'),
'database' => env('DB_DATABASE', 'forge'),
'username' => env('DB_USERNAME', 'forge'),
'password' => env('DB_PASSWORD', ''),
'charset' => 'utf8',
'collation' => 'utf8_unicode_ci',
'prefix' => '',
'strict' => false,
'engine' => null,
],
发现主机、端口、用户、密码对应的都是env,那么我们找到项目根目录下的env文件修改对应的参数;
使用DB facade实现CURD
首先新建一个StudentController.php控制器
<?php
namespace App\Http\Controllers;
use Illuminate\Support\Facades\DB;
class StudentController extends Controller {
public function test () {
return 'test';
}
}
使用路由访问,记得在routes.php文件中加上对应的路由地址;
Route::get('test', ['uses' => 'StudentController@test']);
- Create(增)
public function test () {
DB::insert('insert into student(name,age) values("gsy","18")');
//另一种写法
DB::insert('insert into student(name,age) values(?,?)', ['hh',20]);
}
- Read(查)
public function test () {
$result = DB::select('select * from student');
dd($result);
}
- Update(改)
DB::update('update student set age = ? where name = ?',[28,'gsy']);
- Delete(删)
DB::delete('delete from student where id = ?',[2]);
查询构造器简介
查询构造器简介:
Laravel查询构造器提供方便、流畅的接口,用来建立及执行数据库查找语法;
使用PDO参数绑定,以保护应用程序免于SQL注入因此传入的参数不需要额外转义特殊字符;
基本可以满足所有的数据库操作,而且在所有支持的数据库系统上都可以执行;
使用查询构造器新增数据:
新增一个add方法
public function add() {
//添加一条数据,返回bool值
$bool = DB::table('student')->insert(
['name' => 'wyx','age' => 18]
);
//添加多条数据,返回bool值
$bool = DB::table('student')->insert([
['name' => 'hhh','age' => 19],
['name' => 'www','age' => 21],
]);
//添加一条数据,返回主键ID
$id = DB::table('student')->insertGetId(
['name' => 'wyx','age' => 18]
);
}
在routes.php文件中配置路由
Route::get('add',['uses' => 'StudentController@add']);
使用查询构造器修改数据:
新增一个update方法
public function update() {
//更新语句,返回影响行数
$num = DB::table('student')->where('id',8)->update(['age' => 30]);
//所有age字段值自增1,返回影响行数
$num = DB::table('student')->increment('age');
//指定字段自增3,返回影响行数
$num = DB::table('student')->where('id',8)->increment('age',3);
//所有age字段值自减1,返回影响行数
$num = DB::table('student')->decrement('age');
//指定字段自减3,返回影响行数
$num = DB::table('student')->where('id',8)->decrement('age',3);
//指定字段自减3同时修改name字段值为tom,返回影响行数
$num = DB::table('student')->where('id',8)->decrement('age',3,['name' => 'tom']);
}
在routes.php文件中配置路由
Route::any('update',['uses' => 'StudentController@update']);
使用查询构造器删除数据:
新增一个delete方法
public function delete() {
//删除ID为8的数据,返回影响行数
$num = DB::table('student')->where('id',8)->delete();
//删除ID>=6的数据,返回影响行数
$num = DB::table('student')->where('id','>=',6)->delete();
}
在routes.php文件中配置路由
Route::any('delete',['uses' => 'StudentController@delete']);
使用查询构造器查询数据:
新增一个select方法
public function select() {
//get方法获取表中所有数据
$result = DB::table('student')->get();
//first方法获取结果集第一条数据
$result = DB::table('student')->first();
//id降序后获取结果集第一条数据
$result = DB::table('student')->orderBy('id','desc')->first();
//where条件
$result = DB::table('student')->where('id','>=',2)->get();
//多个where条件
$result = DB::table('student')->whereRaw('id >= ? and age > ?',[2,23])->get();
//返回指定某个字段的一维数组
$result = DB::table('student')->pluck('name');
//返回指定字段的数组,并以age字段作为数组的下标,会去重
$result = DB::table('student')->lists('name','age');
//返回指定字段的多维数组
$result = DB::table('student')->select('name','id','age')->get();
//当数据库有几十万条数据的时候,如果使用get方法,服务器内存会爆
//使用chunk分段获取数据,每个数组装2条数据,后面要跟上一个闭包也就是匿名函数
DB::table('student')->chunk(2,function ($data) {
dump($data);
});
}
在routes.php文件中配置路由
Route::any('select',['uses' => 'StudentController@select']);
查询构造器中的聚合函数
新建一个query方法
public function query() {
//count函数返回数据表记录总条数
$num = DB::table('student')->count();
//max函数返回该字段最大值
$max = DB::table('student')->max('age');
//min函数返回该字段最小值
$min = DB::table('student')->min('age');
//avg函数返回该字段平均值
$avg = DB::table('student')->avg('age');
//sum函数返回该字段总和
$sum = DB::table('student')->sum('age');
}
数据库操作之Eloquent ORM
Laravel自带的Eloquent ORM是一个优美、简介的ActiveRecord实现,用来实现数据库操作;
每个数据表都有一个与之相对应的“模型”用于和数据表交互;
模型的建立
app根目录下是模型的位置,新建Student.php模型文件与studen表对应
<?php
namespace App;
use Illuminate\Database\Eloquent\Model;
class Student extends Model {
//关联表名
protected $table = 'student';
//指定主键
protected $primaryKey = 'id';
}
控制层新增ormRead查询方法
public function ormRead() {
//返回一个集合,attributes里面存放数据
$result = Student::all();
//返回一个集合,查出ID为4的数据
$result = Student::find(4);
//查询构造器get()在orm中的使用,查出所有数据
$result = Student::get();
//查询构造器first()在orm中的使用,根据条件查出数据
$result = Student::where('id','>','2')->orderBy('age','desc')->first();
//查询构造器chunk()在orm中的使用,每次查出2条数据
Student::chunk(2,function ($data) {
dump($data);
});
}
聚合函数也可在orm中使用,自行测试,查询构造器一定要熟练运用;
rotues.php添加对应路由
Route::any('ormRead',['uses' => 'StudentController@ormRead']);