Page 1 of 1

กรณีแชร์ไฟล์แล้วคีย์ข้อมูลชนกันครับ

Posted: Mon Aug 13, 2018 4:35 am
by sakajohn
รบกวนสอบถามครับ ผมแชร์ไฟล์ DataBase ไว้ โดยให้แต่ละ user ทำการบันทึกข้อมูลต่อกันลงไปเรื่อยๆ โดยให้เปิดไฟล์ขึ้นมาแล้วทำการบันทึก เมื่อบันทึกเสร็จให้saveและปิดไฟล์ แต่มีบางครั้งที่ User บันทึกข้อมูลใน Cell เดียวกันทำให้เกิด error ไม่สามารถบันทึกไฟล์ได้ ถ้าปิดไฟล์ DataBaseไป มันก็จะไปเริ่มคำสั่งใหม่ตั้งแต่ต้น ผมต้องการว่า ถ้าเกิด Error ให้แต่ละคนกลับมาบันทึกข้อมูลใหม่ ตรงคำสั่ง บันทึกงาน Databaseแค่นั้นครับ ผมจะต้องแก้ไข code อย่างไรครับ พอดีไฟล์งานใหญ่เลยไม่ได้แนบมาด้วยครับ

Code: Select all

Sub Macro1()
' Macro1 Macro
'

'
Dim rg As Range

Set rg = Range("T9")
Set rg = Range("U17")

rg.Activate
If Application.CountA(Range("T9")) = 0 Then
    MsgBox "กรุณากรอกข้อมูลให้ครบ"
    Exit Sub
End If
rg.Activate
If Application.CountA(Range("U17")) = 0 Then
    MsgBox "กรุณาระบุสถานที่ส่งของ"
    Exit Sub
End If
Dim x As Integer
    x = MsgBox("ต้องการพิมพ์ใบจ่ายงาน ใช่หรือไม่", vbOKCancel)
    If x = vbCancel Then
    Sheets("sheet2").Select
    Else
MsgBox "ใส่ใบจ่ายงานด้วยครับ"
ActiveSheet.Unprotect Password:="1234"
Range("L56") = Range("L56") + 1
If Range("AC10").Value <> 0 Then
MsgBox ("รหัสซ้ำ กรุณาสั่งพิมพ์อีกครั้ง"), vbCritical
Exit Sub
Else

'บันทึก SaleData
   Application.Goto Reference:= _
        "OFFSET(R9C30,1,0,COUNTIF(C34,"">0""),COUNTA(R9)-4)"
    Selection.Copy
    Workbooks("SaleData.xlsx").Activate
    Sheets("NOI").Select
    Application.Goto Reference:="OFFSET(R1C1,COUNTA(C1),0)"
    Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _
        :=False, Transpose:=False
    Application.CutCopyMode = False
    ActiveWorkbook.Save
ThisWorkbook.Activate
     
     'บันทึกงาน DataBase
    Application.Goto Reference:= _
        "OFFSET(R9C30,1,0,COUNTIF(C34,"">0""),COUNTA(R9)-4)"
    Selection.Copy
    Workbooks.Open Filename:="\\ACCOUNT\Data (D)\SALE\DataBase.xlsx"
    Sheets("Sheet1").Select
    Application.Goto Reference:="OFFSET(R1C1,COUNTA(C1),0)"
    Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _
        :=False, Transpose:=False
    Application.CutCopyMode = False
    ActiveWorkbook.Save
    ActiveWorkbook.Close
    
    
   
   ActiveSheet.PageSetup.PrintArea = "$A$1:$W$60"
    Application.ActivePrinter = "NOI on Ne00:"
    ActiveWindow.SelectedSheets.PrintOut Copies:=3, ActivePrinter:= _
            "NOI on Ne00:", Collate:=True, IgnorePrintAreas:=False
    'ActiveWindow.SelectedSheets.PrintOut Copies:=3
    
    
    Range("t9,e15,I18,P18,T18,I22,P22,T22,I26,P26,T26,I30,P30,T30,I34,P34,T34,I38,P38,T38,N44,N46,N48,N5,U17").Select
    Range("t9,e15,I18,P18,T18,I22,P22,T22,I26,P26,T26,I30,P30,T30,I34,P34,T34,I38,P38,T38,N44,N46,N48,N50,U17").Activate
    Selection.ClearContents
    Range("i18").Select
    ActiveSheet.Protect Password:="1234"
    MsgBox ("บันทึกข้อมูลเรียบร้อย"), vbInformation
    End If

Re: กรณีแชร์ไฟล์แล้วคีย์ข้อมูลชนกันครับ

Posted: Mon Aug 13, 2018 6:27 am
by snasui
:D การบันทึกข้อมูลไปยังไฟล์ที่ Shared ไว้ ไม่ควรจะเกิด Error ครับ

การ Shared ไฟล์สามารถทำงานพร้อมกันได้ถึง 255 คน

วิธีการ Shared ที่ถูกต้องสำหรับไฟล์ Database คือ เข้าเมนู Review > Share Workbook > เลือก Allow change by more than one user...

วิธีที่ถูกต้องสำหรับการบันทึกคือ ใช้ Code เปิดไฟล์ Database นี้ขึ้นมา > Save > บันทึก > Save > Close

สังเกตว่าจะมีการ Save ก่อนหนึ่งครั้งแล้วค่อยบันทึก ทั้งนี้เพื่อให้ข้อมูลในไฟล์ Database เป็นข้อมูลที่ถูกบันทึกมาล่าสุดเพราะคนอื่นอาจจะทำงานอยู่ด้วยและทำการบันทึกก่อนเราจะบันทึก เราจะได้บันทึกต่อจากนั้นไม่ใช่บันทึกทับกับของคนอื่น

กรณีไฟล์ใหญ่ ให้ Save As ไปเป็นไฟล์สำรองแล้วตัดมาเฉพาะที่เกี่ยวข้องกับคำถามนี้เท่านั้น ไม่จำเป็นต้องส่งไฟล์ต้นฉบับมาครับ

Re: กรณีแชร์ไฟล์แล้วคีย์ข้อมูลชนกันครับ

Posted: Mon Aug 13, 2018 7:22 pm
by sakajohn
ถ้าผมแก้เป็นแบบนี้ถูกต้องมั้ยครับ

Code: Select all

'บันทึกงาน DataBase
    Application.Goto Reference:= _
        "OFFSET(R9C30,1,0,COUNTIF(C34,"">0""),COUNTA(R9)-4)"
    Selection.Copy
    Workbooks.Open Filename:="\\ACCOUNT\Data (D)\SALE\DataBase.xlsx"
    ActiveWorkbook.Save
    Sheets("Sheet1").Select
    Application.Goto Reference:="OFFSET(R1C1,COUNTA(C1),0)"
    Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _
        :=False, Transpose:=False
    Application.CutCopyMode = False
    ActiveWorkbook.Save
    ActiveWorkbook.Close

Re: กรณีแชร์ไฟล์แล้วคีย์ข้อมูลชนกันครับ

Posted: Mon Aug 13, 2018 7:53 pm
by snasui
:D วิธีการที่ผมแจ้งไปครอบคลุมไปถึงการเปิดไฟล์ Database ค้างไว้และปิดเมื่อเสร็จงานแล้ว แต่หากว่าในการทำงานจริงเป็นการเปิดแล้วบันทึกทันที ความจำเป็นในการ Save ก่อนที่จะบันทึกก็จะน้อยลงไป แต่ทำไว้ด้วยก็ไม่เสียหายอะไร

จาก Code ที่เขียนมาลองนำไปทดสอบใช้งานดูแล้วสังเกตว่าได้ผลหรือไม่อย่างไร ติดตรงไหนค่อยนำมาถามกันต่อครับ

Re: กำหนด Format cell ไม่ให้เปลี่ยน

Posted: Sun Aug 19, 2018 1:00 am
by sakajohn
snasui wrote: Sat Aug 18, 2018 5:27 pm :D เรื่องการ Share File ผมหมายถึงให้กลับไปถามตอบกันในกระทู้นี้ครับ viewtopic.php?f=3&t=14009

ในการใช้งานจริงได้มีการกำหนดการ Shared ให้กับไฟล์ DataBase.xlsx หรือไม่ครับ ไฟล์ที่แนบมายังไม่ได้กำหนด ช่วยกำหนดมาให้ด้วยครับ

ปกติแชร์ไฟล์ไว้ครับ

Re: กรณีแชร์ไฟล์แล้วคีย์ข้อมูลชนกันครับ

Posted: Sun Aug 19, 2018 7:09 am
by snasui
:D ตัวอย่างการปรับ Code ครับ

Code: Select all

'Other code...
    Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _
        :=False, Transpose:=False
On Error GoTo SaveAgain
    Err.Clear ' or Err = 0
    ActiveWorkbook.Save
    ActiveWorkbook.Close
    ThisWorkbook.Activate
SaveAgain:
    If Err <> 0 Then Resume
    'สั่งพิมพ์
    Range("Q13:W13").Select
    With Selection.Font
'Other code...