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 > Mysql เลือกวันที่น้อยกว่า xxxx-xx-xx แต่ว่าแสดงเฉพาะรายการวันที่ที่ใหม่ที่สุด?



 

Mysql เลือกวันที่น้อยกว่า xxxx-xx-xx แต่ว่าแสดงเฉพาะรายการวันที่ที่ใหม่ที่สุด?

 



Topic : 134815



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



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




มีข้อมูลอยู่ประมาณนี้...


Code (SQL)
CREATE TABLE IF NOT EXISTS `rdb_apm_bills` (
  `bill_id` bigint(20) NOT NULL AUTO_INCREMENT,
  `user_id` bigint(20) DEFAULT NULL COMMENT 'refer to users.user_id of who add this',
  `bill_customer_prefix` varchar(30) COLLATE utf8mb4_unicode_ci DEFAULT NULL ,
  `bill_customer_firstname` varchar(255) COLLATE utf8mb4_unicode_ci DEFAULT NULL ,
  `bill_customer_lastname` varchar(255) COLLATE utf8mb4_unicode_ci DEFAULT NULL ,
  `bill_customer_nid` varchar(30) COLLATE utf8mb4_unicode_ci DEFAULT NULL ,
  `building_id` bigint(20) DEFAULT NULL ,
  `bill_building_name` varchar(50) COLLATE utf8mb4_unicode_ci DEFAULT NULL ,
  `room_id` bigint(20) DEFAULT NULL ,
  `bill_room_floor` varchar(10) COLLATE utf8mb4_unicode_ci DEFAULT NULL ,
  `bill_room_num` varchar(30) COLLATE utf8mb4_unicode_ci DEFAULT NULL ,
  `bill_room_description` varchar(255) COLLATE utf8mb4_unicode_ci DEFAULT NULL ,
  `rr_id` bigint(20) DEFAULT NULL ,
  `bill_rr_price` decimal(20,9) NOT NULL ,
  `bill_rr_description` varchar(255) COLLATE utf8mb4_unicode_ci DEFAULT NULL ,
  `bill_rr_type` int(1) NOT NULL ,
  `bill_cycle_type` int(1) NOT NULL DEFAULT 3 ,
  `bill_date` date DEFAULT NULL ,
  `bill_other_price` decimal(20,9) DEFAULT NULL ,
  `bill_other_description` mediumtext COLLATE utf8mb4_unicode_ci DEFAULT NULL ,
  `bill_update_user_ids` mediumtext COLLATE utf8mb4_unicode_ci DEFAULT NULL ,
  `bill_create_date` datetime DEFAULT NULL ,
  `bill_last_update` datetime DEFAULT NULL,
  `bill_skip_print` tinyint(1) NOT NULL DEFAULT 0,
  PRIMARY KEY (`bill_id`),
  KEY `user_id` (`user_id`),
  KEY `building_id` (`building_id`),
  KEY `room_id` (`room_id`),
  KEY `rr_id` (`rr_id`)
) ENGINE=InnoDB  DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci  AUTO_INCREMENT=7 ;

--
-- Dumping data for table `rdb_apm_bills`
--

INSERT INTO `rdb_apm_bills` (`bill_id`, `user_id`, `bill_customer_prefix`, `bill_customer_firstname`, `bill_customer_lastname`, `bill_customer_nid`, `building_id`, `bill_building_name`, `room_id`, `bill_room_floor`, `bill_room_num`, `bill_room_description`, `rr_id`, `bill_rr_price`, `bill_rr_description`, `bill_rr_type`, `bill_cycle_type`, `bill_date`, `bill_other_price`, `bill_other_description`, `bill_total`, `bill_update_user_ids`, `bill_create_date`, `bill_last_update`, `bill_skip_print`) VALUES
(1, 1, NULL, '101', 'dec19', NULL, 1, 'อาคาร 1', 9, '1', '101', NULL, 10, '10000.000000000', 'ร้านค้า <div>', 3, 3, '2019-12-01', NULL, NULL, '10090.000000000', 'a:1:{i:0;a:2:{s:7:"user_id";s:1:"1";s:8:"dateTime";i:1580211652;}}', '2020-01-28 18:23:51', '2020-01-28 18:40:52', 0),
(2, 1, NULL, '102', 'jan', NULL, 1, 'อาคาร 1', 10, '1', '102', NULL, 10, '10000.000000000', 'ร้านค้า <div>', 3, 3, '2020-01-01', NULL, NULL, '10114.000000000', NULL, '2020-01-28 18:24:23', '2020-01-28 18:24:23', 0),
(3, 1, NULL, '101', 'jan', NULL, 1, 'อาคาร 1', 9, '1', '101', NULL, 10, '10000.000000000', 'ร้านค้า <div>', 3, 3, '2020-01-01', NULL, NULL, '10102.000000000', 'a:1:{i:0;a:2:{s:7:"user_id";s:1:"1";s:8:"dateTime";i:1580211661;}}', '2020-01-28 18:24:34', '2020-01-28 18:41:01', 0),
(4, 1, NULL, '104', 'jan', NULL, 1, 'อาคาร 1', 12, '1', '104', NULL, 11, '11000.790000000', 'ร้านค้า', 3, 3, '2020-01-01', NULL, NULL, '11095.790000000', NULL, '2020-01-28 18:36:12', '2020-01-28 18:36:12', 0),
(5, 1, NULL, '104', 'feb', NULL, 1, 'อาคาร 1', 12, '1', '104', NULL, 11, '11000.790000000', 'ร้านค้า', 3, 3, '2020-02-01', NULL, NULL, '11181.790000000', 'a:2:{i:0;a:2:{s:7:"user_id";s:1:"1";s:8:"dateTime";i:1580211601;}i:1;a:2:{s:7:"user_id";s:1:"1";s:8:"dateTime";i:1580211425;}}', '2020-01-28 18:36:56', '2020-01-28 18:40:01', 0),
(6, 1, NULL, '102', 'mar', NULL, 1, 'อาคาร 1', 10, '1', '102', NULL, 10, '10000.000000000', 'ร้านค้า <div>', 3, 3, '2020-03-01', NULL, NULL, '10304.000000000', NULL, '2020-01-28 18:39:27', '2020-01-28 18:39:27', 0);



ต้องการเลือกแสดงหลายรายการโดยมีเงื่อนไขคือ
Code (SQL)
`rdb_apm_bills`.`room_id` IN ('9', '10', '11', '13', '14', '15', '16', '49', '50', '51', '52', '53', '54', '55', '56', '1', '2', '3', '4', '5', '6', '7', '8', '17', '18', '19', '20', '21', '22', '23', '24', '25', '26', '27', '28', '29', '30', '31', '32', '33', '34', '35', '36', '37', '38', '39', '40', '41', '42', '43', '44', '45', '46', '47', '48')


และ
Code (SQL)
`bill_date` < '2020-02-01'

โดยที่เรียงลำดับเอาเฉพาะวันที่ `bill_date` ใหม่สุดออกมา.

ปัจจุบันใช้โค้ด
Code (SQL)
SELECT 
  `apm_bills`.*, 
  `apm_bill_meters`.*, 
  `apm_bills`.`bill_id` AS `bill_id` 

FROM `rdb_apm_bills` AS `apm_bills`             

LEFT JOIN `rdb_apm_bill_meters` AS `apm_bill_meters` 
  ON `apm_bills`.`bill_id` = `apm_bill_meters`.`bill_id`             

WHERE 1 
  AND `apm_bills`.`room_id` IN ('9', '10', '11', '13', '14', '15', '16', '49', '50', '51', '52', '53', '54', '55', '56', '1', '2', '3', '4', '5', '6', '7', '8', '17', '18', '19', '20', '21', '22', '23', '24', '25', '26', '27', '28', '29', '30', '31', '32', '33', '34', '35', '36', '37', '38', '39', '40', '41', '42', '43', '44', '45', '46', '47', '48') 
  AND `bill_date` < '2020-02-01' 

GROUP BY `apm_bills`.`bill_id` 

ORDER BY `apm_bills`.`bill_date` DESC;


แต่ว่า room_id 9 มันดันเอาข้อมูลวันที่ 2019-12-01 มาแทนซะนี่... (คือมันออกมาหลายอันซ้ำๆแล้วอันล่างสุดมัน 2019 แล้ว php ก็ดันแสดงผล 2019 ซะงั้น)
ทำไงให้มันได้ตามเงื่อนไขครับ?



Tag : PHP, MySQL, MySQL







Move To Hilight (Stock) 
Send To Friend.Bookmark.
Date : 2020-01-28 19:41:57 By : mr.v View : 696 Reply : 9
 

 

No. 1



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



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


Code (SQL)
select * from (
SELECT 
  `apm_bills`.*, 
  `apm_bill_meters`.*, 
  `apm_bills`.`bill_id` AS `bill_id` 

FROM `rdb_apm_bills` AS `apm_bills`             

LEFT JOIN `rdb_apm_bill_meters` AS `apm_bill_meters` 
  ON `apm_bills`.`bill_id` = `apm_bill_meters`.`bill_id`             

WHERE 1 
  AND `apm_bills`.`room_id` IN ('9', '10', '11', '13', '14', '15', '16', '49', '50', '51', '52', '53', '54', '55', '56', '1', '2', '3', '4', '5', '6', '7', '8', '17', '18', '19', '20', '21', '22', '23', '24', '25', '26', '27', '28', '29', '30', '31', '32', '33', '34', '35', '36', '37', '38', '39', '40', '41', '42', '43', '44', '45', '46', '47', '48') 
  AND `bill_date` < '2020-02-01' 

GROUP BY `apm_bills`.`bill_id` 
) as t 
ORDER BY t.`bill_date` DESC;



ลองดูครับ ไม่รู้ว่าจะได้ไหม เพราะเคยเจอปัญหา order by หลัง group by ไม่ทำงาน ตามต้องการ






แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2020-01-28 20:24:20 By : Chaidhanan
 


 

No. 2



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

Hall of Fame 2012

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


ขอตามครับ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2020-01-28 20:27:15 By : Genesis™
 

 

No. 3



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



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


Error ครับ
Quote:
Duplicate column name 'bill_id'


ทดลองเอา join table ออกก็ปรากฏว่ายังไม่ได้ ผลลัพธ์เหมือนเดิมคือออกมาทั้ง 2 โดยมี 2019 อยู่ล่างสุด

Code (SQL)
SELECT * FROM (
SELECT 
  `apm_bills`.*

FROM `rdb_apm_bills` AS `apm_bills`                 

WHERE 1 
  AND `apm_bills`.`room_id` IN ('9', '10', '11', '13', '14', '15', '16', '49', '50', '51', '52', '53', '54', '55', '56', '1', '2', '3', '4', '5', '6', '7', '8', '17', '18', '19', '20', '21', '22', '23', '24', '25', '26', '27', '28', '29', '30', '31', '32', '33', '34', '35', '36', '37', '38', '39', '40', '41', '42', '43', '44', '45', '46', '47', '48') 
  AND `bill_date` < '2020-02-01' 

GROUP BY `apm_bills`.`bill_id` 
) AS `t`

ORDER BY `t`.`bill_date` DESC;




edit: -------------
ได้เป็นอันนี้แทน

Code (SQL)
SELECT 
  `apm_bills`.*,
  `apm_bill_meters`.*

FROM `rdb_apm_bills` AS `apm_bills`             

INNER JOIN (
  SELECT `bill_date` FROM `rdb_apm_bills` WHERE `bill_date` < '2020-02-01' ORDER BY `bill_date` DESC LIMIT 0, 1
) AS `tmp_bills` ON `apm_bills`.`bill_date` = `tmp_bills`.`bill_date`

LEFT JOIN `rdb_apm_bill_meters` AS `apm_bill_meters` 
  ON `apm_bills`.`bill_id` = `apm_bill_meters`.`bill_id`             

WHERE 1 
  AND `apm_bills`.`room_id` IN ('9', '10', '11', '13', '14', '15', '16', '49', '50', '51', '52', '53', '54', '55', '56', '1', '2', '3', '4', '5', '6', '7', '8', '17', '18', '19', '20', '21', '22', '23', '24', '25', '26', '27', '28', '29', '30', '31', '32', '33', '34', '35', '36', '37', '38', '39', '40', '41', '42', '43', '44', '45', '46', '47', '48') 
  #AND `apm_bills`.`bill_date` < '2020-02-01' #  อันนี้จะมีหรือไม่ก็ได้ ค่าเท่ากัน

GROUP BY `apm_bills`.`room_id` 

ORDER BY `bill_date` DESC


ข้อเสียคือมันหาเดือนล่าสุดไม่ได้ถ้า where เกินเดือนที่มีไป 1 เดือน
อย่างเช่นข้อมูลล่าสุดอยู่ที่ 2020-02-01 แต่ไป where `bill_date` < '2020-04-01' จะหาไม่เจออะไรเลย


ประวัติการแก้ไข
2020-01-28 20:56:25
2020-01-28 21:37:20
2020-01-28 21:38:00
2020-01-28 21:43:40
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2020-01-28 20:54:20 By : mr.v
 


 

No. 4



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



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

อยากจะช่วย แต่ รัน SQL ไม่ได้ครับ ตารางไม่ครบ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2020-01-29 06:44:01 By : {Cyberman}
 


 

No. 5



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



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


ตอบความคิดเห็นที่ : 4 เขียนโดย : {Cyberman} เมื่อวันที่ 2020-01-29 06:44:01
รายละเอียดของการตอบ ::
ตัวที่มัน JOIN ทั้งหลายมันไม่จำเป็นผมเลยไม่เอามา ใน sql query ก็เอาออกไปก่อนก็ได้ครับ

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2020-01-29 11:40:10 By : mr.v
 


 

No. 6

Guest


ทำ ข้อ มูล มา ได้ งง มาก
กว่าจะ ทำ table,qry ได้


แบบนี้ได้ไหมครับ
Code (SQL)
SELECT top 1
  apm_bills.bill_id,max(apm_bills.bill_date) --, 
  --apm_bill_meters.*, 
  --apm_bills.bill_id AS bill_idx

FROM rdb_apm_bills AS apm_bills             

--LEFT JOIN rdb_apm_bill_meters AS apm_bill_meters 
--  ON apm_bills.bill_id = apm_bill_meters.bill_id             

WHERE 1 =1  
  AND apm_bills.room_id IN ('9', '10', '11', '13', '14', '15', '16', '49', '50', '51', '52', '53', '54', '55', '56', '1', '2', '3', '4', '5', '6', '7', '8', '17', '18', '19', '20', '21', '22', '23', '24', '25', '26', '27', '28', '29', '30', '31', '32', '33', '34', '35', '36', '37', '38', '39', '40', '41', '42', '43', '44', '45', '46', '47', '48') 
  AND bill_date < '2020-03-01' 

GROUP BY apm_bills.bill_id 

ORDER BY max(apm_bills.bill_date) DESC;

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2020-01-29 15:58:44 By : WWWWIN
 


 

No. 7



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



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


ตอบความคิดเห็นที่ : 6 เขียนโดย : WWWWIN เมื่อวันที่ 2020-01-29 15:58:44
รายละเอียดของการตอบ ::
ไม่ได้ครับ ติดตั้งแต่ SELECT TOP 1 เลยครับ
SELECT TOP มันไม่มีใน MySQL ครับ



ประวัติการแก้ไข
2020-01-30 00:25:23
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2020-01-29 17:46:08 By : mr.v
 


 

No. 8

Guest


ตอบความคิดเห็นที่ : 7 เขียนโดย : mr.v เมื่อวันที่ 2020-01-29 17:46:08
รายละเอียดของการตอบ ::


ใช้ limit 1 ต่อแทน top 1 ไว้ด่านล่างครับ


แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2020-01-30 08:42:54 By : ไ
 


 

No. 9



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



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


ตอบความคิดเห็นที่ : 8 เขียนโดย : เมื่อวันที่ 2020-01-30 08:42:54
รายละเอียดของการตอบ ::
LIMIT 1 มันออกมาแค่รายการเดียว อันนี้ผมจะให้ออกมาหลายรายการครับ ทบทวนคำถามซ้ำ...

Quote:
Mysql .....

ต้องการเลือกแสดงหลายรายการ... ....โดยที่เรียงลำดับเอาเฉพาะวันที่ `bill_date` ใหม่สุดออกมา.




สรุปได้มาเป็นอันนี้...

Code (SQL)
WITH `apm_bills_latest` AS (             
    SELECT `apm_bills`.*, ROW_NUMBER() OVER (PARTITION BY `room_id` ORDER BY `bill_date` DESC) AS `rn`             
    FROM `rdb_apm_bills` AS `apm_bills` 
    WHERE `apm_bills`.`bill_date` < '2020-02-01'         
)         

SELECT *          

FROM `apm_bills_latest`          

LEFT JOIN `rdb_apm_bill_meters` AS `apm_bill_meters` ON `apm_bills_latest`.`bill_id` = `apm_bill_meters`.`bill_id`         

WHERE 
  `rn` = 1 
  AND `apm_bills_latest`.`room_id` IN (...);


อ้างอิงจาก https://stackoverflow.com/a/1313293/128761 โดยต้องใช้ Mysql server >= 8.0, Maria DB >= 10.2.1


ประวัติการแก้ไข
2020-01-30 11:23:24
2020-01-30 13:16:26
2020-01-30 13:17:43
2020-02-01 05:15:43
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2020-01-30 11:22:11 By : mr.v
 

   

ค้นหาข้อมูล


   
 

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