Register Register Member Login Member Login Member Login Forgot Password ??
PHP , ASP , ASP.NET, VB.NET, C#, Java , jQuery , Android , iOS , Windows Phone
 

Registered : 109,027

HOME > PHP > PHP Forum > สอบถามปัญหาคำสั่ง SQL ของ MySQLI เกี่ยวกับการเกิด Warning: mysqli_fetch_assoc()



 

สอบถามปัญหาคำสั่ง SQL ของ MySQLI เกี่ยวกับการเกิด Warning: mysqli_fetch_assoc()

 



Topic : 113160



โพสกระทู้ ( 31 )
บทความ ( 0 )



สถานะออฟไลน์




คืออันดับแรก จะมีไฟล์ 2 ไฟล์ ไฟล์ search.php ทำหน้าที่ในการค้นหาข้อมูลเมื่อค้นหาข้อมูลเสร็จเรียบร้อยแล้วก็จะมีฟิวออกมาหลายฟิว มีให้กดเลือก รายละเอียด ไฟล์ที่ 2 ไฟล์ detail.php ก็คือเมื่อกด รายละเอียด มาจากไฟล์ search.php แล้ว จะมาขึ้นที่หน้า detail.php ขึ้นรายละเอียดต่างๆ

ปัญหาคือในไฟล detail.php คำสั่ง SQL ในการ Select บางส่วนสามารถรันได้ไม่มีปัญหา แต่พอมา Select ส่วนนี้ มีปัญหาครับ ขึ้นว่า

Warning: mysqli_fetch_assoc() expects parameter 1 to be mysqli_result, boolean given in


Code (search.php)
<?php
		//ini_set('display_errors', 1);
		//error_reporting(~0);
		
		
			
		include("config.php");
		
		
?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>ค้นหา</title>
</head>

<body>

<form  method="get" name="search">
  <div align="center">
    <table width="338" height="96" border="0" cellpadding="0" cellspacing="0">
    <tr>
        <td>รหัสวิทยานิพนธ์</td>
        <td><label for="txt_ThesisID"></label>
        <input type="text" name="txt_ThesisID" id="txt_ThesisID" /></td>
      </tr>
      <tr>
        <td>ชื่อวิทยานิพนธ์</td>
        <td><label for="txt_ThesisID"></label>
        <input type="text" name="txt_ThesisName" id="txt_ThesisName" /></td>
      </tr>
      <tr>
        <td>ปีการศึกษา</td>
        <td><label for="txt_StudentName"></label>
        <input type="text" name="txt_Year" id="txt_Year" /></td>
      </tr>
      <tr>
        <td>ชื่อนักศึกษา</td>
        <td><label for="txt_StudentName"></label>
        <input type="text" name="txt_StudentName" id="txt_StudentName" /></td>
      </tr>
  </table><br />
  <input name="Search_submit" type="submit" value="Search" id="Search_submit" />
  </div>

</form>
<blockquote>
  <hr align="center"/>
<div align="center">
<?php
			$strSearch_ThesisID ='';
			$strSearch_ThesisName ='';
			$strSearch_Year = '';
			
			
			if(isset($_GET['txt_ThesisID'],$_GET['txt_ThesisName'],$_GET['txt_Year'] )) {
				
				$strSearch_ThesisID = $_GET['txt_ThesisID'];
				
				$strSearch_ThesisName = $_GET['txt_ThesisName'];
				
				$strSearch_Year = $_GET ['txt_Year'];
				
				$strSearch_StudentName = $_GET['txt_StudentName'];
				
						
				$sql = "SELECT * FROM `thesis` WHERE `Thesis_ID` LIKE '%".$strSearch_ThesisID."%' 
				
				AND Thesis_name LIKE '%".$strSearch_ThesisName."%' AND Thesis_year LIKE '%".$strSearch_Year."%'  
				
				 ";
			
			
				$query = mysqli_query($conn,$sql);

?>
</div>
</blockquote>
<div align="center">
<div align="center">
<table width="789" height="75" border="1" cellpadding="1" cellspacing="1">
  <tr>
    <td width="202" height="40"><div align="center">รหัสวิทยานิพนธ์</div></td>
    <td width="407"><div align="center">ชื่อวิทยานิพนธ์</div></td>
    <td width="162"><div align="center">ประจำปีการศึกษา</div></td>
    <td width="162">&nbsp;</td>
  </tr>
  
<?php

while($result = mysqli_fetch_assoc($query) )


{
	$searchID = $result['Thesis_ID'];
	$searchThesisname = $result['Thesis_name'];
	$searchThesisYear = $result['Thesis_year'];
	
?>
  <tr>
    <td height="32"><div align="center"><?php echo $searchID; ?></div></td>
    <td><?php echo $searchThesisname; ?></td>
    <td><div align="center"><?php echo $searchThesisYear; ?></div></td>
    <td><div align="center"><a href="detail_thesis.php?Thesis_ID=<?php echo $searchID;?>">รายละเอียด</a></div></td>
  </tr>

<?php
} //End while loop

}

mysqli_close($conn);
			
?>

</table>
</div>
</body>
</html>



Code (detail.php)
<?php
		include("config.php");
		
		//ini_set('display_errors', 1);
		//error_reporting(~0);
		
		
		
		
		if(isset($_GET['Thesis_ID'])){
			
			$strThesis_ID = $_GET['Thesis_ID'];
		}
		
			
			$sql = "SELECT *
			
					FROM thesis INNER JOIN student ON thesis.Thesis_ID = student.Thesis_ID 
					
					WHERE Thesis_ID = '".$strThesis_ID."'";
		
		
			//$sql = "SELECT *
			
					//FROM department INNER JOIN thesis ON department.Department_ID = thesis.Department_ID
						
					//WHERE Thesis_ID = '".$strThesis_ID."' ";
			
			
			
			
		
		
	
	$query = mysqli_query($conn,$sql);
	
	
	
	$result = mysqli_fetch_assoc($query);
	
	$result_thesisID = $result['Thesis_ID'];
	$result_thesisName = $result['Thesis_name'];
	$result_thesisYear = $result['Thesis_year'];
	$result_studentName = $result['Student_name'];
	//$result_teacherName = $result['Teacher_name'];
	
	
	

?>



ใน ไฟล์ detail ที่ผมทำ //$sql = "SELECT * ตรงคำสั่ง SQL นั้น ผมรันได้ไม่มีปัญหาอะไร



Tag : PHP, MySQL









ประวัติการแก้ไข
2014-12-10 19:52:08
2014-12-10 20:07:12
Move To Hilight (Stock) 
Send To Friend.Bookmark.
Date : 2014-12-10 19:48:48 By : tairatza View : 807 Reply : 7
 

 

No. 1



โพสกระทู้ ( 9,556 )
บทความ ( 2 )



สถานะออฟไลน์


35. $query = mysqli_query($conn,$sql) or die ( $sql . "<br>" . mysqli_error($conn) );

เพิ่มสีแดงครับ แล้วเอามาดูครับ






แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-12-10 20:13:50 By : Chaidhanan
 


 

No. 2



โพสกระทู้ ( 31 )
บทความ ( 0 )



สถานะออฟไลน์


ตอบความคิดเห็นที่ : 1 เขียนโดย : Chaidhanan เมื่อวันที่ 2014-12-10 20:13:50
รายละเอียดของการตอบ ::
พอรันแล้วได้แบบนี้ครับ สังเกตุที่ Thesis_ID = 'TS-2551' ตรงนี้ ผมเลือก เลขที่วิทยานิพนธ์ ที่มี ID 'TS-2551' ครับ
SELECT * FROM thesis INNER JOIN student ON thesis.Thesis_ID = student.Thesis_ID WHERE Thesis_ID = 'TS-2551'
Column 'Thesis_ID' in where clause is ambiguous

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-12-10 20:31:24 By : tairatza
 

 

No. 3



โพสกระทู้ ( 9,556 )
บทความ ( 2 )



สถานะออฟไลน์


WHERE Thesis_ID = 'TS-2551'

Column 'Thesis_ID' in where clause is ambiguous

เกิดจาก ชื่อ มีอยู่ ทั้ง สองตารางครับ ต้องกำหนดชื่อตารางให้มัน

เช่น table1.Thesis_ID

สีแดงใส่ชื่อตารางที่ถูกต้องครับ


ประวัติการแก้ไข
2014-12-10 20:36:30
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-12-10 20:35:30 By : Chaidhanan
 


 

No. 4



โพสกระทู้ ( 1,819 )
บทความ ( 20 )

สมาชิกที่ใส่เสื้อไทยครีเอท

สถานะออฟไลน์
Facebook

เพราะมันไม่รู้ว่า Thesis_ID ใน WHERE เนี่ย จะใช้ของตารางไหนครับ
ก็แค่ให้ระบุไปว่าเป็นของตารางไหนครับ

Code
$sql = "SELECT * FROM thesis INNER JOIN student ON thesis.Thesis_ID = student.Thesis_ID WHERE thesis.Thesis_ID = '".$strThesis_ID."'";

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-12-10 20:36:00 By : phpinfo()
 


 

No. 5



โพสกระทู้ ( 31 )
บทความ ( 0 )



สถานะออฟไลน์


ขอขอบคุณท่าน ทั้ง 2 คนมากนะครับ ได้แล้วละครับ เดวจะลองนำ table อีก 3 table มาต่อกันดูครับ

ถ้าเจองูคงโดนชกตาย T^T
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-12-10 20:49:20 By : tairatza
 


 

No. 6



โพสกระทู้ ( 1,819 )
บทความ ( 20 )

สมาชิกที่ใส่เสื้อไทยครีเอท

สถานะออฟไลน์
Facebook

ตอบความคิดเห็นที่ : 5 เขียนโดย : tairatza เมื่อวันที่ 2014-12-10 20:49:20
รายละเอียดของการตอบ ::


แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-12-10 20:49:55 By : phpinfo()
 


 

No. 7



โพสกระทู้ ( 74,058 )
บทความ ( 838 )

สมาชิกที่ใส่เสื้อไทยครีเอท

สถานะออฟไลน์
Twitter Facebook


แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-12-11 10:05:25 By : mr.win
 

   

ค้นหาข้อมูล


   
 

แสดงความคิดเห็น
Re : สอบถามปัญหาคำสั่ง SQL ของ MySQLI เกี่ยวกับการเกิด Warning: mysqli_fetch_assoc()
 
 
รายละเอียด
 
ตัวหนา ตัวเอียง ตัวขีดเส้นใต้ ตัวมีขีดกลาง| ตัวเรืองแสง ตัวมีเงา ตัวอักษรวิ่ง| จัดย่อหน้าอิสระ จัดย่อหน้าชิดซ้าย จัดย่อหน้ากึ่งกลาง จัดย่อหน้าชิดขวา| เส้นขวาง| ขนาดตัวอักษร แบบตัวอักษร
ใส่แฟลช ใส่รูป ใส่ไฮเปอร์ลิ้งค์ ใส่อีเมล์ ใส่ลิ้งค์ FTP| ใส่แถวของตาราง ใส่คอลัมน์ตาราง| ตัวยก ตัวห้อย ตัวพิมพ์ดีด| ใส่โค้ด ใส่การอ้างถึงคำพูด| ใส่ลีสต์
smiley for :lol: smiley for :ken: smiley for :D smiley for :) smiley for ;) smiley for :eek: smiley for :geek: smiley for :roll: smiley for :erm: smiley for :cool: smiley for :blank: smiley for :idea: smiley for :ehh: smiley for :aargh: smiley for :evil:
Insert PHP Code
Insert ASP Code
Insert VB.NET Code Insert C#.NET Code Insert JavaScript Code Insert C#.NET Code
Insert Java Code
Insert Android Code
Insert Objective-C Code
Insert XML Code
Insert SQL Code
Insert Code
เพื่อความเรียบร้อยของข้อความ ควรจัดรูปแบบให้พอดีกับขนาดของหน้าจอ เพื่อง่ายต่อการอ่านและสบายตา และตรวจสอบภาษาไทยให้ถูกต้อง

อัพโหลดแทรกรูปภาพ

Notice

เพื่อความปลอดภัยของเว็บบอร์ด ไม่อนุญาติให้แทรก แท็ก [img]....[/img] โดยการอัพโหลดไฟล์รูปจากที่อื่น เช่นเว็บไซต์ ฟรีอัพโหลดต่าง ๆ
อัพโหลดแทรกรูปภาพ ให้ใช้บริการอัพโหลดไฟล์ของไทยครีเอท และตัดรูปภาพให้พอดีกับสกรีน เพื่อความโหลดเร็วและไฟล์ไม่ถูกลบทิ้ง

   
  เพื่อความปลอดภัยและการตรวจสอบ กระทู้ที่แทรกไฟล์อัพโหลดไฟล์จากที่อื่น อาจจะถูกลบทิ้ง
 
โดย
อีเมล์
บวกค่าให้ถูก
<= ตัวเลขฮินดูอารบิก เช่น 123 (หรือล็อกอินเข้าระบบสมาชิกเพื่อไม่ต้องกรอก)







Exchange: นำเข้าสินค้าจากจีน, Taobao, เฟอร์นิเจอร์, ของพรีเมี่ยม, ร่ม, ปากกา, power bank, แฟลชไดร์ฟ, กระบอกน้ำ

Load balance : Server 00
ThaiCreate.Com Logo
© www.ThaiCreate.Com. 2003-2024 All Rights Reserved.
ไทยครีเอทบริการ จัดทำดูแลแก้ไข Web Application ทุกรูปแบบ (PHP, .Net Application, VB.Net, C#)
[Conditions Privacy Statement] ติดต่อโฆษณา 081-987-6107 อัตราราคา คลิกที่นี่