我有一个代码,我想在其中使用存储在数据库中的ID在内容中显示我的数据


I have a code in which i want to display my data in the content using there ids stored in database

我正在开发一个网站,这是我的代码,在我的代码中,我有两个id sId(section)和ssId(SubSectionId),我有一个页面,比如说index.php,现在我正在制作这样的url——当我点击左边的导航栏时,我有链接,当我点击一个链接时,它会发送一个类似localhost/index.php?sId=29&ssId=0 的id

现在,我想通过录制发送id localhost/index.php?sId=29&ssId=181 的子部分的相同左导航,使用id在相同的页面index.php上显示ssId=181数据

这里的问题是,结果显示在sId=29的内容区上,而不是ssId=181,并且两者都存储在数据库中。。

if(isset($_GET['sId']) && !empty($_GET['sId']))
{
?>
   <div>
    <br /><br />
        <h2 class="heading">
        <?php 
           $sId = intval($_GET['sId']);
           $qry = "SELECT `SectionId`,`Title`,`Details` FROM `section` WHERE `SectionId` = $sId";
           $records = mysql_query($qry);
           while($record= mysql_fetch_array($records))
           {
              echo $record['Title'];    
          ?>
        </h2>
        <br />
        <p>
        <?php
              echo $record['Details'];
           }
        ?>  
        </p>
    </div>
</div>
<?php
}
elseif(isset($_GET['sId']) && !empty($_GET['sId']) && isset($_GET['ssId']) && !empty($_GET['ssId']))
{
?>      
 <div>
 <br /><br />
 <h2 class="heading">
 <?php 
     $sId = intval($_GET['sId']);
     $ssId = intval($_GET['ssId']); 
     $qry = "SELECT SubSectionId,Title,Details FROM `pages` WHERE `SubSectionId` = $ssId";
     $records = mysql_query($qry);
     while($record= mysql_fetch_array($records))
     {
        echo $record['Title'];
     ?> 
        </h2>
        <br />
        <p>
     <?php 
        echo $record['Details'];
     }
     ?>
        </p>
    </div>
</div>      
<?php   
  }
}

希望你们能理解。提前谢谢。

如果我理解正确,你说的是以下内容。

  1. 脚本需要一个sid和/或ssid作为输入
  2. 如果提供了任何一个,脚本将从DB加载相关内容并显示它
  3. 但是,当前您的脚本不显示ssid的内容,只显示sid的内容

我说得对吗?

尝试使用两个IF块而不是一个IF/ELSE。这将确保所有满足的条件都将运行,而不仅仅是一个条件。

此外,您可以坚持只使用empty函数调用。

if ( !empty($_GET['sId']) ) {
   //load and show content for section
}
if ( !empty($_GET['ssId']) ) {
   //load and show content for sub section
}

更新-要使子部分优先于部分,您需要反转IF/ELSE条件。

if ( !empty($_GET['sId']) && !empty($_GET['ssId']) ) {
   //load and show content for sub section if availavle
} else if ( !empty($_GET['sId']) ) {
   //load and show content for section
}