我有一个名为 name、description 和 features 的表单属性,其中 features 是多个复选框就像
feature 1
feature 2
feature 2
feature 4
用户可以一次选择多个复选框。我有一个名为 product 的数据库表,如
-----------------------------------------
id name description features
-----------------------------------------
当用户选择多个复选框时,我需要将所有复选框值插入到功能列中。现在我可以像 echo 一样选择复选框值
$feat = Input::get('features');
foreach ($feat as $key => $n){
echo $feat[$n];
}
但我需要将这些功能插入到数据库中,对于正常插入,我们会这样做:
$product = new Product;
$product->name = Input::get('name');
$product->description = Input::get('description');
$product->features = Input::get('features');
$product->save();
但是我应该如何修改上面的代码才能将数组值保存到数据库中呢?我正在尝试将值插入同一列,因为我不会根据功能查询它。
最佳答案
这很简单。如果您知道您不会查询这些特征,那么将它们存储为 Json 或序列化数组是完全没问题的。但是,如果您需要查询它们并且它们是您应用程序的关键方面,您应该将它们放在它们自己的表中。
我更喜欢以 Json 格式存储数组,因为它更易于阅读并且不特定于 PHP。 Laravel 为您提供了非常好的选择来完成这项工作。
首先,在迁移中将 features-products 表的字段声明为 json:
Schema::create('products', function (Blueprint $table) {
// ...
$table->json('features');
});
然后将您的Product-model 告诉automatically cast it当您通过简单地设置一个$casts-attribute 来访问它时到一个数组:
class Product extends Model
{
// ...
protected $casts = [
'features' => 'json'
];
}
就是这样。现在数组将存储为 Json,但是当您使用 $product->features 访问它时,您将得到一个数组。
为了让一切变得更简单,你应该设置一个 fillable attribute在您的产品型号上:
class Product extends Model
{
// ...
protected $fillable = ['name', 'description', 'features'];
}
这允许在您的 Controller (或您创建产品的任何地方)中执行类似的操作:
$product = Product::create(Input::all());
...而不是更新它并一一设置属性。
并且如上所述,请确保您不需要这些功能是可查询的,这意味着您不会遇到您试图获得仅具有特定功能或其他东西的某些产品的情况。但是如果你确实需要查找特征,你应该把它们放在它们自己的表中。否则这种方法就很好,因为它更方便。
关于php - 将数组值插入数据库 laravel,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32453987/
我有多个ActiveRecord子类Item的实例数组,我需要根据最早的事件循环打印。在这种情况下,我需要打印付款和维护日期,如下所示:ItemAmaintenancerequiredin5daysItemBpaymentrequiredin6daysItemApaymentrequiredin7daysItemBmaintenancerequiredin8days我目前有两个查询,用于查找maintenance和payment项目(非排他性查询),并输出如下内容:paymentrequiredin...maintenancerequiredin...有什么方法可以改善上述(丑陋的)代
我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i
我的代码目前看起来像这样numbers=[1,2,3,4,5]defpop_threepop=[]3.times{pop有没有办法在一行中完成pop_three方法中的内容?我基本上想做类似numbers.slice(0,3)的事情,但要删除切片中的数组项。嗯...嗯,我想我刚刚意识到我可以试试slice! 最佳答案 是numbers.pop(3)或者numbers.shift(3)如果你想要另一边。 关于ruby-多次弹出/移动ruby数组,我们在StackOverflow上找到一
我需要读入一个包含数字列表的文件。此代码读取文件并将其放入二维数组中。现在我需要获取数组中所有数字的平均值,但我需要将数组的内容更改为int。有什么想法可以将to_i方法放在哪里吗?ClassTerraindefinitializefile_name@input=IO.readlines(file_name)#readinfile@size=@input[0].to_i@land=[@size]x=1whilex 最佳答案 只需将数组映射为整数:@land边注如果你想得到一条线的平均值,你可以这样做:values=@input[x]
我正在使用puppet为ruby程序提供一组常量。我需要提供一组主机名,我的程序将对其进行迭代。在我之前使用的bash脚本中,我只是将它作为一个puppet变量hosts=>"host1,host2"我将其提供给bash脚本作为HOSTS=显然这对ruby不太适用——我需要它的格式hosts=["host1","host2"]自从phosts和putsmy_array.inspect提供输出["host1","host2"]我希望使用其中之一。不幸的是,我终其一生都无法弄清楚如何让它发挥作用。我尝试了以下各项:我发现某处他们指出我需要在函数调用前放置“function_”……这
这个问题在这里已经有了答案:Checktoseeifanarrayisalreadysorted?(8个答案)关闭9年前。我只是想知道是否有办法检查数组是否在增加?这是我的解决方案,但我正在寻找更漂亮的方法:n=-1@arr.flatten.each{|e|returnfalseife
我有一个这样的哈希数组:[{:foo=>2,:date=>Sat,01Sep2014},{:foo2=>2,:date=>Sat,02Sep2014},{:foo3=>3,:date=>Sat,01Sep2014},{:foo4=>4,:date=>Sat,03Sep2014},{:foo5=>5,:date=>Sat,02Sep2014}]如果:date相同,我想合并哈希值。我对上面数组的期望是:[{:foo=>2,:foo3=>3,:date=>Sat,01Sep2014},{:foo2=>2,:foo5=>5:date=>Sat,02Sep2014},{:foo4=>4,:dat
我正在尝试在Ruby中制作一个cli应用程序,它接受一个给定的数组,然后将其显示为一个列表,我可以使用箭头键浏览它。我觉得我已经在Ruby中看到一个库已经这样做了,但我记不起它的名字了。我正在尝试对soundcloud2000中的代码进行逆向工程做类似的事情,但他的代码与SoundcloudAPI的使用紧密耦合。我知道cursesgem,我正在考虑更抽象的东西。广告有没有人见过可以做到这一点的库或一些概念证明的Ruby代码可以做到这一点? 最佳答案 我不知道这是否是您正在寻找的,但也许您可以使用我的想法。由于我没有关于您要完成的工作
我使用Ember作为我的前端和GrapeAPI来为我的API提供服务。前端发送类似:{"service"=>{"name"=>"Name","duration"=>"30","user"=>nil,"organization"=>"org","category"=>nil,"description"=>"description","disabled"=>true,"color"=>nil,"availabilities"=>[{"day"=>"Saturday","enabled"=>false,"timeSlots"=>[{"startAt"=>"09:00AM","endAt"=>
有时我需要处理键/值数据。我不喜欢使用数组,因为它们在大小上没有限制(很容易不小心添加超过2个项目,而且您最终需要稍后验证大小)。此外,0和1的索引变成了魔数(MagicNumber),并且在传达含义方面做得很差(“当我说0时,我的意思是head...”)。散列也不合适,因为可能会不小心添加额外的条目。我写了下面的类来解决这个问题:classPairattr_accessor:head,:taildefinitialize(h,t)@head,@tail=h,tendend它工作得很好并且解决了问题,但我很想知道:Ruby标准库是否已经带有这样一个类? 最佳