仅使用一次整数

时间:2011-03-23 06:55:09

标签: php mysql codeigniter

我的表由100个不同的名称组成,全部都是唯一的,并且所有名称都有一个1-100之间的数字。

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

我该如何做到这一点?

2 个答案:

答案 0 :(得分:3)

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

如果您需要的只是函数的名称和ID,并且您的名称总数不是太大(比如您提到的~100)那么最简单的方法就是将它们全部提取到内存中,这样您就不必处理数据库游标或重新查询。

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
     }
  }
}

答案 1 :(得分:0)

http://codeigniter.com/user_guide/database/index.html

$this->db->select('id, name');
$query = $this->db->get('mytable');
for($i =0; i<5; i++){
foreach ($query->result_array() as $row)
{
    /* you can use $row['id'] and $row['name']
     and pass them as arguments your function 
   */
}

}