10-11-15, 01:07 PM
(16-12-12, 07:08 PM)hago كتب :☼ فى حدث الــ Form_Load :![]()
![]()
اخي haggggggo .. جزززاك ربي خيرررا .. لكن لدي سؤال ..اذا استخدمت ال ADO & DataGrid control
للرررربط .. هل من الممكن كتابة نفس الاكواد؟؟لكن مع تغيير الكلمة الموجوده بالكووود من flexGrid ???????
اعضاء المنتدى الكريم بعد السلام والتحية** يتم التطبيق فى درسنا هذا على دليل هاتف مصغر لتسهيل عمليه الشرح والفهم **
لعل الكثير من المبرمجون المبتدئين يتسالون عن الاختلاف بين ادوت الربط المحتلفة وايهما افضل وكثر الحديث عن ذلك فالأغلبية الشائعة فى هذا المنتدى يستخدم طريقة الربط عبر الكود البرمجى نسبة لسهولتها فى تحقيق الهدف المنشود
لا اطيل الحديث كثيرا فموضوعنا يتكلم عن كيفية ربط البرنامج بالاكسس عن طريق الكود مع العمليات المختلفة فى قواعد البيانات مثل :
الاضاف - والحفظ - والتعديل - والحذف - ووضع النتيجة على اداة العرض MSFlexGrid
نبدأ الشرح
أنشئ قاعدة بيانات اكسس وسميها Telephone وإنشئ ايضاً جدول وسميه Tabel1 ثم اضف ثلاث حقول :رقمى = Num
نصى = Nme
رقمى = Phone
![]()
متطلبات البرنامج :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 :
كود :
Dim db As New ADODB.Connection
Dim rs As New ADODB.Recordset
Dim sql As 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
☼ إضغط دبل كليك على الاداة MSFlexGrid واكتب الكود التالى فى حدث MSFlexGrid1_Clickكود :
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 بالنسبة للربط من خلال شاشة الخصائص .
تمتع بخصائص الاداتين معاً
اسأل الله العلى العظيم ان اكون قد وفقنى فى موضوعى هذا متمنياً لكم مزيداً من التقدم
وفى النهاية : اذا الشرح جيد وعجبكم فهو من عند الله اما غير هذا فهو من عندى

