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 > Raw Query Laravel 5.6, SQL SERV ต้องการใส่เครื่องหมาย Single Quotes



 

Raw Query Laravel 5.6, SQL SERV ต้องการใส่เครื่องหมาย Single Quotes

 



Topic : 131096



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

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

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



Raw Query Laravel 5.6, SQL SERV
ต้องการใส่เครื่องหมาย Single Quotes between '2018-04-01' and '2018-04-30' เพราะถ้าไม่มีเครืองหมาย ' เวลา query จะไม่มีข้อมูลออกมาเลย

Code (PHP)
แบบที่ 1
->whereBetween ('opdmas.VisitDate',[(convert(date,str_replace("*", "'",'*2018-04-01*'))),(convert(date,str_replace("*","'",'*2018-04-30*')))])
Error 
Call to undefined function App\Http\Controllers\Report\convert()"


Code (PHP)
แบบที่ 2
->whereBetween ('opdmas.VisitDate',[str_replace("*", "'",'*2018-04-01*'),str_replace("*","'",'*2018-04-30*')])
Error 
Conversion failed when converting date and/or time from character string......
output:  [opdmas].[VisitDate] between '2018-04-01' and '2018-04-30'


Code (PHP)
แบบที่ 3
->whereBetween ('opdmas.VisitDate',["'2018-04-01'","'2018/04/30'"])
Error
Conversion failed when converting date and/or time from character string.
output : opdmas].[VisitDate] between '2018-04-01' and '2018/04/30'




Tag : PHP, Ms SQL Server 2016, Laravel Framework









ประวัติการแก้ไข
2018-05-20 15:04:11
2018-05-20 15:04:42
Move To Hilight (Stock) 
Send To Friend.Bookmark.
Date : 2018-05-20 15:03:12 By : nottpoo View : 1567 Reply : 10
 

 

No. 1



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



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


Code (PHP)
$query->whereBetween('datetime',array('2018-05-01','2018-05-31 23:59:59'))









ประวัติการแก้ไข
2018-05-20 18:06:27
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2018-05-20 18:03:20 By : Chaidhanan
 


 

No. 2



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

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

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

ตอบความคิดเห็นที่ : 1 เขียนโดย : Chaidhanan เมื่อวันที่ 2018-05-20 18:03:20
รายละเอียดของการตอบ ::
ต้องการระบุฟิล์ด ที่มันดึงมาแสดง คือ master.VisitDate เพราะว่าข้อมูลวันที่นั้นได้มาจากการ join Table
แต่ว่าการระบุ Array มันจะยอมให้แค่ ค่าเดียว แต่โค้ดที่พี่ ให้มา มันระบุแค่ datetime แล้วตามด้วย Array แล้วมันจะรู้เหรอคะว่าดึงมาจาก
Table ไหน ถ้าเราไม่ระบุให้มัน


ก็เลยลองเอาฟิลด์ master.VisitDate ออก มันก็ฟ้องทันทีเลยคะ Invalid column name 'datetime'
Code (PHP)
"SQLSTATE[42S22]: [Microsoft][ODBC Driver 13 for SQL Server][SQL Server]Invalid column name 'datetime'.


ถ้าใส่แบบนี้ ->whereBetween('master.VisitDate','datetime',array('2018-04-01','2018-04-30'))
Error เพราะมันยอมได้แค่ค่าเดียวตาม function whereBetween

Code (PHP)
	 public function whereBetween($column, array $values, $boolean = 'and', $not = false){
	 .
	 .
	}
	Type error: Argument 2 passed to Illuminate\Database\Query\Builder::whereBetween() must be of the type array, string given, called in D:\Apache24\htdocs\Laravel...on line 23


Code (PHP)
public function TodayDetail()
    {
    //RAW QUERIES
	$TodayDetail = DB::table('DB_TEST.dbo.HNOPD_master  as master')
	->join('DB_TEST.dbo.PRESCRIP  as prescrip',
		function ($join){
	         $join->on('master.VN','=','prescrip.VN')
	                  ->on('master.VisitDate','=','prescrip.VisitDate');
	              })
	->join(
			 'DB_TEST.dbo.Cconfig  as config'
			 ,'prescrip.Clinic','=','config.code'
			 	)
	->select(DB::raw('count(master.VN) as VN','count(DISTINCT prescrip.Doctor) as Doctor')
			,'master.VisitDate'
			,'prescrip.Clinic'
			,'config.LocalName'
			)
	->where([['master.sxl','=','0'],['prescrip.Clinic','=',"'AO'"],['config.CtrlCode','=','12345']])
	->whereBetween('master.VisitDate','datetime',array('2018-04-01','2018-04-30'))
        ->get();
}


พอใส่แบบนี้
Code (PHP)
->whereBetween('opdmas.VisitDate',array('2018-04-01','2018-04-30'))


ไม่ error แต่ไม่มีข้อมูลออกมาตามรูป
aa


ประวัติการแก้ไข
2018-05-20 23:43:31
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2018-05-20 23:37:04 By : nottpoo
 

 

No. 3



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



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


datetime เป็นชื่อสมมติ แค่ให้รู้ว่าเป็น type datetime คุณก็เปลี่ยนให้ถูกต้องเอาเองครับ

จุดสำคัญคือไม่ต้องไปใส่ quote ให้มัน มันใส่ให้เองอัตตโนมัติครับ

ส่วนที่มันไม่มีค่าออกมา นี่ต้องดูว่า ข้อมูลมันถูกต้องไหม ลองให้มัน echo statement ออกมาเช็คด้วยตาก่อนว่า ถูกต้องไหม
มี condition อะไรผิดเพี้ยนไปหรือเปล่า มีวงเล็บ ถูกต้องหรือไม่
ให้ลองใช้ ->toSql(); ดูครับ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2018-05-21 09:05:08 By : Chaidhanan
 


 

No. 4

Guest


ตอบความคิดเห็นที่ : 3 เขียนโดย : Chaidhanan เมื่อวันที่ 2018-05-21 09:05:08
รายละเอียดของการตอบ ::
สุดยอดครับ น้าสอนได้ดีจริงๆ ใจเย็น

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2018-05-21 11:20:52 By : DK
 


 

No. 5



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

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

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

ตอบความคิดเห็นที่ : 3 เขียนโดย : Chaidhanan เมื่อวันที่ 2018-05-21 09:05:08
รายละเอียดของการตอบ ::
SQL ออกมาปกติคะ ติดแค่ตรง between 2018-04-01 and 2018-04-30 ไม่มีเครื่องหมาย '
ติดออกมาด้วย ทำให้ Query ข้อมูลออกมาเป็นค่าว่าง แต่พอลองเอา ' ใส่ด้วยมือ ข้อมูลออกคะ


แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2018-05-21 13:31:03 By : nottpoo
 


 

No. 6



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



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


ตอบไม่ถูกเหมือนกันครับ ว่าทำไมไม่มี single quote ครอบมาด้วย เพราะที่เคยทำมามันมีออกมาด้วย

อันนี้เป็นการทำแบบอ้อม แต่ไม่ใช่การแก้ปัญหาเรื่องการใช้ whereBetween

->whereRaw(" your_fieldname between '2018-01-01' and '2018-01-31 23:59:59.999' ")->get();
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2018-05-21 14:21:11 By : Chaidhanan
 


 

No. 7

Guest


config/database.php
เปิด strict mode ใว้หรือเปล่าครับ เปลี่ยนเป็น false
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2018-05-21 15:19:42 By : DK
 


 

No. 8



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

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

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

ตอบความคิดเห็นที่ : 7 เขียนโดย : DK เมื่อวันที่ 2018-05-21 15:19:42
รายละเอียดของการตอบ ::
เปลี่ยนเป็น false แล้วคะ


อันนี้ที่ได้จาก tosql();
Code (PHP)
select count(mas.VN) as VN, [mas].[VisitDate], [prescrip].[Clinic], [config].[EnglishName], [config].[LocalName] as [LocalName] 
from [DB_TEST].[dbo].[MASTER] as [mas] inner join [DB_TEST].[dbo].[PRESCRIP] as [prescrip] on [mas].[VN] = [prescrip].[VN] 
and [mas].[VisitDate] = [prescrip].[VisitDate] inner join [DB_TEST].[dbo].[config] as [config] on [prescrip].[Clinic] = [config].[code] 
where ([mas].[cxl] = ? and [prescrip].[Clinic] = ? and [config].[CtrlCode] = ?) and [mas].[VisitDate] between ? and ? and [prescrip].
[Clinic] in (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?) 
group by [mas].[VisitDate], [prescrip].[Clinic], [config].[EnglishName], [config].[LocalName]


แต่พอใส่
//var_dump($sql->toSql());
//var_dump($sql->getBindings());
เพื่อจะดูค่า ทำไม error "Call to a member function toSql() on string"


ประวัติการแก้ไข
2018-05-21 16:31:55
2018-05-21 16:41:26
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2018-05-21 16:30:53 By : nottpoo
 


 

No. 9

Guest


db::enableQueryLog();

ใส่ใว้ก่อนคิวรี่

dd(db::getQueryLog());
ใว้ล่างคิวรี่
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2018-05-21 19:48:24 By : DK
 


 

No. 10

Guest


ใช้ Eloquent เถอะครับ ชีวิตจะได้ดีขึ้น
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2018-05-21 19:52:24 By : DK
 

 

No. 11



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

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

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

ตอบความคิดเห็นที่ : 10 เขียนโดย : DK เมื่อวันที่ 2018-05-21 19:52:24
รายละเอียดของการตอบ ::
อืม เดี๋ยวอาจจะปรับ ดูคะ

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2018-05-21 20:47:26 By : nottpoo
 


   

ค้นหาข้อมูล


   
 

แสดงความคิดเห็น
Re : Raw Query Laravel 5.6, SQL SERV ต้องการใส่เครื่องหมาย Single Quotes
 
 
รายละเอียด
 
ตัวหนา ตัวเอียง ตัวขีดเส้นใต้ ตัวมีขีดกลาง| ตัวเรืองแสง ตัวมีเงา ตัวอักษรวิ่ง| จัดย่อหน้าอิสระ จัดย่อหน้าชิดซ้าย จัดย่อหน้ากึ่งกลาง จัดย่อหน้าชิดขวา| เส้นขวาง| ขนาดตัวอักษร แบบตัวอักษร
ใส่แฟลช ใส่รูป ใส่ไฮเปอร์ลิ้งค์ ใส่อีเมล์ ใส่ลิ้งค์ 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 อัตราราคา คลิกที่นี่