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

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


[PHP] ดึงข้อมูลจาก 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 : 951 Reply : 5
 

 

No. 1



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

Hall of Fame 2012

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


Example
01.$cars = array(
02.    array(
03.        "name"=>"Urus",
04.        "record"=>"10,12",
05.    ),
06.    array(
07.        "name"=>"Cayenne",
08.        "record"=>"10,15",
09.    ),
10.);
11. 
12.$price = array(
13.    10 => 1000,
14.    12 => 1200,
15.    15 => 1500,
16.);
17. 
18.for($i=0;$i<count($cars);$i++){
19.    echo $cars[$i]['name']."<br>";
20.    $exps = explode(',',$cars[$i]['record']);
21.    $total = 0;
22.    foreach($exps as $exp){
23.        echo $exp."=".$price[$exp]."<br>";
24.        $total += $price[$exp];
25.    }
26.    echo "total =".$total."<br>";
27.}


อ่าน 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)
01.SELECT 
02.    result,
03.    LENGTH(GROUP_CONCAT(file_path)) - LENGTH(REPLACE(GROUP_CONCAT(file_path), result, '')) AS qty
04.FROM  (
05.        SELECT 
06.                SUBSTRING_INDEX(SUBSTRING_INDEX(file_path, ',', a.letter + 1), ',', -1) result,
07.            file_path
08.        FROM  book
09.            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
10.) a
11.GROUP BY result
12.HAVING COUNT(result) > 0 AND result <> ''
13.ORDER BY result

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

 

No. 3



โพสกระทู้ ( 4,765 )
บทความ ( 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)
01.CREATE TABLE table1
02.    (`id` int, `value` varchar(20))
03.;
04.     
05.INSERT INTO table1
06.    (`id`, `value`)
07.VALUES
08.    (1, 'Red,Green,Blue'),
09.    (2, 'Orangered,Periwinkle'),
10.    (3, 'Green,Blue,Orangered'),
11.    (4, 'Red,Blue')
12.;
13. 
14.DELIMITER $$
15. 
16.DROP PROCEDURE IF EXISTS explode_table $$
17.CREATE PROCEDURE explode_table(bound VARCHAR(255))
18. 
19.BEGIN
20. 
21.DECLARE id INT DEFAULT 0;
22.DECLARE value TEXT;
23.DECLARE occurance INT DEFAULT 0;
24.DECLARE i INT DEFAULT 0;
25.DECLARE splitted_value TEXT;
26.DECLARE done INT DEFAULT 0;
27.DECLARE cur1 CURSOR FOR SELECT table1.id, table1.value
28.                                     FROM table1
29.                                     WHERE table1.value != '';
30.DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = 1;
31. 
32.DROP TEMPORARY TABLE IF EXISTS table2;
33.CREATE TEMPORARY TABLE table2(
34.`id` INT NOT NULL,
35.`value` VARCHAR(255) NOT NULL
36.) ENGINE=Memory;
37. 
38.OPEN cur1;
39.  read_loop: LOOP
40.    FETCH cur1 INTO id, value;
41.    IF done THEN
42.      LEAVE read_loop;
43.    END IF;
44. 
45.    SET occurance = (SELECT LENGTH(value)
46.                             - LENGTH(REPLACE(value, bound, ''))
47.                             +1);
48.    SET i=1;
49.    WHILE i <= occurance DO
50.      SET splitted_value =
51.      (SELECT REPLACE(SUBSTRING(SUBSTRING_INDEX(value, bound, i),
52.      LENGTH(SUBSTRING_INDEX(value, bound, i - 1)) + 1), ',', ''));
53. 
54.      INSERT INTO table2 VALUES (id, splitted_value);
55.      SET i = i + 1;
56. 
57.    END WHILE;
58.  END LOOP;
59. 
60.  SELECT t.value `สี`, COUNT(t.value) `จำนวน` FROM (SELECT * FROM table2) t GROUP BY t.value;
61. CLOSE cur1;
62.END; $$
63. 
64.-- เวลาเรียกใช้            
65.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 (หรือล็อกอินเข้าระบบสมาชิกเพื่อไม่ต้องกรอก)





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