SQL-запрос на основе Drupal через PHP: count t1 join t2 - PullRequest
0 голосов
/ 24 мая 2011

У меня есть две таблицы, например, так:

table {node}
`nid`, `uid`, `type`
 1    1   basketball
 2    1   basketball
 3    1   football
 4    2   football
 5    2   basketball

table {strato_ticket}
`tid`, `author_uid`, `purpose`, `active`
 1      1   'Ticket to a basketball game' TRUE
 2      1   'Ticket to a football game'   TRUE
 3      2   'Ticket to a football game'   FALSE

Я хотел бы создать отчет, который подсчитывает количество узлов каждого типа, а затем подсчитывает количество активных заявок, связанных с каждым пользователем.с таким типом узла.

Мое решение использует комбинацию SQL и PHP: у меня есть цикл PHP для каждого типа интересующего меня узла, который упрощает запрос SQL и переводит из типа'to' target ', например

$node_types = array('basketball', 'football');
foreach($node_types as $node){
  switch($type){
    case 'basketball':
      $purpose = array('Ticket to a basketball node');
      break;
    case 'football':
      $purpose = array('Ticket to a football game');
      break;
  }
  $where = " WHERE ({strato_ticket}.`purpose` = '"
    .implode("' OR {strato_ticket}.`purpose` = '",$purpose)."')";

Наконец, у меня проблема - запрос SQL.Когда я просто подсчитывал узлы, принадлежащие каждому пользователю, он работал нормально:

$query = "
      SELECT uid, count( * ) AS nodes_owned
      FROM {node} WHERE `type` = '$type'
      GROUP BY uid ORDER BY nodes_owned DESC
      ";
  $query = db_query($query);

output:
Now displaying info for basketball.
uid nodes_owned
 1       2
 2       1
Now displaying info for football.
uid nodes_owned
 1       1
 2       1

Но теперь, когда мне нужно выполнить запрос к другой таблице, strato_ticket, все усложняется, и мой запрос возвращает FALSE, не бросаяошибка (я думаю).

 $query = "
    SELECT count(*) as tickets
    FROM {strato_ticket} INNER JOIN (
        SELECT node.uid, count( * ) AS nodes_owned
        FROM {node} WHERE `type` = '$type'
        GROUP BY uid
      ) AS {nodecount}
      ON {strato_ticket}.`author_uid` = {nodecount}.`uid`
      $where
      GROUP BY nodecount.uid ORDER BY nodecount.nodes_owned DESC
      ";
  $query = db_query($query);

Я не очень хорошо разбираюсь в SQL и не совсем уверен, как он сломался.Не могли бы воспользоваться небольшой помощью?

В идеале хотелось бы посмотреть

uid nodes_owned tickets
//basketball
 1       2        1
 2       1        0
//football 
 1       1        1
 2       1        0

1 Ответ

0 голосов
/ 25 мая 2011

Помимо заполнителей, к которым я могу обратиться позже, я думаю, что это решает это.

$form = array();
$node_types = array('basketball','football');
// if($user->uid == 1){
  $form[$type][] = array('#value'=>"Showing how many of each node type each user owns.".'<br/>');
  foreach($node_types as $type){
  // Count the number of nodes each user owns of $type.
  $form[$type][] = array('#value'=>"Now displaying info for $type".'s. <br/>');
  switch($type){
    case 'basketball':
      $purpose = array('ticket to a basketball game', 'basketball');
    break;
    case 'football':
      $purpose = array('ticket to a football game');
    break;
  }
  $purpose = implode("', '", $purpose);
  //@todo : Make a temporary table to query against so I'm not hitting node table multiple times.
  $ticketquery = "
    SELECT author_uid, purpose, COUNT( * ) AS invitees_accepted
    FROM {strato_ticket}
    WHERE purpose IN ('$purpose')
    GROUP BY author_uid, `purpose`
  ";
  $nodequery = "
    SELECT node.uid, count( * ) AS nodes_owned, type
    FROM {node}
    WHERE `type` IN ('$type')
    GROUP BY uid, type";
  $query = "
    SELECT * FROM
    ($nodequery) AS nt
    JOIN
    ($ticketquery) AS tt
    ON nt.uid = tt.author_uid
    GROUP BY nt.uid ORDER BY nt.nodes_owned DESC
   ";

  drupal_set_message('Query is <br/>'.$query);
  //return;
  $query = db_query($query);
  $first = true;
  while ($rec = db_fetch_object($query)){
    if($first){
      $form[$type][] = array('#value'=>"And the winner is: ".print_r($rec, true).'<br/>');
      $first = false;
    }
    else {
     $form[$type][] = array('#value'=>print_r($rec, true).'<br/>');
    }
  }
 // }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...