تقييم الموضوع :
  • 0 أصوات - بمعدل 0
  • 1
  • 2
  • 3
  • 4
  • 5
احتاج كود لعمل نسخة من قاعدة بيانات اكسس اثناء الاتصال بها
#1
احتاج كود لعمل نسخة من قاعدة بيانات اكسس  عندما تكون مفتوحة او اثناء الاتصال بها.

انا استخدم     FileCopy  ولكن يلزم قطع الاتصال قبل النسخ.



هل يوجد طريقة 

------------------------------
الرد }}}}
تم الشكر بواسطة:
#2
اخوية العزيز اذا تحب تنسخ ملف اثناء استخدامة فلازم تستخدم نسخ الملف كBinary
PHP كود :
Private Sub cmdBackupDataBase_Click()
 
     Dim X As String
      Open App
.Path "\file.mdb" For Binary As #1
 
     Open App.Path "\file_Copy.mdb" For Binary As #2
 
     X String(LOF(1) - 1" ")
 
     Get #1, , X
 
     Put #2, , X
 
     Close
End Sub 
الرد }}}}
#3
أهلا بك أخي الكريم , جرب الثلاث طرق , الطريقة الأولى طريقة الأخ "محمد العبيدي" وهاذي طريقتين إضافيه :

- الطريقة الثانية : هي بإستخدام مكتبة الـ Microsoft Scripting Runtime حيث لابد أولا من إضافتها لمشروع برنامجك وذلك بالذهاب إلى قائمة "Project " أو "مشروع" في شاشة برنامج الفيجول بيسك ثم إختيار الأمر "References" أو "مراجع" ثم بعد ظهور الشاشة الخاصه بأسماء المكتبات إبحث عن إسم المكتبه التي بإسم  Microsoft Scripting Runtime ثم ضع علامة صح عليها ثم "OK" أو "موافق" ثم إستخدم الكود التالي :

PHP كود :
Private Sub Command1_Click()

Dim FSO As New FileSystemObject

FSO
.CopyFile "D:\db1.mdb""C:\db1.mdb"
DoEvents

Set FSO 
Nothing

End Sub 

- ملاحظه :- إذا إستخدمت الطريقة الثانية , يجب إرفاق ملف المكتبة المستخدمه وهو بإسم scrrun.dll يجب إرفاقه مع ملفات تثبيت برنامجك عند تحزيم ملفات برنامجك , وهذا الملف موجود في جهازك في هذا المسار : C:Windows\System32

- الطريقة الثالثة : وهي بإستخدام دالة API , قم بإضافة هذا الكود في أعلى كود الفورم الذي تريد إستخدام كود النسخ فيه :

PHP كود :
Private Declare Function CopyFile Lib "kernel32" Alias "CopyFileA" _
       
(ByVal lpExistingFileName As StringByVal lpNewFileName As String_
       ByVal bFailIfExists 
As Long) As Long

Private Function CopyFileA(OldFileName As StringNewFileName As String) As Boolean
On Error Resume Next
Err.Clear

If CopyFile(OldFileNameNewFileNameFalse) <> 1 Then
   CopyFileA 
False
Else
 
  CopyFileA True
End 
If

End Function 

ثم إستخدم كود النسخ في المكان الذي تريد في الفورم هكذا :

PHP كود :
Private Sub Command1_Click()

If 
CopyFileA("D:\db1.mdb""C:\db1.mdb") = True Then
   MsgBox 
"تم النسخ بنجاح"
Else
 
  MsgBox "لم يتم النسخ"
End If

End Sub 
الرد }}}}
#4
(31-10-16, 10:13 PM)محمد العبيدي كتب : اخوية العزيز اذا تحب تنسخ ملف اثناء استخدامة فلازم تستخدم نسخ الملف كBinary
PHP كود :
Private Sub cmdBackupDataBase_Click()
 
     Dim X As String
      Open App
.Path "\file.mdb" For Binary As #1
 
     Open App.Path "\file_Copy.mdb" For Binary As #2
 
     X String(LOF(1) - 1" ")
 
     Get #1, , X
 
     Put #2, , X
 
     Close
End Sub 


الف الف شكر اخي الكريم الغالي / [b]محمد العبيدي[/b]

الله يحفظك ويجزيك الف خير

(01-11-16, 01:47 AM)Ahmed_Mansoor كتب : أهلا بك أخي الكريم , جرب الثلاث طرق , الطريقة الأولى طريقة الأخ "محمد العبيدي" وهاذي طريقتين إضافيه :

- الطريقة الثانية : هي بإستخدام مكتبة الـ Microsoft Scripting Runtime حيث لابد أولا من إضافتها لمشروع برنامجك وذلك بالذهاب إلى قائمة "Project " أو "مشروع" في شاشة برنامج الفيجول بيسك ثم إختيار الأمر "References" أو "مراجع" ثم بعد ظهور الشاشة الخاصه بأسماء المكتبات إبحث عن إسم المكتبه التي بإسم  Microsoft Scripting Runtime ثم ضع علامة صح عليها ثم "OK" أو "موافق" ثم إستخدم الكود التالي :

PHP كود :
Private Sub Command1_Click()

Dim FSO As New FileSystemObject

FSO
.CopyFile "D:\db1.mdb""C:\db1.mdb"
DoEvents

Set FSO 
Nothing

End Sub 

- ملاحظه :- إذا إستخدمت الطريقة الثانية , يجب إرفاق ملف المكتبة المستخدمه وهو بإسم scrrun.dll يجب إرفاقه مع ملفات تثبيت برنامجك عند تحزيم ملفات برنامجك , وهذا الملف موجود في جهازك في هذا المسار : C:Windows\System32

- الطريقة الثالثة : وهي بإستخدام دالة API , قم بإضافة هذا الكود في أعلى كود الفورم الذي تريد إستخدام كود النسخ فيه :

PHP كود :
Private Declare Function CopyFile Lib "kernel32" Alias "CopyFileA" _
       
(ByVal lpExistingFileName As StringByVal lpNewFileName As String_
       ByVal bFailIfExists 
As Long) As Long

Private Function CopyFileA(OldFileName As StringNewFileName As String) As Boolean
On Error Resume Next
Err.Clear

If CopyFile(OldFileNameNewFileNameFalse) <> 1 Then
   CopyFileA 
False
Else
 
  CopyFileA True
End 
If

End Function 

ثم إستخدم كود النسخ في المكان الذي تريد في الفورم هكذا :

PHP كود :
Private Sub Command1_Click()

If 
CopyFileA("D:\db1.mdb""C:\db1.mdb") = True Then
   MsgBox 
"تم النسخ بنجاح"
Else
 
  MsgBox "لم يتم النسخ"
End If

End Sub 

عاجز عن الشكر استاذي الفاضل / Ahmed_Mansoor

الله يطول بعمرك ويجزيك الف خير 
الرد }}}}
تم الشكر بواسطة: Amir_alzubidy , Ahmed_Mansoor


المواضيع المحتمل أن تكون متشابهة .
الموضوع : الكاتب الردود : المشاهدات : آخر رد
  كيفية ربط قاعدة البيانات القوائم المنسدلة bidaya 12 138 أمس, 01:54 PM
آخر رد: bidaya
  فتح برنامج مبرمج بالفيجوال بيسك6 و قاعدة بيانات MYSQL Ahmed Salem12 1 57 01-12-16, 03:40 PM
آخر رد: sendbad100
  [سؤال] احتاج مساعده في برنامج موعد الحضور والانصراف mera 6 311 30-11-16, 10:59 PM
آخر رد: فاطمة غ
  [سؤال] برجاء المساعده في تغيير إسم جدول في قاعدة بيانات SQl Server بالفيجول بيسك6 engabuhema 2 57 24-11-16, 01:49 AM
آخر رد: ahmedabdelaliem
  [سؤال] ما هي افضل طريقة لعمل نسخة تجريبية لبرنامج مبيعات sendbad100 2 97 19-11-16, 12:45 PM
آخر رد: sendbad100
  مشكلة : قاعدة بيانات البرنامج بعد التنصيب لا تصبح بشكل ملف للقراءة فقط haiderkh 3 99 10-11-16, 12:56 AM
آخر رد: Ahmed_Mansoor
  [سؤال] احتاج مساعده في كيفيه زياده رقم على مدخل mera 4 132 08-11-16, 03:05 AM
آخر رد: mera
  [سؤال] اظهار بيانات Combo1 في Text iisys 3 170 07-11-16, 06:16 AM
آخر رد: AL_BRNS
  [سؤال] رفع فيديو في قاعدة البيانات jihad20003000 0 56 04-11-16, 02:35 PM
آخر رد: jihad20003000
  البحث المتقدم في قاعدة بيانات اكسس haniblack 4 142 31-10-16, 10:00 PM
آخر رد: moamen said

التنقل السريع :


يقوم بقرائة الموضوع: بالاضافة الى ( 1 ) ضيف كريم