اعضاء المنتدى الكريم بعد السلام والتحية
لعل الكثير من المبرمجون المبتدئين يتسالون عن الاختلاف بين ادوت الربط المحتلفة وايهما افضل وكثر الحديث عن ذلك فالأغلبية الشائعة فى هذا المنتدى يستخدم طريقة الربط عبر الكود البرمجى نسبة لسهولتها فى تحقيق الهدف المنشود
لا اطيل الحديث كثيرا فموضوعنا يتكلم عن كيفية ربط البرنامج بالاكسس عن طريق الكود مع العمليات المختلفة فى قواعد البيانات مثل :
الاضاف - والحفظ - والتعديل - والحذف - ووضع النتيجة على اداة العرض MSFlexGrid
** يتم التطبيق فى درسنا هذا على دليل هاتف مصغر لتسهيل عمليه الشرح والفهم **لعل الكثير من المبرمجون المبتدئين يتسالون عن الاختلاف بين ادوت الربط المحتلفة وايهما افضل وكثر الحديث عن ذلك فالأغلبية الشائعة فى هذا المنتدى يستخدم طريقة الربط عبر الكود البرمجى نسبة لسهولتها فى تحقيق الهدف المنشود
لا اطيل الحديث كثيرا فموضوعنا يتكلم عن كيفية ربط البرنامج بالاكسس عن طريق الكود مع العمليات المختلفة فى قواعد البيانات مثل :
الاضاف - والحفظ - والتعديل - والحذف - ووضع النتيجة على اداة العرض MSFlexGrid
نبدأ الشرح
أنشئ قاعدة بيانات اكسس وسميها Telephone وإنشئ ايضاً جدول وسميه Tabel1 ثم اضف ثلاث حقول :
رقمى = Num نصى = Nme
رقمى = Phone
متطلبات البرنامج :
(3 ليبل) *(3 تكست)*(4 كوماند)*(1 اداة عرض MSFlexGrid)
الادوات الثلاث الاولى موجودة لاضافة اداة العرض MSFlexGrid اتبع الاتى :
References --->> Compontes --->> Microsift FlixGrid Control 6.0(3 ليبل) *(3 تكست)*(4 كوماند)*(1 اداة عرض MSFlexGrid)
الادوات الثلاث الاولى موجودة لاضافة اداة العرض MSFlexGrid اتبع الاتى :
* تم تقسيم الشرح على ثلاثة اجزاء :
ارسم الادوات على الفورم وغير التسمية كالاتى :
الرقم = Label1الإسم = Label2
رقم الهاتف = Label3
♦ ♦ ♦ ♦ ♦ ♦ ♦ ♦
إضافة = Command1
حفظ = Command2
تعديل = Command3
حذف = Command4
خروج = Command5
من خصائص الــ MSFlexGrid إجعل الخصاية Right ToLeft = True
ليكون تصميم النموزج او الفورم على هذا الشكل :
** او إختر مايناسبك فى تصميم النموزج **
الجزء الثانى : أداة ربط قاعدة البيانات Ado
نضيف اداة الاتصال بقاعدة البيانات :
من الخصائص اذهب فى الاعلى الى قائمة Project ومن ثم اختر References وابحث عن Microsoft ActiveX Data Obiects 2.8 Libray او اى اصدارة من الاصدارات الخمسة الاخرى
☼ أنشئ ثلاث متغيرات فى قسم التصريحات General Declarations :
من الخصائص اذهب فى الاعلى الى قائمة Project ومن ثم اختر References وابحث عن Microsoft ActiveX Data Obiects 2.8 Libray او اى اصدارة من الاصدارات الخمسة الاخرى
☼ أنشئ ثلاث متغيرات فى قسم التصريحات General Declarations :
كود :
Dim db As New ADODB.Connection
Dim rs As New ADODB.Recordset
Dim sql As String
السطر الاول : للاتصال بقاعدة البيانات
السطر الثانى : للاتصال بالجدوال فى قاعدة البياناتالسطر الثالث : تعريف متغير منوع String
السطر الثانى : للاتصال بالجدوال فى قاعدة البياناتالسطر الثالث : تعريف متغير منوع String
كود :
If db.State = 1 Then db.Close
db.CursorLocation = adUseClient
db.Provider = "Microsoft.Jet.OLEDB.4.0;"
db.Open App.Path & "\Telephone.mdb"
Call Filldata
السطر الثانى : هنا التعامل مع جهاز واحد فقط
السطر الثالث : هو المزود الخاص بقواعد بيانات من نوع اكسس
السطر الرابع : هنا فتحنا الاتصال بقاعدة البيانات Telephone المتواجدة فى مجلد البرنامج
السطر الخامس: هو استدعاء لــ Sub من خلاله يتم ملئ البيانات من قاعدة البيانات ووضع التيجة فى اداة العرض MSFlexGrid
ويكون الكود كالتالى :
كود :
Sub Filldata()
If rs.State = 1 Then rs.Close
rs.Open "Tabel1", db, adOpenStatic, adLockPessimistic
MSFlexGrid1.Rows = rs.RecordCount + 1
MSFlexGrid1.Cols = 3
MSFlexGrid1.ColWidth(0) = 800
MSFlexGrid1.ColWidth(1) = 3500
MSFlexGrid1.ColWidth(2) = 3100
MSFlexGrid1.ColAlignment(-1) = 3
MSFlexGrid1.TextMatrix(0, 0) = "الرقم"
MSFlexGrid1.TextMatrix(0, 1) = "الإســـــــــــم"
MSFlexGrid1.TextMatrix(0, 2) = "رقم الهـــــــــاتف"
For i = 1 To rs.RecordCount
MSFlexGrid1.TextMatrix(i, 0) = rs!Num
MSFlexGrid1.TextMatrix(i, 1) = rs!Nme
MSFlexGrid1.TextMatrix(i, 2) = rs!Phone
rs.MoveNext
Next
End Sub
السطر الثانى : فتح الجدول
السطر الثالث : هنا اخبرنا اداة العرض ان عدد صفوفها هو عدد السجلات +1 والعدد 1 هو لصف العمود
السطر الرابع : عدد الاعمدة يساوى 2
من السطر الخامس الى السطر الثامن : ضبط عرض الخلايا والمحاذاة
من السطر التاسع الى السطر الحادى عشر : تسمية الاعمدة
اما السطور الاخيرة : عملنا حلقة تكرار تبدأ من (1) الى عدد السجلات ونعطى جدول البيانات المرور للسجل التالى لكى لاتتكرر السجلات ومن ثم نهاية الحلقة
☼ عمل Sub :
كود :
Sub ClearAll()
Text1.Text = ""
Text2.Text = ""
Text3.Text = ""
Text1.SetFocus
End Sub
☼ فى كود الإضافة :
كود :
Call ClearAll
كود :
If rs.State = 1 Then rs.Close
sql = "select * from Tabel1 where Num =" & Text1.Text & ""
rs.Open sql, db, adOpenKeyset, adLockOptimistic
If rs.EOF Then
rs.AddNew
rs![Num] = Text1.Text
rs![Nme] = Text2.Text
rs![Phone] = Text3.Text
rs.Update
MsgBox " تمت عمليه الحفظ بنجاح", vbInformation
Call ClearAll
Call Filldata
Else
MsgBox " هذا الرقم موجود مسبقاً", vbCritical
Text1.SetFocus
End If
☼ كود التعديل :
كود :
If rs.State = 1 Then rs.Close
sql = " select * from Tabel1 where Num =" & Text1.Text & ""
rs.Open sql, db, adOpenKeyset, adLockPessimistic
rs![NON] = Text1.Text
rs![Nme] = Text2.Text
rs![Phone] = Text3.Text
rs.Update
MsgBox " تمت عمليه التعديل بنجاح", vbInformation
Call ClearAll
Call Filldata
كود :
If rs.State = 1 Then rs.Close
sql = "Delete * from Tabel1 where Num =" & Text1.Text & ""
rs.Open sql, db, adOpenKeyset, adLockOptimistic
MsgBox " تمت عمليه الحذف بنجاح", vbInformation
Call ClearAll
Call Filldata
كود :
Text1.Text = MSFlexGrid1.TextMatrix(MSFlexGrid1.Row, 0)
Text2.Text = MSFlexGrid1.TextMatrix(MSFlexGrid1.Row, 1)
Text3.Text = MSFlexGrid1.TextMatrix(MSFlexGrid1.Row, 2)
الان اعمل Run وشوف النتيجة
إضافة بسيطة :
بالنسبة للإخوة اللذين يعتمدون على أداة Adodc في التعامل مع قاعدة البيانات لن يتمكنوا من عرض محتويات الجداول داخل MsFlexGrid ، لأن MsFlexGrid لا تدعم أداة Adodc ولكن تدعم أداة Data لربط قاعدة البيانات .
الحل :
اذا كنت تريد العمل على اداة Adodc لربط قاعدة البيانات وفي نفس الوقت تربط FlexGrid بها والاستغناء عن الـ DataGrid ؛ - للاستفادة من تلوين الاعمدة او الصفوف وما الى ذلك - ، قم بتنفيذ نفس الخطوات التي ذكرها اخي الكريم الفاضل hago بالنسبة لإضافة اداة Microsoft FlexGrid Control 6.0 .
ولكن ..
هذه المره اختر Microsoft Hierarchical FlexGrid Control 6.0 ( OLEDB .
وهي اداة مطابقة لـ MsFlexGrid ولها نفس الخصائص إلا انها تدعم اداة Adodc بالنسبة للربط من خلال شاشة الخصائص .
تمتع بخصائص الاداتين معاً
اسأل الله العلى العظيم ان اكون قد وفقنى فى موضوعى هذا متمنياً لكم مزيداً من التقدم
وفى النهاية : اذا الشرح جيد وعجبكم فهو من عند الله اما غير هذا فهو من عندى
سبحان الله وبحمده سبحان الله العظيم
آللهم لگ آلحمد حتى ترضى .. ولگ آلحمد إذا رضيِت .. ولگ آلحمد بعد آلرضآ
آللهم لگ آلحمد حتى ترضى .. ولگ آلحمد إذا رضيِت .. ولگ آلحمد بعد آلرضآ