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

Registered : 108,358

HOME > PHP > PHP Forum > php ติดปัญหาขึ้น error บรรทัดที่ 21 Fatal error: Uncaught Error: Call to a member function query() on null



 

php ติดปัญหาขึ้น error บรรทัดที่ 21 Fatal error: Uncaught Error: Call to a member function query() on null

 



Topic : 135324



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



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



ผมกำลังติดปัญหาจากการเขียน code php สร้างตารางแสดงข้อมูลจากในฐานข้อมูลครับ

แค่กลับขึ้น error ดังนี้ครับ
Fatal error: Uncaught Error: Call to a member function query() on null in /storage/ssd5/912/11562912/public_html/0000/0000.php:21 Stack trace: #0 {main} thrown in /storage/ssd5/912/11562912/public_html/0000/0000.php on line 21

โดยที่ code ของผมเป็นแบบนี้ครับ
หากมีผู้เชี่ยวชาญคนใดรู้สาเหตุและวิธีแก้รบกวนช่วยบอกผมด้วยนะครับ ขอบคุณครับ

Code (PHP)
<?php 
$conn= mysqli_connect("localhost","0000","0000","0000") or die("Error: " . mysqli_error($con)); 
mysqli_query($conn, "SET NAMES 'utf8' "); 
 $mysqli = null;
   if(isset($_GET["DATE"]))
   {
	   $mysqli = $_GET["DATE"];
   }
   
$i=1;  
$query="SELECT a.*,
(SELECT COUNT(b.DATE) FROM meter b WHERE b.DATE=a.DATE GROUP BY b.DATE) as num,
(SELECT SUM(b.A_K) FROM meter b WHERE b.DATE=a.DATE GROUP BY b.DATE) as avg_A,
(SELECT SUM(b.B_K) FROM meter b WHERE b.DATE=a.DATE GROUP BY b.DATE) as avg_B,
(SELECT SUM(b.C_K) FROM meter b WHERE b.DATE=a.DATE GROUP BY b.DATE) as avg_C,
(SELECT MAX(b.A_W) FROM meter b WHERE b.DATE=a.DATE GROUP BY b.DATE) as max_A,
(SELECT MAX(b.B_W) FROM meter b WHERE b.DATE=a.DATE GROUP BY b.DATE) as max_B,
(SELECT MAX(b.C_W) FROM meter b WHERE b.DATE=a.DATE GROUP BY b.DATE) as max_C
FROM meter a ORDER BY a.DATE ASC
";  
$result = $mysqli->query($query); // ทำการ query คำสั่ง sql   
$total=$result->num_rows;  // นับจำนวนถวที่แสดง ทั้งหมด  
$aggr_arr=array();   
while($row=$result->fetch_array()){ // วนลูปแสดงข้อมูล  
        $dateKey=date("dmY",strtotime($row['DATE']));   
        $row_span=0;
        if(!isset($aggr_arr[$dateKey])){  
            $aggr_arr[$dateKey]=array();  
            $row_span=1;
        }  
?>  
<table width="1300" border="1" cellpadding="10" align="center">
<tr>	<tr><td rowspan="2" align="center">Date Day</td>
		<td colspan="3" align="center">A</td>
        <td colspan="3" align="center">Phase B</td>
        <td colspan="3" align="center">Phase C</td>
        </tr>
		<td align="center">Average</td>
        <td align="center">Maximum</td>
        <td align="center">Load</td>
        <td align="center">Average</td>
        <td align="center">Maximum</td>
        <td align="center">Load</td>
        <td align="center">Average</td>
        <td align="center">Maximum</td>
        <td align="center">Load</td>
        <tr>
        <td rowspan="3" align="center" width="15%"><h1><font size="8"><?=$row['DATE']?></td>
			<td><?=$row['avg_A']?></td>
            <td><?=$row['max_A']?></td>
            <td><h4></td>
			<td><h4><?=$row['avg_B']?></td>
            <td><?=$row['max_B']?></td>
            <td><h4></td>
			<td><?=$row['avg_C']?></td>
            <td><?=$row['max_C']?></td>
            <td><h4></td>
        </tr>
<?php $i++; } ?>              
        </table>




Tag : PHP, MySQL, HTML, Web Hosting, Windows







Move To Hilight (Stock) 
Send To Friend.Bookmark.
Date : 2020-06-22 18:59:21 By : deatinyfrank View : 57 Reply : 7
 

 

No. 1



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



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

ตอน connect ใช้ตัวแปรอะไร ต่อไปก็ใช้อันนั้น
Code (PHP)
$conn= mysqli_connect(...); // ประกาศ $conn


Code (PHP)
$result = $conn->query($query);  // ก็ต้องใช้ $conn


เพิ่งสังเกตว่ามีหลายที่ แก้ไขให้เหมือนกันทั้งหมดครับ








ประวัติการแก้ไข
2020-06-22 19:40:41
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2020-06-22 19:39:20 By : PhrayaDev
 


 

No. 2



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



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

ตอบความคิดเห็นที่ : 1 เขียนโดย : PhrayaDev เมื่อวันที่ 2020-06-22 19:39:20
รายละเอียดของการตอบ ::
ขอบคุณครับ แก้ปัญหาเก่าได้แล้วแต่ปัญหาใหม่ก็เพิ่มมาอีกครับ

Notice: Trying to get property 'num_rows' of non-object in /storage/ssd5/912/11562912/public_html/0000/0000.php on line 22

Fatal error: Uncaught Error: Call to a member function fetch_array() on boolean in /storage/ssd5/912/11562912/public_html/0000/0000.php:24 Stack trace: #0 {main} thrown in /storage/ssd5/912/11562912/public_html/0000/0000.php on line 24




ประวัติการแก้ไข
2020-06-22 20:16:08
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2020-06-22 20:15:42 By : deatinyfrank
 

 

No. 3



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



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

$result ไม่ใช่ mysqli_result object เป็นผลต่อเนื่องจากการคิวรีล้มเหลวในบรรทัดที่ 21
ตรวจสอบคำสั่ง SQL ว่าผิดตรงไหน

Code (PHP)
$query = "....";
$result = $conn->query($query);

if (!$conn->error) {
   printf("Error message: %s\n", $conn->error);
}

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2020-06-22 21:13:54 By : PhrayaDev
 


 

No. 4



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



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

ตอบความคิดเห็นที่ : 3 เขียนโดย : PhrayaDev เมื่อวันที่ 2020-06-22 21:13:54
รายละเอียดของการตอบ ::
ผมแก้ code ให้เป็นแบบนี้แล้ว แต่มันก็ยังขึ้น error อยู่แบบเดิมครับ

Notice: Trying to get property 'num_rows' of non-object in /storage/ssd5/912/11562912/public_html/0000/0000.php on line 19

Fatal error: Uncaught Error: Call to a member function fetch_array() on boolean in /storage/ssd5/912/11562912/public_html/test1/0000/0000.php:21 Stack trace: #0 {main} thrown in /storage/ssd5/912/11562912/public_html/test1/0000/0000.php on line 21

Code (PHP)
<?php 
$conn= mysqli_connect("localhost","0000","0000","0000") or die("Error: " . mysqli_error($con)); 
mysqli_query($conn, "SET NAMES 'utf8' "); 
$i=1;  
$query="SELECT a.*,
(SELECT COUNT(b.DATE) FROM meter b WHERE b.DATE=a.DATE GROUP BY b.DATE) as num,
(SELECT SUM(b.A_K) FROM meter b WHERE b.DATE=a.DATE GROUP BY b.DATE) as avg_A,
(SELECT SUM(b.B_K) FROM meter b WHERE b.DATE=a.DATE GROUP BY b.DATE) as avg_B,
(SELECT SUM(b.C_K) FROM meter b WHERE b.DATE=a.DATE GROUP BY b.DATE) as avg_C,
(SELECT MAX(b.A_W) FROM meter b WHERE b.DATE=a.DATE GROUP BY b.DATE) as max_A,
(SELECT MAX(b.B_W) FROM meter b WHERE b.DATE=a.DATE GROUP BY b.DATE) as max_B,
(SELECT MAX(b.C_W) FROM meter b WHERE b.DATE=a.DATE GROUP BY b.DATE) as max_C
FROM meter a ORDER BY a.DATE ASC
";  
$result = $conn->query($q); // ทำการ query คำสั่ง sql
if (!$conn->error) {
   printf("Error message: %s\n", $conn->error);
}
$total=$result->num_rows;  // นับจำนวนถวที่แสดง ทั้งหมด  
$aggr_arr=array();   
while($row=$result->fetch_array()){ // วนลูปแสดงข้อมูล  
        $dateKey=date("dmY",strtotime($row['DATE']));   
        $row_span=0;
        if(!isset($aggr_arr[$dateKey])){  
            $aggr_arr[$dateKey]=array();  
            $row_span=1;
        }   
?>  
<table width="1300" border="1" cellpadding="10" align="center">
<tr>	<tr><td rowspan="2" align="center">Date Day</td>
		<td colspan="3" align="center">A</td>
        <td colspan="3" align="center">Phase B</td>
        <td colspan="3" align="center">Phase C</td>
        </tr>
		<td align="center">Average</td>
        <td align="center">Maximum</td>
        <td align="center">Load</td>
        <td align="center">Average</td>
        <td align="center">Maximum</td>
        <td align="center">Load</td>
        <td align="center">Average</td>
        <td align="center">Maximum</td>
        <td align="center">Load</td>
        <tr>
        <td rowspan="3" align="center" width="15%"><h1><font size="8"><?=$row['DATE']?></td>
			<td><?=$row['avg_A']?></td>
            <td><?=$row['max_A']?></td>
            <td><h4></td>
			<td><h4><?=$row['avg_B']?></td>
            <td><?=$row['max_B']?></td>
            <td><h4></td>
			<td><?=$row['avg_C']?></td>
            <td><?=$row['max_C']?></td>
            <td><h4></td>
        </tr>
<?php $i++; } ?>              
        </table>


แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2020-06-22 23:43:20 By : deatinyfrank
 


 

No. 5



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



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

ตอบความคิดเห็นที่ : 3 เขียนโดย : PhrayaDev เมื่อวันที่ 2020-06-22 21:13:54
รายละเอียดของการตอบ ::
ตอนนี้ผมแก้เป็นแบบนี้แล้วมันขึ้น error แบบนี้ครับ

Notice: Undefined index: DATE in /storage/ssd5/912/11562912/public_html/test1/0000.php on line 15
Error message:


Code (PHP)
<?php 
$conn= mysqli_connect("localhost","0000","0000","0000") or die("Error: " . mysqli_error($con)); 
mysqli_query($conn, "SET NAMES 'utf8' "); 
$i=1;  
$q="SELECT a.*,
(SELECT COUNT(b.DATE) FROM test1 b WHERE b.DATE=a.DATE GROUP BY b.DATE) as num,
(SELECT SUM(b.M_A_KWH) FROM test1 b WHERE b.DATE=a.DATE GROUP BY b.DATE) as avg_A,
(SELECT SUM(b.M_B_KWH) FROM test1 b WHERE b.DATE=a.DATE GROUP BY b.DATE) as avg_B,
(SELECT SUM(b.M_C_KWH) FROM test1 b WHERE b.DATE=a.DATE GROUP BY b.DATE) as avg_C,
(SELECT MAX(b.M_A_WATT) FROM test1 b WHERE b.DATE=a.DATE GROUP BY b.DATE) as max_A,
(SELECT MAX(b.M_B_WATT) FROM test1 b WHERE b.DATE=a.DATE GROUP BY b.DATE) as max_B,
(SELECT MAX(b.M_C_WATT) FROM test1 b WHERE b.DATE=a.DATE GROUP BY b.DATE) as max_C
FROM test1 a ORDER BY a.DATE ASC
"; 
$DATE=$_GET['DATE'];
$q="select * from test1 where DATE='$DATE'";
$result = $conn->query($q); // ทำการ query คำสั่ง sql
if (!$conn->error) {
   printf("Error message: %s\n", $conn->error);
}
$total=$result->num_rows;  // นับจำนวนถวที่แสดง ทั้งหมด  
$aggr_arr=array();   
while($row=$result->fetch_array()){ // วนลูปแสดงข้อมูล  
        $dateKey=date("dmY",strtotime($row['DATE']));   
        $row_span=0;
        if(!isset($aggr_arr[$dateKey])){  
            $aggr_arr[$dateKey]=array();  
            $row_span=1;
        }   
?>  
<table width="800" border="1" cellpadding="10" align="center">
<tr>	<tr><td rowspan="2" align="center">Date Day</td>
		<td colspan="3" align="center">Phase A</td>
        <td colspan="3" align="center">Phase B</td>
        <td colspan="3" align="center">Phase C</td>
        </tr>
		<td align="center">Average Energy per Day</td>
        <td align="center">Maximun Load per Day</td>
        <td align="center">Load Factor per Day</td>
        <td align="center">Average Energy per Day</td>
        <td align="center">Maximun Load per Day</td>
        <td align="center">Load Factor per Day</td>
        <td align="center">Average Energy per Day</td>
        <td align="center">Maximun Load per Day</td>
        <td align="center">Load Factor per Day</td>
        <tr>
        <td align="center" width="15%"><h1><font size="8"><?=$row['DATE']?></td>
			<td align="center" bgcolor="FFE6E6"><h4><?=$row['avg_A']?></td>
            <td align="center" bgcolor="FFE6E6"><h4><?=$row['max_A']?></td>
            <td align="center" bgcolor="FFE6E6"><h4></td>
			<td align="center" bgcolor="C8FFFF"><h4><?=$row['avg_B']?></td>
            <td align="center" bgcolor="C8FFFF"><h4><?=$row['max_B']?></td>
            <td align="center" bgcolor="C8FFFF"><h4></td>
			<td align="center" bgcolor="FAFAD2"><h4><?=$row['avg_C']?></td>
            <td align="center" bgcolor="FAFAD2"><h4><?=$row['max_C']?></td>
            <td align="center" bgcolor="FAFAD2"><h4></td>
        </tr>
<?php $i++;  }?>              
        </table>


แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2020-06-22 23:59:34 By : deatinyfrank
 


 

No. 6



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



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

ถ้าใช้เงื่อนไขแบบนี้มีรายละเอียดของ Error message: ไหมครับ

Code (PHP)
$query = "...";
$result = $conn->query($query);

if (!$result) {
   printf("Error message: %s\n", $conn->error);
}


หรือ

Code (PHP)
$query = "...";

if (!($result = $conn->query($query))) {
   printf("Error message: %s\n", $conn->error);
}



ส่วน Notice: Undefined index อ่านบทความนี้ครับ
https://www.thaicreate.com/community/notice-undefined-index.html
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2020-06-23 03:42:34 By : PhrayaDev
 


 

No. 7



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



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


พื้นฐานหลังการคิวรี่
Code (PHP)
<?php
$sql='select ....';
$rs=$con->query($sql);
if ($con->errno>0){
  die($con->error.'<br>'.$sql);
}
if($rs->num_row<1){
  die('result is empty');
}
while( $ro = $rs->fetch_object()){
   ....
}


แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2020-06-23 14:11:15 By : Chaidhanan
 

   

ค้นหาข้อมูล


   
 

แสดงความคิดเห็น
Re : php ติดปัญหาขึ้น error บรรทัดที่ 21 Fatal error: Uncaught Error: Call to a member function query() on null
 
 
รายละเอียด
 
ตัวหนา ตัวเอียง ตัวขีดเส้นใต้ ตัวมีขีดกลาง| ตัวเรืองแสง ตัวมีเงา ตัวอักษรวิ่ง| จัดย่อหน้าอิสระ จัดย่อหน้าชิดซ้าย จัดย่อหน้ากึ่งกลาง จัดย่อหน้าชิดขวา| เส้นขวาง| ขนาดตัวอักษร แบบตัวอักษร
ใส่แฟลช ใส่รูป ใส่ไฮเปอร์ลิ้งค์ ใส่อีเมล์ ใส่ลิ้งค์ 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: Voake, Comcube, รับทำเว็บไซต์ รับเขียนโปรแกรม , รับทำบัญชี , โรงงานผลิตครีม , สำนักงานบัญชี , รับจดทะเบียนบริษัท , Pangpond , รถมือสอง

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