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 > รบกวนช่วยดู code การเรียกฐานข้อมูล สองฐานข้อมูล เพื่อมา check เงื่อนไขทีครับ



 

รบกวนช่วยดู code การเรียกฐานข้อมูล สองฐานข้อมูล เพื่อมา check เงื่อนไขทีครับ

 



Topic : 060542

Guest




Code (PHP)
<?
include('../config.inc.php');

$sql="select * from cp_topics where id";
$dbquery=mysql_db_query($dbname,$sql);
$row=mysql_num_rows($dbquery);

$sql2="select * from cp_topics_sub where id";
$dbquery2=mysql_db_query($dbname,$sql2);
$row2=mysql_num_rows($dbquery2);
?>


ข้างบนคือ code การเรียกใช้

ส่วนข้างล่างนี้คือ code แสดงผลครับ

Code (PHP)
<?
for($i=1;$i<=$row;$i++){
$result=mysql_fetch_array($dbquery); //เรียกค่าแรกมา check
for($j=1;$j<=$row2;$j++) {
	$result2=mysql_fetch_array($dbquery2); //เรียกค่าที่ 2 มา check
	if($result2['topic_check']==$result['topic_name']) {  // ค่าแรกกับค่าสองตรงกันทำข้างล่าง
?>
<table id="box-table-a">
  <thead>
		<tr>
			<th scope="col">:: <?=$result['topic_name']; ?> ::</th>
			<th scope="col"></th>
			<th scope="col"></th>
		</tr>
    	<tr>
            <td class="test">ฟอรั่ม</td>
            <td class="test">เวลา</td>
            <td class="test">ผู้โพส</td>
 
        </tr>
    </thead>
    <tbody>
    	<tr>
        	<td>:: <?=$result2['topic_name'];?> ::</div><br><div><?=$result2['topic_detail'];?></td>
            <td><?=$result2['topic_date'];?></td>
            <td><?=$result2['topic_check'];?></td>
        </tr>
    </tbody>
</table>
<?}
echo $result['topic_name']."a ".$result2['topic_check']."b<br>"; //a หมายถึง มาจาก topic_name ส่วน b คือ มาจาก topic_check
}
}?>


ซึ่งในฐานข้อมูล cp_topics มีข้อมูลสองแถว ในฟิว topic_name = test และ test2 ตามลำดับ
ส่วน cp_topics_sub มีข้อมูลสองแถวเช่นกัน ในฟิว topic_check = test และ test2 ตามลำดับ

ผลลัพธ์ของโค้ดที่ได้เป็นแบบนี้ครับ

ทำตามเงื่อนไข 1 ครั้ง นอกนั้นไม่เข้าครับ echo ค่า ออกมาได้ดังนี้

testa testb
testa test2b
test2a b
test2a b

testa testb //ครั้งแรกนำมาเทียบกันได้ ทำให้เข้าเงื่อนไข 1 ครั้งตามที่คาดไว้
testa test2b //เทียบกันแล้วค่าไม่ตรงกัน ไม่เข้าเงื่อนไข เป็นไปตามทางที่ถูกต้องอยู่ครับ

แต่ปัญหาอยู่ตรงนี้ครับ เมื่อลูปรอบแรกเสร็จเรียบร้อยก็จะกลับไป for แรกอีกครั้ง ปัญหาคือ

for($j=1;$j<=$row2;$j++) {
$result2=mysql_fetch_array($dbquery2);

โค้ดตรงนี้ไม่รับค่ามาจากฐานข้อมูลในการลูปรอบสองครับ

ทำให้ผลลัพธ์ออกมาแบบนี้
test2a b // ตรง b ซึ่งเป็น topic_check ตามหลักต้องแสดงค่า testb
test2a b // และตรงนี้ก็จะต้องแสดงค่า test2b ซึ่งจะทำให้ค่าตรงกันและเข้าเงื่อนไข if อีกครั้ง

อยากให้ช่วยดูทีครับว่าผมทำผิดอะไรตรงไหนทำไมค่าถึงไม่มาในการลูปครั้งที่ 2

ขอขอบคุณมาก่อน ณ ที่นี้ด้วยครับ ขอบคุณครับ



Tag : PHP







Move To Hilight (Stock) 
Send To Friend.Bookmark.
Date : 2011-05-23 01:11:30 By : เอส View : 1036 Reply : 4
 

 

No. 1



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

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

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

คุณจะต้องแทรก Query ใน Loop อันแรกน่ะครับ






แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2011-05-23 15:20:19 By : webmaster
 


 

No. 2

Guest


ได้แล้วครับ ขอบคุณมากมากครับ พี่วิน ผมอ่านบทความพี่หลายอันมาก ได้ความรู้เยอะเลยครับ ขอบคุณมากมากครับ

พี่สุโค่ยมักๆ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2011-05-23 18:39:23 By : เอส
 

 

No. 3

Guest


กรรมครับไม่ได้สังเกตุดีดี คือว่า ยังไงผมก็ต้องการให้มันแสดงหลัง Loop สอง ให้ได้อ่ะครับ

งั้นผลที่ได้จะไม่ได้ตามที่ผมต้องการอ่ะครับ

testa testb
testa test2b
test2a b
test2a b

ตรงนี้อ่ะครับ ถ้าทำไปไว้ใน Loop แรกมันจะไม่ได้ตามที่ผมต้องการ คือมันจะ check เทียบรอบสองไม่ได้ ที่ผมต้องการคือทำให้

test2a b
test2a b กลายเป็น

test2a testb
test2a test2b ให้ได้

คือยังไงก็ต้องให้มันแสดง Query ใน Loop สอง อ่ะครับ ไม่มีวิธีเหรอครับ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2011-05-23 19:12:03 By : เอส
 


 

No. 4



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



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

ทำได้แล้วยังคะ ขอดูหน่อยอ่า
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2012-02-09 11:36:37 By : sunnyonto
 

   

ค้นหาข้อมูล


   
 

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