当前位置: 首页 > 知识库问答 >
问题:

使用CI活动记录在数据库中动态插入值?

鱼锦
2023-03-14

我有一个从外部数据库获取数据的功能,我可以获得特定的电影信息,如id、名称、类型等。现在,如果电影类型是例如动画,我只希望将这一种类型添加到db中。现在我可以使用isset来解决这个问题,但接下来我会为tyresnull设置db条目,我想避免这种情况。解决这个问题的最佳方法是什么?使用foreach循环?

$records = array(
    array('film_id' => $movies['id'], 'genre_id' => $movies['genre'][0]),
    array('film_id' => $movies['id'], 'genre_id' => $movies['genre'][1]),
    array('film_id' => $movies['id'], 'genre_id' => $movies['genre'][2])
);

$this->db->insert_batch('film_genre', $records);

共有2个答案

齐修贤
2023-03-14

您可以使用MySQL的GROUP BY函数对获取的数据进行分组

宋育
2023-03-14

您也可以使用array_filter

$arr = array(

    array("id"=>3, "genre"=>"action"),
    array("id"=>13, "genre"=>"comedy"),
    array("id"=>23, "genre"=>"action"),
    array("id"=>53, "genre"=>"comedy"),
    array("id"=>63, "genre"=>"drama"),
    array("id"=>73, "genre"=>"action"),
    array("id"=>83, "genre"=>"drama"),

);

function genre($var)
{
    if($var['genre'] == 'action')
    {
        return $var;
       // you can also do the insert here like $this->db->insert();
    }
}

$filtered = array_filter($arr, "genre");

print_r($filtered)
 类似资料:
  • 问题内容: 我想在Codeigniter的活动记录中使用mySQL函数NOW()在数据库中插入当前时间。以下查询将不起作用: 这是因为CodeIgniter的ActiveRecord类自动转义输入。 通过调用set()并传递peratmeter FALSE,以下代码可以正常工作,以使它不会逃脱NOW()。 但是,我的问题是,除此之外还有其他方法吗?例如,如果我可以通过只添加数据数组中的所有内容来以

  • 问题内容: 有没有办法一次插入多个记录而不是一次插入? 我有一个非常丑陋的耙子任务,正在做以下事情… 这必须非常低效,并且必须有更好的方法… 问题答案: 该方法也将数组作为参数。 但是,它仍然对每个条目执行一个SQL查询,而不是单个SQL查询。它效率更高,因为它只需要在后台创建一个activerecord对象。 如果要同时从同一客户端插入许多行,请使用带有多个VALUES列表的INSERT语句一次

  • 我是Java新手,在将动态数据插入Excel文件时遇到问题。下面是下面的代码。如果我删除我的excel文件并重新运行我的程序。然后它会创建一个新的文件,也会插入下面的数据。(hello,goodbye,true,date)。在第一次运行期间,程序仍然可以插入下面的数据,但是当我执行下一次运行时,数据不能存储到下一行。这是下面的代码来检查文件是否存在。我希望我可以得到一个人来帮助我,因为我正在为这段

  • 问题内容: 为了在小型Java桌面应用程序中使用日志记录,我试图深入了解某些方法的操作。我使用一个非常愚蠢的小型Java程序对其进行测试。 特别是,在测试LogManager.readConfiguration()方法的行为时,我发现了一些奇怪的东西。在所有测试中,LogManager均从JRE目录中lib / logging.properties中的属性文件中读取其配置。此时,此文件的内容如下:

  • 我在类方法中使用active record import gem来导入从csv文件读取的列表数组,如下代码所示: 根据active record导入文档,我正在尝试将列表的标题和VIN字段设置为冲突目标。如果列表的VIN字段发生冲突,我希望进行更新,而不是创建。 但是现在,每次我运行CSV上传时,它都在从isting.import创建一个新的列表,而不检查它是否冲突。 我哪里出错了?

  • 问题:是否可以构建一个类方法作用域,它可以基于表中数组中的值查询对象?如果是,我怎么做? 更新:一些进展 我知道了如何使用'select'方法创建一个数组,其中包含我想要的所有对象。但是我仍然需要将结果作为活动记录对象返回,所以我创建了一个类方法范围。