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 > ดึงข้อมูลจาก database ข้อมูลที่เป็นแบบนี้ 1,2,4 แล้วต้องการแยกการแสดงผลและนับจำนวน ต้องทำยังไงครับ



 

ดึงข้อมูลจาก database ข้อมูลที่เป็นแบบนี้ 1,2,4 แล้วต้องการแยกการแสดงผลและนับจำนวน ต้องทำยังไงครับ

 



Topic : 135642



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



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




สวัสดีครับ มือใหม่ครับ ขอคำแนะนำเรื่องการดึงข้อมูลมาแสดงผลหน่อยครับ
ตามรูปนี้นะครับ
ตาราง

ต้องการให้มันแยกการแสดงผล ads ออกมาและรวมผลด้วย ต้องเขียนทำยังไงครับ
คิดว่าน่าจะเคยมีหลายท่านถามเคสแบบนี้แล้ว
ต้องขอโทษด้วย แต่ผมไม่รู้ว่ามันจะใช้คีย์เวิดในการเสิชว่าอะไรดี
พยายามเสิชหาก็ไม่เจอ

ถ้าพอมีตัวอย่างให้ link ให้ศึกษา ก็ได้ครับ
ขอบคุณครับ



Tag : PHP, MySQL







Move To Hilight (Stock) 
Send To Friend.Bookmark.
Date : 2020-10-19 14:03:12 By : newbie24 View : 872 Reply : 5
 

 

No. 1



โพสกระทู้ ( 4,169 )
บทความ ( 7 )

Hall of Fame 2012

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


Example
$cars = array(
    array(
        "name"=>"Urus", 
        "record"=>"10,12", 
    ),
    array(
        "name"=>"Cayenne", 
        "record"=>"10,15", 
    ),
);

$price = array(
	10 => 1000,
	12 => 1200,
	15 => 1500,
);

for($i=0;$i<count($cars);$i++){
	echo $cars[$i]['name']."<br>";
	$exps = explode(',',$cars[$i]['record']);
	$total = 0;	
	foreach($exps as $exp){
		echo $exp."=".$price[$exp]."<br>";
		$total += $price[$exp];
	}
	echo "total =".$total."<br>";
}


อ่าน Code ทำความเข้าใจแล้วนำไป Dev กับ mysqli








ประวัติการแก้ไข
2020-10-19 14:44:39
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2020-10-19 14:42:00 By : Genesis™
 


 

No. 2



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



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

วิธีคิวรี่เพื่อได้เลขเรียงด้านหน้า
https://stackoverflow.com/questions/58929877/mysql-split-comma-separated-values-and-group-by-result

วิธีนับจำนวน เปลี่ยน - เป็น ฟิลด์ที่ได้จากด้านบน
https://stackoverflow.com/questions/7020001/how-to-count-items-in-comma-separated-list-mysql


Code (SQL)

SELECT  
	result, 
	LENGTH(GROUP_CONCAT(file_path)) - LENGTH(REPLACE(GROUP_CONCAT(file_path), result, '')) AS qty
FROM  (
        SELECT  
		  		SUBSTRING_INDEX(SUBSTRING_INDEX(file_path, ',', a.letter + 1), ',', -1) result,
	        file_path
        FROM  book
            INNER JOIN (SELECT 0 letter UNION ALL SELECT 1 UNION ALL SELECT 2 UNION ALL SELECT 3) a ON LENGTH(REPLACE(file_path, ',' , '')) <= LENGTH(file_path) - a.letter
) a
GROUP BY result
HAVING COUNT(result) > 0 AND result <> ''
ORDER BY result

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2020-10-20 09:15:09 By : {Cyberman}
 

 

No. 3



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



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


ถ้ามีตัวอย่างข้อมูล table structure, data ก็เอามาลง จะได้มีคนเอาไปทดลองเขียนหาวิธีแสดง
อย่ามาแต่ภาพ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2020-10-20 11:43:52 By : mr.v
 


 

No. 4



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



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

No.2 สอนดื่มไวด์ (Widenius' Solutions)
มี 2 ขั้นตอนสำคัญ Step 1 - แจงตารางให้ได้แบบนี้ Step1 Step 2 - GROUP BY


ดูสด http://sqlfiddle.com/#!9/9beff9/1


No.1 สอนการเลอร์ (Lerdorf' school)
ง่ายเพราะเป็นการแก้ปัญหาในระดับโปรแกรม (App Level Solution)


ต้องการความท้าทาย ต้องกินสตอร์ (Stored Procedure)
Code (SQL)
CREATE TABLE table1
    (`id` int, `value` varchar(20))
;
    
INSERT INTO table1
    (`id`, `value`)
VALUES
    (1, 'Red,Green,Blue'),
    (2, 'Orangered,Periwinkle'),
    (3, 'Green,Blue,Orangered'),
    (4, 'Red,Blue')
;

DELIMITER $$

DROP PROCEDURE IF EXISTS explode_table $$
CREATE PROCEDURE explode_table(bound VARCHAR(255))

BEGIN

DECLARE id INT DEFAULT 0;
DECLARE value TEXT;
DECLARE occurance INT DEFAULT 0;
DECLARE i INT DEFAULT 0;
DECLARE splitted_value TEXT;
DECLARE done INT DEFAULT 0;
DECLARE cur1 CURSOR FOR SELECT table1.id, table1.value
                                     FROM table1
                                     WHERE table1.value != '';
DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = 1;

DROP TEMPORARY TABLE IF EXISTS table2;
CREATE TEMPORARY TABLE table2(
`id` INT NOT NULL,
`value` VARCHAR(255) NOT NULL
) ENGINE=Memory;

OPEN cur1;
  read_loop: LOOP
    FETCH cur1 INTO id, value;
    IF done THEN
      LEAVE read_loop;
    END IF;

    SET occurance = (SELECT LENGTH(value)
                             - LENGTH(REPLACE(value, bound, ''))
                             +1);
    SET i=1;
    WHILE i <= occurance DO
      SET splitted_value =
      (SELECT REPLACE(SUBSTRING(SUBSTRING_INDEX(value, bound, i),
      LENGTH(SUBSTRING_INDEX(value, bound, i - 1)) + 1), ',', ''));

      INSERT INTO table2 VALUES (id, splitted_value);
      SET i = i + 1;

    END WHILE;
  END LOOP;

  SELECT t.value `สี`, COUNT(t.value) `จำนวน` FROM (SELECT * FROM table2) t GROUP BY t.value;
 CLOSE cur1;
END; $$

-- เวลาเรียกใช้             
CALL explode_table(',');


ดูสด



สีเขียว คือ keyword นอกนั้นไม่ใช่ เพราะผมตั้งเอง
https://www.mysqltutorial.org/mysql-stored-procedure-tutorial.aspx/
ถ้าชอบกินสตอร์ ค่อยๆ ศึกษาไป (อย่างน้อยให้ถึงเรื่อง Cursor...แล้วชีวิตจะง่ายขึ้น )
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2020-10-21 14:51:32 By : PhrayaDev
 


 

No. 5



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



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


ขอบคุณทุกท่านมากครับ ลองไปปรับใช้ได้แล้วครับ ใช้เวลาไปหลายวันเลยกว่าจะมั่วได้
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2020-10-22 15:42:28 By : newphpuser
 

   

ค้นหาข้อมูล


   
 

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