|
SQL Server 2008 การ SELECT แบบ LIKE % % ใน Query Builder |
SQL Server 2008 การ SELECT แบบ LIKE % % ใน Query Builder พอดีวันนี้นั่งเขียนโปแรกรม ฐานข้อมูลลูกค้าอยู่ มีจุดที่ต้องการค้นหา โดยใช้ like % % ซึ่งปกติ ผมจะมักใช้งาน query builder มากว่า มานั่งเขียนโค้ดเองอยู่แล้ว
เอาละครับ เรามาดู like % % ตามบทความนี้กันก่อนครับ
https://www.thaicreate.com/tutorial/sql-like.html
https://www.w3schools.com/sql/sql_like.asp
เท่าที่เห็น select ไม่ได้ซับซ้อนอะไรมากมาย ครับ
รูปแบบมีแค่
Code (C#)
SELECT column1, column2, ...
FROM table_name
WHERE columnN LIKE pattern
ผมจะลองใช้กับตาราง Postcode ดูนะครับ
data:image/s3,"s3://crabby-images/0af20/0af20501782c5f89cf34cebcfdc0a68707591efb" alt="55 55"
ง่ายใช่ไม๊ครับ
ทีนี้ผมจะลองใช้ like ดูนะครับ
การใช้ like สามารถ พิมพ์ ข้อความที่เราต้องการลงใน ช่อง filter ได้เลย แบบนี้
data:image/s3,"s3://crabby-images/e58df/e58df37ac8dfe65c2f23dca89b1f2ba1430ff180" alt="2 2"
พอเรา Excuted Query จะเห็นว่า ตรงช่องที่เรา พิมพ์ไว้ จะมี ' คล่อมไว้ แบบนี้ ครับ
data:image/s3,"s3://crabby-images/1ed81/1ed8187a64a14a5e80bf545bfb18f32c084d5a7e" alt="3 3"
ทีนี้ เราจะใช้ like % ดู
โดยพิมพ์ like %ข้อความที่ต้องการค้น หรือ like ข้อความที่ต้องการค้น% หรือ like %ข้อความที่ต้องการค้น%
แบบนี้ ครับ
data:image/s3,"s3://crabby-images/841d3/841d3125b5601dd408f2d7471edfe839c95ce14d" alt="4 4"
นอกจากนี้แล้ว เรายังสารมารถ ค้นหาแบบใส่ paramter ได้ด้วยนะครับ
อ่านเพิ่มเติมได้จาก
https://www.thaicreate.com/community/csharp-add-query-parameter-in-wizard-ban-ban/view.html
การใส่ paramter จะต้องมี @ นำหน้า คำค้น ครับ
เช่น ผมจะให้ user ค้น จาก รหัสไปรษณี
ผมก็จะเขียนดังนี้ครับ
data:image/s3,"s3://crabby-images/da1aa/da1aaba0a1ddb352aee4addd727831460ecedf40" alt="5 5"
รูปแบบจะเป็น แบบนี้ครับ
PostCode LIKE '%' + @Cri + '%'
Excuted Query จะเห็นว่ามี หน้า dialog ขึ้นมาเพื่อให้เรา กรอกข้อมูลที่ต้องการค้นหาลงไป
data:image/s3,"s3://crabby-images/9b420/9b4205ec01208bdf26ee2530dd8b4cf1d78170db" alt="6 6"
พอเราค้นหาจะได้แบบนี้ครับ
data:image/s3,"s3://crabby-images/df2b0/df2b0eb25210cdc425a89f51ae20679a0ed396d3" alt="7 7"
ไม่คิดว่าจะรหัสไปรษณี %123% เลยนะเนี๊ยะ 5555
ทีเด็ดมันอยู่ตรงนี้ครับ
ผมจะให้ user ค้น จาก รหัสไปรษณี หรือ จังหวัด หรือ อำเภอ หรือ ตู้ รหัสไปรษณี
เราก็ ก๊อบ โค้ดเดิมเรา ไปใส่ในช่อง Or ของ column ที่จะค้นต่อไป
ในที่นี้ ผมมี PostCode แล้ว
ผมจะค้นจาก PostOffice/Amphur/Province ก็ก๊อบ LIKE '%' + @Cri + '%' ไปวางดังรูป
data:image/s3,"s3://crabby-images/57404/57404be29a2229bc97ecfab00bd7d96d382ea90e" alt="8 8"
Excuted Query จะเห็นว่ามี หน้า dialog ขึ้นมาเพื่อให้เรา กรอกข้อมูลที่ต้องการค้นหาลงไป
ค้นแบบ 1
data:image/s3,"s3://crabby-images/b5523/b5523738619625d833f47d275dc7872092b72ac4" alt="9 9"
data:image/s3,"s3://crabby-images/06968/06968e0a9f12e850a099036f73a111fc90cbbaf7" alt="10 10"
ค้น 2
data:image/s3,"s3://crabby-images/16db7/16db70a0a853db2f01dccd72df9d18bb193b054b" alt="11 11"
data:image/s3,"s3://crabby-images/03255/0325558e0e35a967ef4fdfbf09e45a3bcf839b6e" alt="12 12"
ค้น 3
data:image/s3,"s3://crabby-images/3a5d3/3a5d3da2cab580e806a931d73b7cdae027d89ac5" alt="13 13"
data:image/s3,"s3://crabby-images/a03fb/a03fbead7611ccd3ed69468fbd46f3664af47717" alt="14 14"
เรามาลองใช้งานกันครับ
data:image/s3,"s3://crabby-images/b1fdf/b1fdf8e2f398d0bbdf23326dc016d2106228d4d4" alt="15 15"
data:image/s3,"s3://crabby-images/022cb/022cb6f93052d2a8c4683a3d3373ea40bbd96da2" alt="16 16"
data:image/s3,"s3://crabby-images/82488/82488516cb34c1b4399fca884784493631cfc513" alt="17 17"
data:image/s3,"s3://crabby-images/c05d9/c05d904112d3dd84dd366b3246ff20a4c6adc185" alt="18 18"
data:image/s3,"s3://crabby-images/6a683/6a6837bc464854230d33fd8c8621b13b110f3888" alt="19 19"
แหล่มดีไม๊ละครับ
อันที่ที่จริง ผมเพิ่งรู้วันนี้(2018-08-22) นี่แหละครับ ว่ามันทำแบบนี้ก็ได้ เลย เอามาเขียนให้อ่านกัน
การเพิ่ม parameter like % การค้นหาใน wizard แบบบ้านๆ ก็ขอจบลงเพียงเท่านี้ครับ เนื่องจากใช้ความรู้แบบบ้าน ๆ จึงได้โค้ด และ หลักการแบบบ้านๆ มาเขียนบทความแบบบ้านๆ ให้อ่านกันครับ
Edit 2018-08-22 15:43
สำหรับการค้นหา แบบ เทพๆ ยังมีต่ออีกครับ
หลังจากนั่งศึกษา อีก ครึ่งวัน ทำให้ได้ Stored Procedure ที่ใช้สำหรับการค้นหา ออกมาด้วยครับ
ข้อดีของ Stored Procedure คือ
เมื่อเราสร้างโปรเจคใหม่ หรือ มี หลายๆ โปรเจคที่ต้องใช้ ฐานข้อมูลเดียวกัน
เราจะไม่ต้อง มาคอยสร้าง โค้ดซ้ำ ๆ ในโปรแกรม
สำหรับ Stored Procedure สามารถศึกษาเพิ่มเติมได้ตามนี้ ครับ
https://www.thaicreate.com/tutorial/oracle-stored-procedure.html
ย้ำว่าอ่านแค่ ครึ่งวัน กับความตั้งใจลองผิดลองถูกนิดๆหน่อยๆก็ได้แล้วครับ
ยกตัวอย่าง Stored Procedure ที่ผมเพิ่งสร้างเสร็จนะครับ
data:image/s3,"s3://crabby-images/2d6b5/2d6b5b6b62309077067c7d0cfed54e3cf9c0f4d1" alt="20 20"
Code (C#)
USE [DATALAB]
GO
/****** Object: StoredProcedure [dbo].[PostCodeByLike] Script Date: 08/22/2018 15:48:27 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
-- =============================================
-- Author: <Author,,Name>
-- Create date: <Create Date,,>
-- Description: <Description,,>
-- =============================================
ALTER PROCEDURE [dbo].[PostCodeByLike]
@Cri varchar(10)
AS
BEGIN
-- SET NOCOUNT ON added to prevent extra result sets from
-- interfering with SELECT statements.
SET NOCOUNT ON;
-- Insert statements for procedure here
SELECT * from View_Postcode where View_Postcode.PostCode like '%'+@Cri+'%'
or View_Postcode.Post_Amphur like '%'+@Cri+'%'
or View_Postcode.Post_PostOffice like '%'+@Cri+'%'
or View_Postcode.Post_Province like '%'+@Cri+'%'
END
แต่ตอนที่ดึง Stored Procedure ไปลงใน Wisard
จะต้องเลือก Stored Procedure ไม่ใช่ SQL
data:image/s3,"s3://crabby-images/a8fbd/a8fbdb3cb30fcb2e514353c3c6c5256d958ac9b0" alt="21 21"
แล้วก็เลือก Stored Procedure ที่ต้องการได้เลย
data:image/s3,"s3://crabby-images/a2042/a2042d66be58a77cdf2eca3e117256f56aef1ad4" alt="22 22"
ผมเพิ่งหัดทำ จะไม่มี Insert Update Delete ใดๆ นะครับ
data:image/s3,"s3://crabby-images/9e205/9e205dcfb6c26eb5c4ed763563a032f6ea556e88" alt="23 23"
รู้สึกจะไม่มี Fill ก็เลยต้อง Add ใหม่(เริ่มจะไม่ยากแล้วครับ หลังจากลองผิดลองถูกมาพักใหญ่)
data:image/s3,"s3://crabby-images/4332f/4332f4b8fbc5b6cf3ce2aeee124212d3039b3802" alt="24 24"
data:image/s3,"s3://crabby-images/1e42c/1e42ca7d485e16337c8b5233c76c51db1c4ffc2d" alt="25 25"
data:image/s3,"s3://crabby-images/0c548/0c548fe0d9b068dbbbe2e8e1026872807530aecc" alt="26 26"
data:image/s3,"s3://crabby-images/3025d/3025d75364b1c30e80061290458f0c121fd2a14b" alt="27 27"
เรียบร้อยครับ
data:image/s3,"s3://crabby-images/22944/22944181e14032e3f314c72db083bfd6fd062c65" alt="28 28"
ลองทดสอบกับ หน้าฟอร์มดู
data:image/s3,"s3://crabby-images/15c21/15c2148c327b3ad7f5769ebe566ddc51ceb9df16" alt="30 30"
ในส่วนของโค้ดจะไม่มี Form_load มาให้เหมือนเราลากตัว ปกติมาลงใน ฟอร์ม นะครับ
และส่งผลให้ ไม่
TableAdapter.Fill
มาให้ เวลาเปิดมา จะกลายเป็นหน้าว่างๆ
จึงเป็นเหตุผลว่า ทำไม ผมจึงต้อง Add Fill ขึ้นมา
ก็เพื่อ รองรับ ตอน เปิดหน้า ฟอร์ม ขึ้นมานั่นเองครับ
Code (C#)
public partial class frmPostCode_View : Form
{
public frmPostCode_View()
{
InitializeComponent();
this.postCodeByLikeDataGridView.SetGridDefaultCellStyle();
}
private void fillLikeCriToolStripButton_Click(object sender, EventArgs e)
{
try
{
this.postCodeByLikeTableAdapter.FillLikeCri(this.dATALAB_Postcode.PostCodeByLike, criToolStripTextBox.Text);
}
catch (System.Exception ex)
{
System.Windows.Forms.MessageBox.Show(ex.Message);
}
}
private void frmPostCode_View_Load(object sender, EventArgs e)
{
this.postCodeByLikeTableAdapter.FillBy(this.dATALAB_Postcode.PostCodeByLike);
}
}
ลองรันดู
data:image/s3,"s3://crabby-images/0114c/0114c0c66ebe4ccde1bec60c4f6889ad2a5e9f2d" alt="31 31"
ใช้ได้ปกติ ครับ
แบบนี้ เราก็สามารถเอา Stored Procedure ไปรันกับโปรแกรมอื่น ที่ใช้ฐานข้อมูลเดียวกันได้สบายครับ
data:image/s3,"s3://crabby-images/fb383/fb38346e31d9bb4f28f9550c882abb3d761cac7e" alt=""
|
|
|
|
data:image/s3,"s3://crabby-images/5d50d/5d50d6c29239a9da7fed3c75f52401da0488417f" alt="" |
|
|
|
By : |
TOR_CHEMISTRY
|
|
Article : |
บทความเป็นการเขียนโดยสมาชิก หากมีปัญหาเรื่องลิขสิทธิ์ กรุณาแจ้งให้ทาง webmaster ทราบด้วยครับ |
|
Score Rating : |
data:image/s3,"s3://crabby-images/fa28a/fa28a4ccb73eccec48000d688830fff77ebecb87" alt="" data:image/s3,"s3://crabby-images/fa28a/fa28a4ccb73eccec48000d688830fff77ebecb87" alt="" |
|
Create Date : |
2018-08-22 |
|
Download : |
No files |
|
Sponsored Links |
|
|
|
|
|
|