2011-10-27 9 views
0

ここで助けが必要な場合は、各メンバーの行数を数え、それらにメールします。WHILE/Loop内でクエリを実行しています

これで、現在いくつの投稿があるのか​​を簡単なメールで知らせることができます。私はメインクエリの中で2番目のクエリを実行する方法を探しました。(ポストテーブルの投稿を数えます。私たちが望むのは、電子メールに各投稿も表示することです。私はすでに最初のクエリでテーブルに参加しています。

ここには現在コードがあります。どんな助けでも大歓迎です。

<?php 

//Connect to mysql server 
$link = mysql_connect(localhost, xxxxxxx, xxxxxxxx); 
if(!$link) { 
    die('Failed to connect to server: ' . mysql_error()); 
} 

//Select database 
$db = mysql_select_db(systm_test); 
if(!$db) { 
    die("Unable to select database"); 
} 
$count = 0; 
$date = date("Y-m-d", $_SERVER['REQUEST_TIME']); 
$day = date("l F jS, Y", $_SERVER['REQUEST_TIME']); 

$qry= sprintf("SELECT p.tech, p.date, e.email, e.fullname, " 
      . "COUNT(*) AS record_count " 
      . "FROM users_test AS e " 
      . "JOIN sc AS p ON e.tech = p.tech " 
      . "WHERE DATE = '%s' " 
      . "GROUP BY p.tech, e.fullname, e.email, p.date", 
      $date 
    ); 

$result = mysql_query($qry); 

if (!$result) { 
    # something went wrong... 
    error_log(sprintf('%d: %s', mysql_errno(), mysql_error())); 
    echo 'Unable to retrieve callpost report'; 

} else { 

    while ($node = mysql_fetch_object($result)) { 



     $headers = "From: xxxxxxxxxx <[email protected]>\r\n"; 
     $headers .= "Content-Type: text/html; charset=\"iso-8859-1\"\r\n"; 
     $headers .= "X-Priority: 1 (Higuest)\r\n"; 
     $headers .= "Importance: High\r\n"; 

     $subject = sprintf('%s | Post Report', $node->fullname); 

      $date = date("Y-m-d", $_SERVER['REQUEST_TIME']); 


     $body = sprintf( 
      'Dear %s, <br><br> 
      Your daily post report for %s. 
      <br> 
      <br>  
      System Info<br> 
      ------------------------------------<br> 
      Member Id:  <b>%d</b><br> 
      Posts:  <b>%d</b> 
      <br> 
      System Name: TEST<br>', 

      $node->fullname, 
      $day, 
      $node->tech, 
      $node->record_count 
     ); 

     if (!mail($node->email, $subject, $body, $headers)) 
     { 
      error_log( 
       sprintf('failed sending email report to %s (%d)', 
        $node->fullname, 
        $node->tech) 
      ); 
     } 
    } //end while statement 
    mail($node->email, $subject, $body, $headers); 
    } 
} 
?> 
+0

一般に、使用しているデータベースに言及する必要があります(また、そのバージョンを使用すると便利です) – jswolf19

答えて

0

あなたの探しているものがサブセレクトです。何かのようなもの。

関連する問題