0

この機能を動作させるのに問題があります。これは私のデータベース設計です

私は、ユーザーが親カテゴリを削除すると、すべてのサブカテゴリも削除されるなどのアプリケーションで作業しています..例:

ユーザーがアプリケーションの「Test1」カテゴリをクリックすると、「Test1.1」と「Test1.1.1」は「Test1」カテゴリの下にあるため削除されます。

ここに画像の説明を入力

これは私のデータベース設計です(上記)。

これは私が書いたコードです:

function DeleteProjectPhotos( $cat_id ) {
        $sql = "SELECT * FROM project_category WHERE category_id = '$cat_id'"; 
        $query = mysql_query( $sql ) or die( mysql_error() );
        if( mysql_num_rows( $query ) > 0 ) {
            $sql = "SELECT * FROM project_category WHERE parent_id = '$cat_id'"; 
            $query = mysql_query( $sql ) or die( mysql_error() );
            if( mysql_num_rows( $query ) > 0 ) {
                while( $row = mysql_fetch_assoc( $query ) ) {
                    $this->DeleteProjectPhotos( $row['category_id'] );
                }
            } else {
                $sql = "DELETE FROM project_category WHERE category_id = '$cat_id'";
                $query = mysql_query( $sql ) or die( mysql_error() );
            }
        }
    }

しかし、category_id 33 を削除しようとすると、すべてが削除されないため、ここのロジック全体が間違っていると思います。このやり方を教えてください。

あなたの助けは非常に高く評価され、報われるでしょう!

ありがとう!:)

4

2 に答える 2

1
<?php

$catID = $_GET['catID']; 
deleteCategory($catID);

function connect(){

  $host = 'localhost';
  $dbName = 'sony';
  $userName = 'root';
  $password = '';

  $conn = new PDO("mysql:host=$host;dbname=$dbName",$userName,$password);
  $conn->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);

  return $conn;
  }

  $stmt = '';
 function deleteCategory($catID){

  $conn = connect();
  $tableName = 'childparent';

  $sql = "select catID from $tableName where parentID = :catID";

  global $stmt;
  $stmt = $conn->prepare($sql);


      $idsToDelete = getChilds($catID);
      $idsToDelete[] = $catID;
  //print_r($idsToDelete);

  $delExp = '';
  foreach($idsToDelete as $id)
     $delExp .= " catID=$id or";
  $delExp = preg_replace('/or$/','',$delExp);

  if($delExp != ''){

      $delSql = "delete from $tableName where $delExp";
      //echo $delSql;

       $delStmt = $conn->prepare($delSql);
       $delStmt->execute(); 

      }






  }

 $collectedIDs = array();

 function getChilds($catID){

 global $stmt,$collectedIDs;

 $stmt->bindValue(':catID',$catID);

 $stmt->execute();

 $childCatIDs = array();
 while($row = $stmt->fetch(pdo::FETCH_ASSOC)){

    $childCatIDs[] = $row['catID'];
    $collectedIDs[] = $row['catID'];    
 }

 //print_r($childCatIDs);
 //die();
 if(!empty($childCatIDs)){
        foreach($childCatIDs as $cid)
            getChilds($cid);

 }

 return $collectedIDs;


  }



?>
于 2012-05-27T18:00:54.903 に答える
-1

トリガーが必要ない場合は、http://php.net/manual/en/function.mysql-affected-rows.phpを削除カテゴリで試すことができます。ID を取得し、リターンがある間に削除しようとします。カテゴリ別または親別

于 2012-05-27T16:41:30.887 に答える