2017-11-24 6 views
-1

나는 해결책을 찾을 수있을 것 같지 않은 문제가있어.php 여러 querys 동안 동안

저는 현재 현재 사용자가 작업하고있는 "프로젝트"관리 대시 보드에 표시 할 수있는 플러그인을 작성하고 있습니다. 그 때문에 2 쿼리가 필요하지만 두 번째 쿼리를 쿼리 할 때 어떤 이유로 사이트가 작동을 멈 춥니 다.

나는 3 개 테이블

wp_posts (POST_NAME 및 ID)

wp_cpm_user_role (PROJECT_ID 및 USER_ID)

wp_users (ID 및 login_login)

가지고 :

wp_posts.ID = wp_cpm_user_role.project_id 

그리고 :

wp_cpm_user_role.user_id 0 wp_users.ID 

내 코드는 지금까지

Function assigned_projects(){ 
//database information 
$current_user = wp_get_current_user(); 
    $servername = "localhost"; 
    $username = "root"; 
    $password = "Password1"; 
    $dbname = "wordpress"; 

    //Create connection 
    $conn = new mysqli($servername, $username, $password, $dbname); 

    if ($mysqli->connect_errno) 
    { 
      printf("Connect failed: %s\n", $mysqli->connect_error); 
      exit(); 
    } 

//First query 
    $sql = "SELECT wp_posts.post_name, wp_posts.ID 
FROM wordpress.wp_posts 
INNER JOIN wp_postmeta ON wp_posts.ID = wp_postmeta.post_id 
WHERE post_type = 'cpm_project' AND meta_key = '_project_active' AND meta_value = 'yes'"; 
$result = $conn->query($sql); 

//get login name on current user 
    $user = $current_user->user_login; 

    //prepare table for presentation 
      echo '<table class="HOTtable">'; 
      echo '<tr>'; 
      echo '<td class="tdcenter">Project name<hr></td>'; 
      echo '<td class="tdright">Quick link<hr></td>'; 
      echo '</tr>'; 

    if ($result->num_rows > 0) 
    { 
      //output data of each row 
      while($row = $result->fetch_assoc()) 
      { 
        $name = $row["post_name"]; 
        $ID = $row["ID"]; 

     //create a direct link to the project url 
        $url = "https://localhost/wp-admin/admin.php?page=cpm_projects&tab=project&action=overview&pid=" . $ID; 

     //second query to match users with projects 
        $sql1 = "SELECT wp_cpm_user_role.user_id, wp_cpm_user_role.project_id, wp_users.user_login FROM wordpress.wp_cpm_user_role INNER JOIN wp_users ON wp_cpm_user_role.user_id = wp_users.ID WHERE wp_cpm_user_role.project_id =" . $ID; 
        $result1 = $conn->query($sql1); 

        while($row1 = $result1->fetch_assoc()) 
        { 
          if ($user == $row1["user_login"] AND $ID == $row1["project_id"]) 
          { 
            echo '<tr>'; 
            echo '<td class="tdcenter">' . $name . '<hr></td>'; 
            echo '<td class="tdright"><a href=' . $url . '>I am the link</a><hr></td>'; 
            echo '</tr>'; 
          } 
        } 
      } 
    } 
    echo '</table>'; 
    $conn->close; 
} 
+0

두 번째 쿼리는지나 갔습니까? MySQL 오류 로그를 보셨습니까? – iquellis

+0

echo $ sql1을 시도하십시오; PHPMyAdmin에서 실행하여 오류가 있는지 확인하십시오. –

답변

-1

내 코드를 삭제하고 내 원래의 게시물에서 코드를 복사했는데, 그것은 ... 지금 작동

코딩이 혼란 스럽습니다. 그러나 시간을내어 주셔서 감사합니다.