- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
如何使用 Yii2 Faker 为 ORM 表创建假记录?例如:
User:
-id
-email
-password
-auth_key
-password_reset_token
-name
-family
-user_img
-is_admin
users_detail:
-id
-user_id
-phone_number
-country
-city
-facebook_url
-googleplus_url
-linkedin_url
-instagram_url
-comment
app.tests.codeception.unit.templates.fixtures
文件代码:
夹具文件 User.php
return [
"email" => $faker->email,
"password" => Yii::$app->getSecurity()->generatePasswordHash('password_' . $index),
"auth_key" => Yii::$app->getSecurity()->generateRandomString(),
"password_reset_token" => Yii::$app->getSecurity()->generateRandomString(),
"name" => $faker->firstName,
"family" => $faker->lastName,
"user_img" => $faker->image(Yii::getAlias("@app/web/uploads/users"), 200, 200, null, false),
"is_admin" => $faker->randomElement(array("1", "0"))
]
关系夹具 user_details.php
return [
"user_id" => ??? I don't know ???,
"phone_number" => $faker->phoneNumber,
"country" => $faker->country,
"city" => $faker->city,
"facebook_url" => $faker->optional()->url,
"googleplus_url" => $faker->optional()->url,
"linkedin_url" => $faker->optional()->url,
"instagram_url" => $faker->optional()->url,
"comment" => $faker->optional()->realText()
];
我需要为用户表中的某些用户使用 faker 为 user_details 表创建数据
最佳答案
对我有用的解决方案是控制主记录的 ID 生成,并在引用字段中也使用该值。
user.php faker 定义:
<?php
/**
* @var $faker \Faker\Generator
* @var $index integer
*/
$security = Yii::$app->getSecurity();
return [
'id' => $index + 1,
'username' => $faker->userName,
'email' => $faker->email,
'auth_key' => $security->generateRandomString(),
'password_hash' => $security->generatePasswordHash( 'password_' . $index ),
//'password_reset_token' => $security->generateRandomString() . '_' . time(),
'confirmed_at' => time(),
//'last_login_at' => time(),
'flags' => 0,
'created_at' => time(),
'updated_at' => time(),
];
关联的token.php faker定义:
<?php
/**
* @var $faker \Faker\Generator
* @var $index integer
*/
$security = Yii::$app->getSecurity();
return [
'user_id' => $index + 1,
'code' => $security->generateRandomString(),
'created_at' => time(),
'type' => 1,
];
$index 变量默认从 0 开始。MySQL 不喜欢 ID 0 值,因此需要添加 +1。
这将生成 user.php 夹具,如下所示:
<?php
return [
'user0' => [
'id' => 1,
'username' => 'arjun.lindgren',
'email' => 'lquitzon@mitchell.com',
'auth_key' => 'yDL6BzlyxBOAFbK15uQ-Fx_AVEqZhE06',
'password_hash' => '$2y$13$SRyNY1ZceQdVMjDFEYaNxeTs0yr5raTgRsquzh6Czom/0loAX9C3W',
'confirmed_at' => 1506074296,
'flags' => 0,
'created_at' => 1506074296,
'updated_at' => 1506074296,
],
'user1' => [
'id' => 2,
'username' => 'jaqueline.bartoletti',
'email' => 'stehr.reginald@schoen.org',
'auth_key' => 'hk1pE_TUoUmqWcxoArOPmRb-t2P7LvKq',
'password_hash' => '$2y$13$IsQxrCaLX4ficjulKKSEbucgLfTyyFSLle30efejBw1giKhwILGSm',
'confirmed_at' => 1506074296,
'flags' => 0,
'created_at' => 1506074296,
'updated_at' => 1506074296,
],
];
还有token.php:
return [
'token0' => [
'user_id' => 1,
'code' => 'nr3oU86ukLjb1oKIlKDBgnj0bWb96mNH',
'created_at' => 1506074295,
'type' => 1,
],
'token1' => [
'user_id' => 2,
'code' => 'TTLcxuS_d_sYDME9m7VShbDsOMEVBqZq',
'created_at' => 1506074295,
'type' => 1,
],
];
不幸的是,生成的别名不会与记录 ID 同步。可能应该将 yii2-faker 扩展更改为从 1 开始以解决此问题。
关于php - 如何建立 Yii2 faker 数据库关系,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38431005/
我正在尝试使用 Excel 中的间接函数来构建公式以在另一张纸上返回值。 在工作表 A 单元格 D3 的值为 B 我想使用值 B 从名为 App Summary 的工作表中的单元格 B6 返回一个值。
我目前正在使用 LumiSoft 的 SIP 堆栈,并且能够在我的 FreePBX 盒子上成功注册分机并调用另一个软电话。我现在需要做的就是通过调用流式传输 WAV 文件(或 RAW,或任何可行的文件
这个问题已经有答案了: How can I fix 'android.os.NetworkOnMainThreadException'? (65 个回答) 已关闭 8 年前。 我有一个安卓 Activ
我正在使用 ws npm 在服务器端,websocket 在客户端。 从 node-js 运行此代码时它工作正常,但从浏览器运行它会出现以下错误: failed: Error in connectio
当我将鼠标悬停在想要淡入和淡出的内容上多次时,它就会不断重复。即使我停止悬停它。我怎样才能阻止这个? $(".featured").hover(function(){ $(this).find
我需要建立一个 mysql 连接并取回一些数据。我可以使用此代码在 Java 中执行此操作 try{ String username;
不能制造愚蠢。具有下一个文件夹结构: /flint/double-conversion/src /燧石/愚蠢/愚蠢/ 其中/flint/folly 包含自述文件和许可证。作为in the readme
我想在编译主单元之前在程序集中嵌入本地引用。但书面目标不起作用。 WithMetadataValue( 'CopyLocal', 'true' )->Met
我不是软件专家,但我确实需要一些建议。 我正在编写一个 C 程序(在下面剪切/粘贴)以通过 LAN(以太网)建立从我的 Mac Pro 到位于它旁边的基于 Windows XP 的测试仪器的 TCP
我正在构建一个应用程序,我的手机经常将数据发送到我的服务器。由于我将使用我的移动数据,我想知道建立(和拆除?)到我的服务器的 TCP 连接需要多少数据。 最佳答案 TCP 三向握手 Device 1
我有一个带有登录表单的网站。当加载登录表单页面时,我创建一个新的 PDO 对象以查看连接是否正常工作。如果成功打开连接,查看者将看到一个登录表单。如果不成功,他们会收到一条消息,说明服务器已关闭。 然
构建我的Electron应用程序后,它将显示产品名称undefined。如何设置其他名称呢? 当前是这样的: 最佳答案 请尝试此操作。引用此链接 https://www.electronjs.org/
我有一个项目在哪里使用这个 jar 。 据我所知...发生 war 之后,文件夹WEB-INF/lib必须具有: mail-1.4.1.jar activation-1.1.jar mysql-con
代码: %{ #include #include #include #include "gener.h" #include "sym_tab.h" #include "scope.h" #inc
我需要将侧边栏小部件集成到我的高流量页面(称为SiteA)中。该小部件应包含我的其他页面之一(称为 SiteB)的最新文章。 在我看来,我有两种可能的解决方案。 SiteA 上的 cUrl 调用从 S
我正在尝试建立 Cortana 技能,以便能够使用 Surface 相机拍照。怎么做?目前我的技能是能够使用bot框架和使用nodejs来回答问题。代码看起来像 bot.dialog('ScanCar
这个问题在这里已经有了答案: Resolving javax.net.ssl.SSLHandshakeException: sun.security.validator.ValidatorExce
当我与网络服务器建立 https 连接时出现 SSLProtocolException。我只在 Android 2.3 Gingebread 中有这个异常(exception);相同的代码在所有其他
我想做的是指定几个端口,然后检查它们是否已建立连接。我找到了以下脚本并运行了,但它只列出了 3 个端口,我不明白为什么。我验证了相关端口的事件规则(以及下面输出中未列出的许多其他端口)。 Set ob
使用 MySQL 我试图使用已经上传到数据库中的数据建立一对多关系。举个例子,假设我在一个表中有一个名字列表,我想将它们连接到一个他们去过的地方的列表。显然 1 个人可以去很多不同的地方,但我在设置时
我是一名优秀的程序员,十分优秀!