Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/295.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Php 只使用一次完整的_Php_Mysql_Codeigniter - Fatal编程技术网

Php 只使用一次完整的

Php 只使用一次完整的,php,mysql,codeigniter,Php,Mysql,Codeigniter,我的表由100个不同的名称组成,所有名称都是唯一的,并且都有一个主键,主键是一个介于1-100之间的数字 如何从第一个名称开始,为每个名称调用一个函数,确保只使用一次,一旦使用每个名称,它将从一开始重新开始,并循环5次 如何才能做到这一点?如果所有名称本身都是唯一的,那么您不必担心检查名称是否已被调用,因为它在您的记录集中只存在一次 如果您只需要函数的名称和id,并且名称的总数不像您提到的~100那么大,那么最简单的方法就是在开始时将它们全部提取到内存中,这样您就不必处理DB游标或重新查询 PD

我的表由100个不同的名称组成,所有名称都是唯一的,并且都有一个主键,主键是一个介于1-100之间的数字

如何从第一个名称开始,为每个名称调用一个函数,确保只使用一次,一旦使用每个名称,它将从一开始重新开始,并循环5次


如何才能做到这一点?

如果所有名称本身都是唯一的,那么您不必担心检查名称是否已被调用,因为它在您的记录集中只存在一次

如果您只需要函数的名称和id,并且名称的总数不像您提到的~100那么大,那么最简单的方法就是在开始时将它们全部提取到内存中,这样您就不必处理DB游标或重新查询

PDO示例:

$db = new PDO($dsn, $username, $password);

// fetch all records returning an array like:
// array($id => $name)
$names = $db->query('SELECT id, name FROM tablename')->fetchAll(PDO::FETCH_KEY_PAIR);

for($i = 0; $i < 5; $i++)
{
   foreach($names as $id => $name)
   {
     myfunction($id, $name); // call your function
   }
}
Mysqli示例:

$db = new Mysqli($host, $username, $password, $dbname);
$result = $db->query('SELECT id, name FROM tablename');

if($result)
{
  $names = $result->fetch_all(MYSQLI_ASSOC);
  $result->free();

  for($i = 0; $i < 5; $i++)
  {
     foreach($names as $j => $row)
     {
       myfunction($row['id'], $row['name']); // call your function
     }
  }
}

如果所有名称本身都是唯一的,那么您不必担心检查名称是否已被调用,因为它在您的记录集中只存在一次

如果您只需要函数的名称和id,并且名称的总数不像您提到的~100那么大,那么最简单的方法就是在开始时将它们全部提取到内存中,这样您就不必处理DB游标或重新查询

PDO示例:

$db = new PDO($dsn, $username, $password);

// fetch all records returning an array like:
// array($id => $name)
$names = $db->query('SELECT id, name FROM tablename')->fetchAll(PDO::FETCH_KEY_PAIR);

for($i = 0; $i < 5; $i++)
{
   foreach($names as $id => $name)
   {
     myfunction($id, $name); // call your function
   }
}
Mysqli示例:

$db = new Mysqli($host, $username, $password, $dbname);
$result = $db->query('SELECT id, name FROM tablename');

if($result)
{
  $names = $result->fetch_all(MYSQLI_ASSOC);
  $result->free();

  for($i = 0; $i < 5; $i++)
  {
     foreach($names as $j => $row)
     {
       myfunction($row['id'], $row['name']); // call your function
     }
  }
}

那么,你想对表中的每一项调用函数,按顺序,五次?你能在表中添加一列,告诉你调用该行函数的次数吗?是的,这正是我想做的。这个问题的标题没有意义。所以,你想对表中的每一项调用函数,按顺序,五次?能否在表中添加一列,告诉您在该行上调用函数的次数?是的,这正是我想做的。这个问题的标题没有任何意义。您可能需要提及您正在使用的数据库扩展或库,这样就不会产生混淆。。。看起来像CodeIgniter,也许吧?我已经添加了到CodeIgniter提供的数据库类的链接-注意。您可能想提及您在那里使用的数据库扩展或库,这样就不会产生混淆。。。看起来像CodeIgniter,也许吧?我已经添加了到CodeIgniter提供的数据库类的链接-当做