分享web开发知识

注册/登录|最近发布|今日推荐

主页 IT知识网页技术软件开发前端开发代码编程运营维护技术分享教程案例
当前位置:首页 > 软件开发

Thinkphp5 ?使用composer中seeder播种机

发布时间:2023-09-06 01:41责任编辑:沈小雨关键词:暂无标签

前因:

前几天,客户要求做一个会员问答的系统,我就按流程做了,到了需要调用数据库数据时,觉得一个个添加又有点笨~

解决过程:

后来查了查手册,看看国外blog案例,我搞出来了个不错的方法~~~

我的使用记录已截图:

直到后面这个,显示出,时间,就表明播种机运行成功了~ 

以下是使用官方过程

Seeder 的创建

在 Thinkphp5 项目中,我们可以在命令行输入下面这条命令:

php think seed:create UserSeeder

创建一个 UserSeeder 文件,创建成功之后你可以在 database/seeds 目录下面看到:

database|-seeds|-|-UserSeeder.php

其内容如下:

<?phpuse think\migration\Seeder;class UserSeeder extends Seeder{ ???/** ????* Run Method. ????* ????* Write your database seeder using this method. ????* ????* More information on writing seeders is available here: ????* http://docs.phinx.org/en/latest/seeding.html ????*/ ???public function run() ???{ ???}}

代码非常的简单,默认的给出了一个 run 方法,现在我们都知道 seeder 文件是用来产生模拟数据的,而产生模拟数据的代码写在 run 方法中就可以了。

Seeder 的 run 方法

run 方法中,我们可以随意填写了可以填充数据库的任意代码。这里我就抛砖引玉啦:

要求:
给数据表 Users 模拟生成100条数据。表结构如下:

字段说明
nickname呢称
email邮箱
password密码

收到需求后,我可以这样写:

<?phpuse think\migration\Seeder;class UserSeeder extends Seeder{ ???/** ????* Run Method. ????* ????* Write your database seeder using this method. ????* ????* More information on writing seeders is available here: ????* http://docs.phinx.org/en/latest/seeding.html ????*/ ???public function run() ???{ ???????$rows = []; ???????for ($i = 0; $i < 100; $i++) { ???????????$rows[] = [ ???????????????‘nickname‘ => mt_rand(10000, 99999), ???????????????‘email‘ => mt_rand(10000, 99999).‘@qq.com‘, ???????????????‘password‘ => md5(‘123456‘), ???????????]; ???????} ???????$this->table(‘users‘)->insert($rows)->save(); ???}}

注意:一定要调用 save() 方法,否则不会保存的。

首先呢,我生成了100条数据,然后调用 $this->table(‘users‘)->insert($rows)->save(); 将生成的数据插入到数据库的 Users 表中。是不是很简单? ^ - ^.

执行 Seeder

Seeder 文件定义好了之后,还必须得执行一下数据才能插入到数据库中,我们可以这样执行:

php think seed:run

执行成功提示: All Done. Took 0.0552s。可以看到:

 
php think seed:run 
 
 
 
 

Thinkphp5 ?使用composer中seeder播种机

原文地址:https://www.cnblogs.com/darrenzzy/p/8436321.html

知识推荐

我的编程学习网——分享web前端后端开发技术知识。 垃圾信息处理邮箱 tousu563@163.com 网站地图
icp备案号 闽ICP备2023006418号-8 不良信息举报平台 互联网安全管理备案 Copyright 2023 www.wodecom.cn All Rights Reserved