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,037

HOME > PHP > PHP Forum > จะเอาค่าจากตารางที่สร้างไว้มาใส่ในตารางที่แสดงผล...อยากเอาค่าจากตาราง geography มาแทนในฟิลด์ รายการตามบัญชีความเสี่ยง



 

จะเอาค่าจากตารางที่สร้างไว้มาใส่ในตารางที่แสดงผล...อยากเอาค่าจากตาราง geography มาแทนในฟิลด์ รายการตามบัญชีความเสี่ยง

 



Topic : 072249



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



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




แสดงรายงานออกมา ดังนี้

select_report

ตาราง"data_insert"

data_insert

ตาราง "geography"

db

แต่ปัญหา คือ อยากเอาค่าจากตาราง geography มาแทนในฟิลด์ รายการตามบัญชีความเสี่ยง ให้แปลงจากตัวเลข เป็นความหมายแทนครับรบกวนช่วยทีครับ

Code (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>
<style type="text/css">
<!--
body {
	background-color: #FFFFFF;
	background-image: url();	
}
.style22 {color: #FFFFFF}
-->
</style>
</head>

<body>


<?php
			
			//echo "?? ";
			$hostname = "localhost"; //?
			$user = "root"; //?
			$password = "root"; //??
			$dbname = "risk"; //??
			$tblname = "data_insert"; //??
			
			
			
			
                 $sql ="SELECT * FROM data_insert
				        GROUP BY GEO_NAME ";
            
			
			
			    
                    
			
			
			mysql_connect($hostname, $user, $password) or die("cannot connect");
			// เลือก database
			mysql_select_db($dbname) or die("cannot select db");
			
			// ทำให้ อ่านภาษาไทยได้ใน utf8 
			mysql_query("SET NAMES utf8");
			
			//***เอาค่าจากตาราง type_post มาใส่แทนฟิลด์ type_pos ของตาราง data
			
			
		
		
				
						


			
			
		                 
	$sqlquery=mysql_db_query($dbname, $sql); 
	
	
	
	//print "มีข้อมูลทั้งหมด ".mysql_num_rows($sqlquery)." รายการ <br><br><br>";
	print"<font size=2><center>สรุปความเสี่ยง</center><br></font> ";
	print "<font size=2><center>ปี</center></font><br><br>";
	
	
	
	 
	 
	 
	print "<table width=700 align=center border=1  cellpadding=0 cellspacing=0 bgcolor=000000>";
			print "<tr bgcolor=0066FF>";
			
			    print "<td align = center><font color=ffffff size=2>ลำดับ</font></td>";
			    print "<td align = center><font color=ffffff size=2>รายการตามบัญชีความเสี่ยง</font></td>";
				
				
				
				print "<td align = center><font color=ffffff size=2>ม.ค.</font></td>";
				print "<td align = center><font color=ffffff size=2>ก.พ.</font></td>";
				print "<td align = center><font color=ffffff size=2>มี.ค.</font></td>";
				
				
			print "</tr>";
			
			
			
			
			$id=1;
			
			
	
			while ($row = mysql_fetch_array($sqlquery)) 
			{		
			

			print "<tr bgcolor=FFF8dc  border=1 bordercolor=000000>";
			    print "<td align = center width=1%><font size=2>".$id."</font></td>";
			
		
				
				print  "<td width=29%><font size=2> ".$row['GEO_NAME']."</font> </td>";
						
						
					
						
						
						
						
						// มกราคม
						$sql_sub = "SELECT*, COUNT(GEO_NAME) AS cnt_GEO_NAME
						            FROM data_insert
									where GEO_NAME=".$row['GEO_NAME']." and year= '".$year."' and month='มกราคม'
                                    GROUP BY GEO_NAME";
						$res_sub = mysql_query($sql_sub);
						$rec_sub = mysql_fetch_array($res_sub);
						
						
                          if($rec_sub['cnt_GEO_NAME']!='')
{
				print  "<td align= center width=8%><font size=2>".$rec_sub['cnt_GEO_NAME']."</font> </td>";
				}
                     else{	print "<td align = center width=8%><font size=2>0</font></td>";}
					 
					 
					 // กุมภาพันธ์
						$sql_sub = "SELECT*, COUNT(GEO_NAME) AS cnt_GEO_NAME
						            FROM data_insert
									where GEO_NAME=".$row['GEO_NAME']." and year= '".$year."' and month='กุมภาพันธ์'
                                    GROUP BY GEO_NAME";
						$res_sub = mysql_query($sql_sub);
						$rec_sub = mysql_fetch_array($res_sub);
						
						
                          if($rec_sub['cnt_GEO_NAME']!='')
{
				print  "<td align= center width=8%><font size=2>".$rec_sub['cnt_GEO_NAME']."</font> </td>";
				}
                     else{	print "<td align = center width=8%><font size=2>0</font></td>";}
					
					 
						
			// มีนาคม
						$sql_sub = "SELECT*, COUNT(GEO_NAME) AS cnt_GEO_NAME
						            FROM data_insert
									where GEO_NAME=".$row['GEO_NAME']." and year= '".$year."' and month='มีนาคม'
                                    GROUP BY GEO_NAME";
						$res_sub = mysql_query($sql_sub);
						$rec_sub = mysql_fetch_array($res_sub);
						
						
                          if($rec_sub['cnt_GEO_NAME']!='')
{
				print  "<td align= center width=8%><font size=2>".$rec_sub['cnt_GEO_NAME']."</font> </td>";
				}
                     else{	print "<td align = center width=8%><font size=2>0</font></td>";}
			
			
			
			
			
			print "</tr>";  
			
			
			$id++;
			 
			 
			 
			 }
			 
			 
			 
			 print"</table><br><br>";
			
	mysql_close();
		
	
	
?>  
	
			



  </tr>
  	

  <span class="style22"></span>
</body>

</html>





Tag : PHP, MySQL









ประวัติการแก้ไข
2012-01-24 10:57:58
Move To Hilight (Stock) 
Send To Friend.Bookmark.
Date : 2012-01-19 10:27:26 By : au_mutd View : 3987 Reply : 11
 

 

No. 1



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

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

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

SQL JOIN ครับ ช่วยคุณได้ครับ ลองดู LEFT JOIN ครับ

Go to : SQL LEFT JOIN






แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2012-01-19 14:07:09 By : webmaster
 


 

No. 2



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



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


พี่ช่วยดูหน่อยครับ มัน error

Code (PHP)
$sql ="SELECT data_insert.*, geography.* 
FROM data_insert
LEFT JOIN geography on data_insert.GEO_NAME=geography.GEO_NAME
GROUP BY data_insert.GEO_NAME ";



ประวัติการแก้ไข
2012-01-24 11:00:33
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2012-01-19 15:58:14 By : au_mutd
 

 

No. 3



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



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


Code (PHP)
$sql = "SELECT *
FROM data_insert d, geography g
WHERE d.GRO_NAME='g.GEO_NAME'
GROUP BY GEO_NAME";



ประวัติการแก้ไข
2012-01-23 14:15:29
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2012-01-19 16:15:39 By : 50121680
 


 

No. 4



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



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


ขึ้นแบบนี้อะครับ

Code
Warning: mysql_fetch_array(): supplied argument is not a valid MySQL result resource in C:\AppServ\www\listmenu\select_report.php on line 100

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2012-01-20 09:01:30 By : au_mutd
 


 

No. 5



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



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


ลอง echo โค้ด sql ออกมาแล้วเอาไปรันใน phpMyAdmin ดูว่า error จากอะไรครับ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2012-01-23 11:05:22 By : amuropao08
 


 

No. 6



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



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


Code
SELECT *
FROM data_insert d, geography g
WHERE d.GEO_NAME=g.GEO_NAME
GROUP BY GEO_NAME


MySQL แสดง:
#1267 - Illegal mix of collations (utf8_general_ci,IMPLICIT) and (utf8_unicode_ci,IMPLICIT) for operation '='

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2012-01-23 11:19:58 By : au_mutd
 


 

No. 7



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



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


ใช้ = ไม่ได้ ลองใช้ LIKE ดูครับ

Code (PHP)
WHERE d.GEO_NAME='g.GEO_NAME'

WHERE d.GEO_NAME LIKE 'g.GEO_NAME'


ปล. เวลาใช้ = หรือ LIKE อย่าลืมใช้ เครื่องหมาย ' ' (single quote)คร่อมนะครับ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2012-01-23 14:15:13 By : 50121680
 


 

No. 8



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



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


ไม่ error ครับ แต่ไม่มีข้อมูลปรากฎเลย



Code (PHP)
                                                $sql ="SELECT *
						FROM data_insert d, geography g
						WHERE d.GEO_NAME LIKE 'g.GEO_NAME'
						GROUP BY g.GEO_NAME";



ประวัติการแก้ไข
2012-01-23 15:21:12
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2012-01-23 15:20:28 By : au_mutd
 


 

No. 9



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



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


ต้องเปรียบเทียบจาก id ครับ ไม่ใช่ข้อความ
เพราะใน data_insert คุณเก็บค่าบัญชีความเสี่ยงเป็นตัวเลข
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2012-01-24 07:41:05 By : amuropao08
 


 

No. 10



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



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


ตอบความคิดเห็นที่ : 6 เขียนโดย : au_mutd เมื่อวันที่ 2012-01-23 11:19:58
รายละเอียดของการตอบ ::

error --> #1267 - Illegal mix of collations (utf8_general_ci,IMPLICIT) and (utf8_unicode_ci,IMPLICIT) for operation '='

เอา code กลับมาให้เกิด error นี้ก่อน แล้วให้คุณไปแก้ Collation ของ table และ field ทั้งหมดที่มา left join กัน ให้ตรงก่อน(ให้เหมือนกันทั้ง database)
คือ ถ้าเป็น utf8_general_ci ก็ให้ใช้ collation นี้ทั้ง database หรือ utf8_unicode_ci ทั้ง database เลือกอย่างใดอย่างหนึ่ง ไม่อย่างนั้นมันจะ implicit กันครับ



ประวัติการแก้ไข
2012-02-13 23:42:21
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2012-02-13 23:41:05 By : Guriko10
 


 

No. 11

Guest


ช่วยด้วยคะเจอ error แบบนี้ใน Joomla ไปไม่เป็นเลยคะ


Error
Illegal mix of collations (utf8_general_ci,IMPLICIT) and (utf8_unicode_ci,IMPLICIT) for operation '=' SQL=SELECT a.id, a.title, a.note, a.position, a.module, a.language,a.checked_out, a.checked_out_time, a.published as published, e.enabled as enabled, a.access, a.ordering, a.publish_up, a.publish_down,l.title AS language_title, l.image AS language_image,uc.name AS editor,ag.title AS access_level,MIN(mm.menuid) AS pages,e.name AS name FROM `#__modules` AS a LEFT JOIN `#__languages` AS l ON l.lang_code = a.language LEFT JOIN #__users AS uc ON uc.id=a.checked_out LEFT JOIN #__viewlevels AS ag ON ag.id = a.access LEFT JOIN #__modules_menu AS mm ON mm.moduleid = a.id LEFT JOIN #__extensions AS e ON e.element = a.module WHERE (a.published IN (0, 1)) AND a.client_id = 0 AND e.client_id =0 GROUP BY a.id, a.title, a.note, a.position, a.module, a.language,a.checked_out,a.checked_out_time, a.published, a.access, a.ordering, l.title, l.image, uc.name, ag.title, e.name,l.lang_code, uc.id, ag.id, mm.moduleid, e.element, a.publish_up, a.publish_down,e.enabled Illegal mix of collations (utf8_general_ci,IMPLICIT) and (utf8_unicode_ci,IMPLICIT) for operation '=' SQL=SELECT a.id, a.title, a.note, a.position, a.module, a.language,a.checked_out, a.checked_out_time, a.published as published, e.enabled as enabled, a.access, a.ordering, a.publish_up, a.publish_down,l.title AS language_title, l.image AS language_image,uc.name AS editor,ag.title AS access_level,MIN(mm.menuid) AS pages,e.name AS name FROM `#__modules` AS a LEFT JOIN `#__languages` AS l ON l.lang_code = a.language LEFT JOIN #__users AS uc ON uc.id=a.checked_out LEFT JOIN #__viewlevels AS ag ON ag.id = a.access LEFT JOIN #__modules_menu AS mm ON mm.moduleid = a.id LEFT JOIN #__extensions AS e ON e.element = a.module WHERE (a.published IN (0, 1)) AND a.client_id = 0 AND e.client_id =0 GROUP BY a.id, a.title, a.note, a.position, a.module, a.language,a.checked_out,a.checked_out_time, a.published, a.access, a.ordering, l.title, l.image, uc.name, ag.title, e.name,l.lang_code, uc.id, ag.id, mm.moduleid, e.element, a.publish_up, a.publish_down,e.enabled ORDER BY `position` asc,a.ordering ASC LIMIT 0, 20 Illegal mix of collations (utf8_general_ci,IMPLICIT) and (utf8_unicode_ci,IMPLICIT) for operation '=' SQL=SELECT a.id, a.title, a.note, a.position, a.module, a.language,a.checked_out, a.checked_out_time, a.published as published, e.enabled as enabled, a.access, a.ordering, a.publish_up, a.publish_down,l.title AS language_title, l.image AS language_image,uc.name AS editor,ag.title AS access_level,MIN(mm.menuid) AS pages,e.name AS name FROM `#__modules` AS a LEFT JOIN `#__languages` AS l ON l.lang_code = a.language LEFT JOIN #__users AS uc ON uc.id=a.checked_out LEFT JOIN #__viewlevels AS ag ON ag.id = a.access LEFT JOIN #__modules_menu AS mm ON mm.moduleid = a.id LEFT JOIN #__extensions AS e ON e.element = a.module WHERE (a.published IN (0, 1)) AND a.client_id = 0 AND e.client_id =0 GROUP BY a.id, a.title, a.note, a.position, a.module, a.language,a.checked_out,a.checked_out_time, a.published, a.access, a.ordering, l.title, l.image, uc.name, ag.title, e.name,l.lang_code, uc.id, ag.id, mm.moduleid, e.element, a.publish_up, a.publish_down,e.enabled ORDER BY `position` asc,a.ordering ASC

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2016-06-15 11:09:38 By : อ้อย
 

   

ค้นหาข้อมูล


   
 

แสดงความคิดเห็น
Re : จะเอาค่าจากตารางที่สร้างไว้มาใส่ในตารางที่แสดงผล...อยากเอาค่าจากตาราง geography มาแทนในฟิลด์ รายการตามบัญชีความเสี่ยง
 
 
รายละเอียด
 
ตัวหนา ตัวเอียง ตัวขีดเส้นใต้ ตัวมีขีดกลาง| ตัวเรืองแสง ตัวมีเงา ตัวอักษรวิ่ง| จัดย่อหน้าอิสระ จัดย่อหน้าชิดซ้าย จัดย่อหน้ากึ่งกลาง จัดย่อหน้าชิดขวา| เส้นขวาง| ขนาดตัวอักษร แบบตัวอักษร
ใส่แฟลช ใส่รูป ใส่ไฮเปอร์ลิ้งค์ ใส่อีเมล์ ใส่ลิ้งค์ 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 03
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 อัตราราคา คลิกที่นี่