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 > ช่วยหน่อยครับ ต้องการใส่ค่า session[] ไว้ใน NOT IN ทำยังได้บ้างครับ



 

ช่วยหน่อยครับ ต้องการใส่ค่า session[] ไว้ใน NOT IN ทำยังได้บ้างครับ

 



Topic : 084041



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



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




คือต้องการ ใส่ค่าของ $_SESSION["strProductID"] ที่ถูกเก็บเป็น array ไปใส่ใน NOT IN แล้วมี คอมม่า "," ด้วยครับ

การทำงานก็คือ เมื่อเลือก order แล้ว ให้ส่งค่า ProductID ไปใน NOT IN เพื่อให้ตารางไม่แสดง สินค้าที่เลือกไปแล้วนะครับ

รบกวนท่านผู้รู้ช่วยแนะนำด้วยว่าจะต้องเขียนโค๊ดเพิ่มเติม ยังไงครับ ต้องใช้ explode() หรือเปล่าครับ แต่ใช้ไม่เป็นอะครับ

ขอบคุณล่วงหน้านะครับ

Product.php
<?
session_start();
?>
<html>
<head>
<title>Product</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<style type="text/css">
body,td {	font-family: Tahoma;	font-size: 12px;}
</style>
</head>
<?
mysql_connect("localhost","root","1234");
mysql_select_db("dbmy");

$strSQL = "SELECT bank.*,product.* FROM bank,product WHERE bank.BankID= product.BankID and product.ProductID NOT IN ( จะใส่ค่าในนี้ )"; // <-------  ต้องการใส่ค่าในวงเว็บครับ เช่น 101,012,103 เป็นต้น
$objQuery = mysql_query($strSQL)  or die(mysql_error());
 
?>
<table width="904"  border="1" cellpadding="5" cellspacing="0">
  <tr>
    <td width="64"><strong>ProductID</strong></td>
    <td width="289"><strong>ชื่อสินค้า</strong></td>
    <td width="153"><strong>ประเภท</strong></td>
    <td width="113"><strong>ธนาคาร</strong></td>
    <td width="76"><strong>เลือก</strong></td>
  </tr>
  <?
  while($objResult = mysql_fetch_array($objQuery))
  {
  ?>
  <tr>
	<td><?=$objResult["ProductID"];?></td>
    <td><?=$objResult["ProductName"];?></td>
    <td><?=$objResult["Type"];?></td>
    <td><?=$objResult["BankName"];?></td>
    <td><a href="order.php?ProductID=<?=$objResult["ProductID"];?>">Order</a></td>
  </tr>
  <?
  }
  ?>
</table>


order.php
<?
ob_start();
session_start();
	
if(!isset($_SESSION["intLine"])) // ถ้า $_SESSION["intLine"] ยังไม่ถูกประกาศค่าตัวแปร ทำตรงนี้ก่อน
{

	 $_SESSION["intLine"] = 0; 
	 $_SESSION["strProductID"][0] = $_GET["ProductID"];  
         $_GET["ProductID"]

	 header("location:product.php");
} else {
	
	$key = array_search($_GET["ProductID"], $_SESSION["strProductID"]);   
	if((string)$key != "") 			
	{
		
	}
	else
	{
		
		 $_SESSION["intLine"] = $_SESSION["intLine"] + 1;
		 $intNewLine = $_SESSION["intLine"];
		 $_SESSION["strProductID"][$intNewLine] = $_GET["ProductID"];
		
	}
	
	 header("location:product.php");

}
?>




Tag : PHP, MySQL









ประวัติการแก้ไข
2012-09-15 13:24:53
2012-09-15 13:25:48
2012-09-15 13:27:18
2012-09-15 13:30:02
Move To Hilight (Stock) 
Send To Friend.Bookmark.
Date : 2012-09-15 13:24:11 By : vinaish View : 1081 Reply : 6
 

 

No. 1



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

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

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

$_SESSION["strProductID"] เป็น array จริงๆหรอครับ (ซึ่งผมคิดว่าคุณไม่ได้เก็บเป็น array แน่ๆ)
หรือแค่เก็บเป็นแบบนี้ 101,102,103
แต่ถ้าเก็บเป็น type array จริงๆให้ลองแบบนี้
Code (PHP)
$strSQL = "SELECT bank.*,product.* FROM bank,product WHERE bank.BankID= product.BankID and product.ProductID NOT IN (".implode($_SESSION["strProductID"]).")";

ถ้าไม่ใช่ array แต่ เก็บเป็นแบบนี้ 101,102,103 ลองแบบนี้
Code (PHP)
$strSQL = "SELECT bank.*,product.* FROM bank,product WHERE bank.BankID= product.BankID and product.ProductID NOT IN (".$_SESSION["strProductID"].")";









ประวัติการแก้ไข
2012-09-15 13:45:11
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2012-09-15 13:44:18 By : mangkunzo
 


 

No. 2



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



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


ยังไม่ได้อะครับ ลอง echo มามันได้ค่า แบบนี้ 101103102104105109110111113112 แต่ต้องการ ให้มีคอมม่าด้วยอะครับ

ไม่ทราบว่าผิดตรงไหน ครับ

Code (PHP)
for($i=0;$i<=(int)$_SESSION["intLine"];$i++)
  {
   $arr = array($_SESSION["strProductID"][$i]);
   $a = implode(",",$arr) ;
   echo $a;
}

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2012-09-15 14:06:30 By : vinaish
 

 

No. 3



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

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

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

ตอบความคิดเห็นที่ : 2 เขียนโดย : vinaish เมื่อวันที่ 2012-09-15 14:06:30
รายละเอียดของการตอบ ::
ลอง echo มามันได้ค่า แบบนี้ 101103102104105109110111113112
หมายถึง echo ตัวไหน $_SESSION["intLine"] หรือ $_SESSION["strProductID"] งงครับ



แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2012-09-15 14:55:11 By : mangkunzo
 


 

No. 4



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



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


$_SESSION["strProductID"][$i] <-- ตัวนี้ครับ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2012-09-15 16:08:26 By : vinaish
 


 

No. 5



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

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

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

ตอบความคิดเห็นที่ : 4 เขียนโดย : vinaish เมื่อวันที่ 2012-09-15 16:08:26
รายละเอียดของการตอบ ::
แสดงว่าเก็บผิดแล้วครับ

คุณต้องปรับ code ตอนเก็บ session ใหม่ ให้มันมี , คั่นระหว่าง id แต่ละตัว เพื่อให้เวลาเอาไปใช้งานสามารถ echo แล้วได้ค่า 101,102,103 เอาไปใช้งานได้เลย

Ex.

$_SESSION['mySess'] = "101,";
$_SESSION['mySess'] .= "102,";
$_SESSION['mySess'] .= "103,";
$_SESSION['mySess'] .= "104";

echo $_SESSION['mySess']; // จะได้ 101,102,103,104


แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2012-09-15 16:33:53 By : mangkunzo
 


 

No. 6



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



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


จะลองดูนะครับ ขอบคุณสำหรับคำแนะนำครับ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2012-09-15 17:48:00 By : vinaish
 

   

ค้นหาข้อมูล


   
 

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