laravel学习笔记(一)通过tinker方便的调试数据库
一,factory模型工厂
1,连接数据库执行migrate命令创建表
php artisan migrate
Migration table created successfully.
Migrated: 2014_10_12_000000_create_users_table
Migrated: 2014_10_12_100000_create_password_resets_table
进入laravel自带的tinker,来快捷的调试数据库数据
php artisan tinker
data:image/s3,"s3://crabby-images/977a7/977a70208e6f1ddbbfcb13dd1da654a9cc4017f4" alt=""
通过工厂创建两个用户
factory('App\User',2)->create()
factory接收的两个参数两个参数,第一个接收模型,第二个为创建模型的数量
然后通过create在数据库中生成随机数据
data:image/s3,"s3://crabby-images/d5c28/d5c28ef577e0ba746a032beba7bd5a182ab2af74" alt=""
2,通过常规的方式查询数据
DB::table('users')->get()
通过DB对象找到users表,然后查询users表的所有数据
data:image/s3,"s3://crabby-images/c3c0e/c3c0ec53a3a17f0d0ca1efe7cc0fbd771953ba6d" alt=""
如果我们想要获取一个数组,可以使用all()命令
data:image/s3,"s3://crabby-images/2bbbb/2bbbb4e5eff6ab841e05a927af18d09c04aaed46" alt=""
如果我们要获取第一个元素,那么也非常的简单
直接通过first获取数据库的第一个数据
DB::table('users')->get()->first()
data:image/s3,"s3://crabby-images/fa685/fa685ac8a63ac486400baeaa11d2b7125d96920b" alt=""
我们还可以对查找的元素进行过滤,通过对first传递一个闭包的方式
DB::table('users')->get()->first(function($user){ return $user->name=="Haven Olson"; })
data:image/s3,"s3://crabby-images/91cf4/91cf4e9c68c84e16fe08758c46a044cf6b58a763" alt=""
如图,如果找到,则返回数据,如果没有,则返回空
data:image/s3,"s3://crabby-images/acac5/acac54ba2bac3184ce73557af1a4828fa2200a7d" alt=""
通过php artisan tinker可以很方便的对数据库进行调试,同时方便执行各种有用的动作,特别是当你想要测试一小段代码的时候,你无需再插入各种var_dump和die,然后还要在调试完后删掉它们,你只需要php artisan tinker就够了。