กระทู้เก่าบอร์ด อ.Yeadram
5,895 13
URL.หัวข้อ /
URL
copy ข้อมูลจาก record หนึ่งไปยังrecord ใหม่
ต้องการ copy ข้อมูลจาก record หนึ่งไปยังrecord ใหม่ โดยในตารางดังกล่าวมีข้อมูลดังต่อไปนี้
ตาราง TCust ประกอบด้วย (CustID Type = Text)
CustID DesA Phone
A1 ดี 9644
A2 พอใช้ 9123
A15 ดี 9948
B6 ดีมาก 9953
B8 ปรับปรุง 9456
ต้องการ copy ข้อมูล DesA Phone จาก record หนึ่ง (ตามที่ระบุ) ไปยังrecord ใหม่ โดยให้กดปุ่ม แล้วมี Msg box บอกว่า โปรดระบุ CustID ที่ต้องการ Copy และใส่ CustID ใหม่ที่ต้องการ ต้องทำอย่างไรค่ะ และต้องการเช็คด้วยว่าเลขที่ใหม่ที่ใส่ไปนั้นซ้ำหรือไม่ เช่นต้องการ Copy ข้อมูลจาก A15 ไปยัง B9 ก็จะได้ข้อมูลใหม่เป็น
CustID DesA Phone
A1 ดี 9644
A2 พอใช้ 9123
A15 ดี 9948
B6 ดีมาก 9953
B8 ปรับปรุง 9456
B9 ปรับปรุง 9456
แต่หาก CustID ใหม่ที่ระบุมีอยู่แล้วในตาราง (ไม่ว่าข้อมูล DesA Phone จะเหมือนกันหรือไม่ก็ตาม ให้มี Msg ถามก่อนว่าต้องการcopy ใช่หรือไม่
ขอบคุณค่ะ
ตาราง TCust ประกอบด้วย (CustID Type = Text)
CustID DesA Phone
A1 ดี 9644
A2 พอใช้ 9123
A15 ดี 9948
B6 ดีมาก 9953
B8 ปรับปรุง 9456
ต้องการ copy ข้อมูล DesA Phone จาก record หนึ่ง (ตามที่ระบุ) ไปยังrecord ใหม่ โดยให้กดปุ่ม แล้วมี Msg box บอกว่า โปรดระบุ CustID ที่ต้องการ Copy และใส่ CustID ใหม่ที่ต้องการ ต้องทำอย่างไรค่ะ และต้องการเช็คด้วยว่าเลขที่ใหม่ที่ใส่ไปนั้นซ้ำหรือไม่ เช่นต้องการ Copy ข้อมูลจาก A15 ไปยัง B9 ก็จะได้ข้อมูลใหม่เป็น
CustID DesA Phone
A1 ดี 9644
A2 พอใช้ 9123
A15 ดี 9948
B6 ดีมาก 9953
B8 ปรับปรุง 9456
B9 ปรับปรุง 9456
แต่หาก CustID ใหม่ที่ระบุมีอยู่แล้วในตาราง (ไม่ว่าข้อมูล DesA Phone จะเหมือนกันหรือไม่ก็ตาม ให้มี Msg ถามก่อนว่าต้องการcopy ใช่หรือไม่
ขอบคุณค่ะ
13 Reply in this Topic. Dispaly 1 pages and you are on page number 1
2 @R01969
เขียน Code ค่ะ ยอมรับว่าเขียน code เองไม่เป็น แต่จะใช้วิธี ลอกคนอื่นมาแก้ไข แต่จะให้ตั้งต้นเขียนเองทำไม่ได้ เพราะไม่รู้จัก VB อย่างแท้จริง
แต่ตอนนี้พยายามศึกษาอยู่ค่ะ
แต่ตอนนี้พยายามศึกษาอยู่ค่ะ
3 @R01971
แต่ละงาน อาจมีวิธีทำได้มากกว่า 1 ทาง
ที่ผมแนะนำไปก่อนนี้ อาจจะใช้วิธี
- ย้ายเคอร์เซอร์ไปที่เรคคอร์ดต้นทาง
- เก็บค่าจากฟิลด์ที่ต้องการเข้าตัวแปร
- ย้ายเคอร์เซอร์ไปที่เรคคอร์ดเป้าหมาย
- วางค่าจากตัวแปรลงใสในฟิลด์
อีกวิธี อาจใช้คำสั่ง CopyRecord โดยตรงเลยก็ได้
หรือ..... อาจใช้วิธีให้รัน คิวรี่ ก็ได้ แบบนี้
ที่ผมแนะนำไปก่อนนี้ อาจจะใช้วิธี
- ย้ายเคอร์เซอร์ไปที่เรคคอร์ดต้นทาง
- เก็บค่าจากฟิลด์ที่ต้องการเข้าตัวแปร
- ย้ายเคอร์เซอร์ไปที่เรคคอร์ดเป้าหมาย
- วางค่าจากตัวแปรลงใสในฟิลด์
อีกวิธี อาจใช้คำสั่ง CopyRecord โดยตรงเลยก็ได้
หรือ..... อาจใช้วิธีให้รัน คิวรี่ ก็ได้ แบบนี้
sub copyrec()
dim srcCustID as string
dim desCustID as string
dim sqlStatement as string
if msgbox("ต้องการคัดลอกเรคคอร์ดหรือไม่")=vbyes then
srcCustID = inputbox("ต้องการคัดลอกจากเรคคอร์ดใด")
if srcCustID<>"" or not isnull(srcCustID) then
dscCustID=inputbox("ต้องการวางใส่เรคคอร์ดใด")
if dscCustID<>"" or not isnull(dscCustID) then
if isnull(dlookup("CustID","tCust","[CustID] = '" & dscCustID & "'")) then
sqlStatement = "Update tCust, (Select tCust.DesA, tCust.Phone From tCust Where tCust.CustID ='" & _
srcCustID & "') As q Set tCust.DesA = q.DesA, tCust.Phone = q.Phone Where tCust.CustID ='" & dscCustID & "';"
debug.print sqlStatement
' docmd.setwarnings false
' docmd.runsql sqlStatement
end if
end if
end if
end if
End Sub
4 @R01974
ที่อาจารย์ yeadram บอก 2 วิธีแรก เป็นการทำโดยตรงที่ตารางใช่ไหมค่ะ
ส่วนวิธี รัน คิวรี่ นั้นต้องทำอย่างไรค่ะ
มีนลองเอา code ไปผูกกับ Button แล้ว ผลที่ได้มี Msg ถาม "ต้องการคัดลอกเรคคอร์ดหรือไม่" เพียงแค่อย่างเดียวเองค่ะ (ตามรูป)
ขอโทษค่ะ ไม่เข้าใจจริง ๆ เพิ่งจะเริ่มศึกษา access ค่ะ
ส่วนวิธี รัน คิวรี่ นั้นต้องทำอย่างไรค่ะ
มีนลองเอา code ไปผูกกับ Button แล้ว ผลที่ได้มี Msg ถาม "ต้องการคัดลอกเรคคอร์ดหรือไม่" เพียงแค่อย่างเดียวเองค่ะ (ตามรูป)
ขอโทษค่ะ ไม่เข้าใจจริง ๆ เพิ่งจะเริ่มศึกษา access ค่ะ
5 @R01975
ง่า.... ไม่ครบ อิอิ ไม่ได้ใส่ ตัวเลือกให้ msgbox
อืมม....
เอา OK เลยก็ได้ ไม่ต้อง yesno หรอก
if msgbox("ต้องการคัดลอกเรคคอร์ดหรือไม่")=vbOK then
หมายความว่า ถ้าเขากด OK ก็เข้าเงื่อนไข ให้ทำงานได้เลย
แต่ถ้าเขากดปิด msgbox หรือกด ESC ก็ไม่ต้องทำงาน
อ้อ แล้วก็ โค้ดที่ให้ไป มันจะทำงานถึงบรรทัดที่เน้นสีแดงนะครับ ให้ เปิด debug window ขึ้นมาตรวจดู (ctl+G) ประโยค sql ก่อนครับ ถ้าคิดว่ามันเขียนได้ถูกต้อง ค่อย เบรคบรรทัดนั้น แล้วปล่อย สองบรรทัดล่างนั่นได้เลย
ที่ทำอย่างนี้เพราะว่า โค้ดที่ให้ไป ผมเขียนสดผ่านการโพสต์นี่เลย ไม่ได้ทดสอบใดๆ เลยครับ คุณมีนลองเอาไปทดสอบแล้วปรับแก้ไป พอได้นะครับ
และ จริงๆ แล้ว โค้ดนี้มันไม่สมบูรณ์นะครับ ที่เขียนให้ก็คือ พอให้เห็นลำดับงาน ว่าเราจะทำการตรวจสอบเงื่อนไขอย่างไร ลำดับอย่างไร ร้องขอข้อมูลเพิ่มเติมจาก ผู้ใช้อย่างไร ได้ข้อมูลมาแล้วเอาไปไว้ไหนหรือเอาไปทำอะไรต่อ ประมาณนี้นะครับ ที่เหลือ อีกหลายๆ อย่าง เช่น ถ้าผู้ใช้กรอกไม่ถูกรูปแบบ จะทำอย่างไร อันนี้คุณมีนต้องไปเพิ่มเติมเอาเองนะครับ ถ้าเอาโค้ดนี้ไปใช้เลย แล้วปรากฎว่า ผู้ใช้อยากลองเล่น ด้วยการ ให้ข้อมูลมั่วๆ มาเช่นคีย์ .. ลงไปใน inputbox ก็เรียบร้อยเลยนะครับข้อมูลคุณมีน อาจเสียหายได้ ดังนั้น ต้องไปดักจับ ดักเช็คพวกนั้นด้วยอีกทีนะครับ
อืมม....
เอา OK เลยก็ได้ ไม่ต้อง yesno หรอก
if msgbox("ต้องการคัดลอกเรคคอร์ดหรือไม่")=vbOK then
หมายความว่า ถ้าเขากด OK ก็เข้าเงื่อนไข ให้ทำงานได้เลย
แต่ถ้าเขากดปิด msgbox หรือกด ESC ก็ไม่ต้องทำงาน
อ้อ แล้วก็ โค้ดที่ให้ไป มันจะทำงานถึงบรรทัดที่เน้นสีแดงนะครับ ให้ เปิด debug window ขึ้นมาตรวจดู (ctl+G) ประโยค sql ก่อนครับ ถ้าคิดว่ามันเขียนได้ถูกต้อง ค่อย เบรคบรรทัดนั้น แล้วปล่อย สองบรรทัดล่างนั่นได้เลย
ที่ทำอย่างนี้เพราะว่า โค้ดที่ให้ไป ผมเขียนสดผ่านการโพสต์นี่เลย ไม่ได้ทดสอบใดๆ เลยครับ คุณมีนลองเอาไปทดสอบแล้วปรับแก้ไป พอได้นะครับ
และ จริงๆ แล้ว โค้ดนี้มันไม่สมบูรณ์นะครับ ที่เขียนให้ก็คือ พอให้เห็นลำดับงาน ว่าเราจะทำการตรวจสอบเงื่อนไขอย่างไร ลำดับอย่างไร ร้องขอข้อมูลเพิ่มเติมจาก ผู้ใช้อย่างไร ได้ข้อมูลมาแล้วเอาไปไว้ไหนหรือเอาไปทำอะไรต่อ ประมาณนี้นะครับ ที่เหลือ อีกหลายๆ อย่าง เช่น ถ้าผู้ใช้กรอกไม่ถูกรูปแบบ จะทำอย่างไร อันนี้คุณมีนต้องไปเพิ่มเติมเอาเองนะครับ ถ้าเอาโค้ดนี้ไปใช้เลย แล้วปรากฎว่า ผู้ใช้อยากลองเล่น ด้วยการ ให้ข้อมูลมั่วๆ มาเช่นคีย์ .. ลงไปใน inputbox ก็เรียบร้อยเลยนะครับข้อมูลคุณมีน อาจเสียหายได้ ดังนั้น ต้องไปดักจับ ดักเช็คพวกนั้นด้วยอีกทีนะครับ
6 @R02002
ทดลองแล้ว โดยสั่ง docmd.runsql sqlStatement ด้วย
แต่ผลคือมี Msg box รับค่า แต่ในตาราง tcust ไม่มีข้อมูลดังกล่าวค่ะ
คือต้องการให้ นำข้อมูลที่ copy ไปไว้ในตาราง tCust ด้วยเลยค่ะ ต้องเขียน code อย่างไรเพิ่มอีกหรือไม่
แต่เท่าที่ลองตีความหมาย sqlStatement เป็นการ Update แล้วไม่ใช่หรือค่ะ
ส่วน "ใช้อยากลองเล่น ด้??ยการ ให้ข้อมูลมั่วๆ มาเช่นคีย์ .. ลงไปใน inputbox ก็เรียบร้อยเลยนะครับข้อมูลคุณมีน อาจเสียหายได้ ดังนั้น ต้องไปดักจับ ดักเช็คพวกนั้นด้วยอีกทีนะครับ" คงต้องศึกษาอีกนาน
แต่ผลคือมี Msg box รับค่า แต่ในตาราง tcust ไม่มีข้อมูลดังกล่าวค่ะ
คือต้องการให้ นำข้อมูลที่ copy ไปไว้ในตาราง tCust ด้วยเลยค่ะ ต้องเขียน code อย่างไรเพิ่มอีกหรือไม่
แต่เท่าที่ลองตีความหมาย sqlStatement เป็นการ Update แล้วไม่ใช่หรือค่ะ
ส่วน "ใช้อยากลองเล่น ด้??ยการ ให้ข้อมูลมั่วๆ มาเช่นคีย์ .. ลงไปใน inputbox ก็เรียบร้อยเลยนะครับข้อมูลคุณมีน อาจเสียหายได้ ดังนั้น ต้องไปดักจับ ดักเช็คพวกนั้นด้วยอีกทีนะครับ" คงต้องศึกษาอีกนาน
7 @R02009
ที่ให้ไปน่ะ เอาไปเอามา ก็มั่วเยอะเหมือนกันนะนั่น
เอาใหม่ อันนี้ได้ทดสอบมาบ้างแล้ว คิดว่าน่าจะได้ผลนะครับ ลองดูครับ
เอาใหม่ อันนี้ได้ทดสอบมาบ้างแล้ว คิดว่าน่าจะได้ผลนะครับ ลองดูครับ
Sub copyrec()
Dim srcCustID As String
Dim desCustID As String
Dim sqlStatement As String
If MsgBox("ต้องการคัดลอกเรคคอร์ดหรือไม่") = vbok Then
srcCustID = inputbox("ต้องการคัดลอกจากเรคคอร์ดใด")
If srcCustID <> "" Or Not isnull(srcCustID) Then
dscCustID = inputbox("ต้องการวางใส่เรคคอร์ดใด")
If dscCustID <> "" Or Not isnull(dscCustID) Then
If isnull(dlookup("CustID", "tCust", "[CustID] = '" & dscCustID & "'")) Then
sqlStatement = "INSERT INTO tCust ( CustID, DesA, phone )" _
& " SELECT '" & dscCustID & "' AS CustID, q.DesA, q.phone" _
& " FROM (" _
& " SELECT tCust.DesA, tCust.phone" _
& " FROM tCust" _
& " WHERE (tCust.CustID='" & srcCustID & "')" _
& " ) As q;"
ElseIf MsgBox("รหัสลูกค้านี้มีข้อมูลอยู่แล้ว" & vbCrLf & "คุณแน่ใจว่าต้องการปรับปรุงข้อมูล", vbQuestion + vbYesNo) = vbYes Then
sqlStatement = "Update tCust, (" _
& " Select tCust.DesA, tCust.Phone" _
& " From tCust" _
& " Where tCust.CustID ='" & srcCustID & "'" _
& " ) As q" _
& " Set tCust.DesA = q.DesA, tCust.Phone = q.Phone" _
& " Where tCust.CustID ='" & dscCustID & "';"
End If
'Debug.Print sqlStatement
DoCmd.SetWarnings False
DoCmd.RunSQL sqlStatement
End If
End If
End If
End Sub
8 @R02010
ได้แล้วค่ะ
แต่สงสัยอีกนิดค่ะ
Dim desCustID As String น่าจะเป็น
Dim dscCustID As String หรือปล่าวค่ะ เพราะด้านใน code ตัวแปรคือ dscCustID ไม่ใช่หรือค่ะ (แต่ทำไมไม่เกิด error ค่ะ)
ขอบคุณมากค่ะ
แต่สงสัยอีกนิดค่ะ
Dim desCustID As String น่าจะเป็น
Dim dscCustID As String หรือปล่าวค่ะ เพราะด้านใน code ตัวแปรคือ dscCustID ไม่ใช่หรือค่ะ (แต่ทำไมไม่เกิด error ค่ะ)
ขอบคุณมากค่ะ
9 @R02013
อ้อ ใช่ครับ ประกาศผิดครับ
ควรจะเปลี่ยนให้มันเหมือนกันซะ นะครับ จะดีกว่า
ที่มันไม่ error เพราะว่า ด้านบนสุดของโมดูลนี้ คุณไม่ได้ประกาศ Option Explicit
อย่าถามต่อนะ ว่ามันคืออะไร อิอิ ตอบไม่ได้จ้า
ควรจะเปลี่ยนให้มันเหมือนกันซะ นะครับ จะดีกว่า
ที่มันไม่ error เพราะว่า ด้านบนสุดของโมดูลนี้ คุณไม่ได้ประกาศ Option Explicit
อย่าถามต่อนะ ว่ามันคืออะไร อิอิ ตอบไม่ได้จ้า
10 @R02014
ขอบพระคุณมากค่ะ
11 @R04387
ขอถามหน่อยครับ
ถ้า ค่าของ CustID เป็น number แบบ long ต้องแก้ไข code ตรงไหนหรือไม่ ทดลองนำ code ไปใช้แล้ว แต่ทำไมไม่มีการ copy ข้อมูลเลยครับ
ขอบคุณครับ
ถ้า ค่าของ CustID เป็น number แบบ long ต้องแก้ไข code ตรงไหนหรือไม่ ทดลองนำ code ไปใช้แล้ว แต่ทำไมไม่มีการ copy ข้อมูลเลยครับ
ขอบคุณครับ
12 @R04390
ใน statement มันจะมี เครื่องหมาย single quote ครับ
โดยเฉพาะที่อ้างถึง"ฟิลด์" หรือ "ค่า" ของ ID
ให้เอามันออกครับ
โดยเฉพาะที่อ้างถึง"ฟิลด์" หรือ "ค่า" ของ ID
ให้เอามันออกครับ
13 @R04391
ขอบคุณครับ
ขอขอบคุณที่ทำ webboard ไว้ด้วยครับ ให้ความรู้และช่วยได้เยอะครับ
ขอขอบคุณที่ทำ webboard ไว้ด้วยครับ ให้ความรู้และช่วยได้เยอะครับ
Time: 0.3930s
คุณคิดออกมาอย่างมีหลักแล้ว คุณตีโจทก์ได้แตก เข้าใจกับโจทก์ ถ้าคุณแปร "กระบวนการคิด" ให้ออกมาในรูปสัญลักษณ์ แล้วก็จะได้ "กระบวนงาน"
1. ถามว่าจะต้องการลอกข้อมูลหรือไม่
2. ถามว่า ต้องการลอกข้อมูลจากเรคคอร์ดใด
3. ถามว่า ต้องการวางข้อมูลที่ลอกมา ใส่เรคคอร์ดใด
4. ถามว่า แน่ใจหรือไม่ ถ้าจะวางข้อมูลทับกับของเก่า
งานระหว่าง ข้อ2 กับข้อ 3 คือการสั่งให้โค้ดไปเอาข้อมูลที่ต้องการ
งานระหว่าง ข้อ3 กับข้อ 4 คือการตรวจสอบว่ามีเรคคอร์ดเลขที่ "นี้" หรือยัง
งาน หลังข้อ 4 คือการวางข้อมูลลงไปในตาราง
คุณมีนคิดว่าคุณมีนเอง ติดตรงกระบวนงานไหนครับ