![]() |
|
مقال- كيفية الاستغناء عن الداتا بيز التقليدية في برامجنا – ألجزء الأول - نسخة قابلة للطباعة +- منتدى فيجوال بيسك لكل العرب | منتدى المبرمجين العرب (http://vb4arb.com/vb) +-- قسم : قسم لغة الفيجوال بيسك VB.NET (http://vb4arb.com/vb/forumdisplay.php?fid=182) +--- قسم : قسم مقالات VB.NET (http://vb4arb.com/vb/forumdisplay.php?fid=184) +--- الموضوع : مقال- كيفية الاستغناء عن الداتا بيز التقليدية في برامجنا – ألجزء الأول (/showthread.php?tid=5232) |
مقال- كيفية الاستغناء عن الداتا بيز التقليدية في برامجنا – ألجزء الأول - RaggiTech - 06-10-12 كاتب الموضوع : silverlight
مقال: كيفية الاستغناء عن الداتا بيز التقليدية في برامجنا – ألجزء الأولاللغة المستخدمة: الفيجوال بيسك التطبيق: فيجوال استوديو 2005 و 2008 المستوي: التقييم متروك للقارئ إعداد: مهندس / عمر أمين إبراهيم في الواقع سبب كتابة هذا المقال أنني قد لاحظت ان الكثير من الزملاء وخصوصا المبتدئين في عالم البرمجة يعانون قليلا مع الداتا بيز لذلك ارد أن أوضح لهم كيف يمكن الإستغناء عن الداتا بيز التقليدية واستبدالها بطرق أخري عندما نريد تخزين أو تجميع ثم استعادة بيانات بشكل عام فإن أول شئ سوف يخطر ببالنا هو استخدام الداتا بيز وبناء ملفات ببرامج الداتا بيز الشهيرة ومن ثم نقوم بربطها ببرامجنا ونتعامل معها من حيث عرض وتخزين واسترجاع البيانات الموجودة في الداتا بيز ومن أشهر الأنظمة التي نستخدمها في برامج الداتا بيز هي SQL, MS Access, and Oracle بالإضافة الي بعض النظم الاخري مثل FireBird و MySQL و PostgreSQL وسنلاحظ هنا أن مايكروسوفت تملك نظامين مختلفين وهما الأكسس و SQL السؤال: هل نحن بحاجه إلي التعامل مع تلك الأنظمة؟ و هل نحن بحاجه الي الاعتماد كليا علي مثل هذه الأنظمة في برامجنا؟ هل يمكن الاستغناء عن تلك الأنظمة؟ في الواقع إجابة مثل هذه الأسئلة مرتبط بك عزيز القارئ وبكيفية الطريقة التي تفكر بها وأيضا مرتبط مع شئ أخر مهم جدا هو قدراتك البرمجية وقدراتك علي التنويع والتخطيط ومن ثم تحديد ما تحتاجه بالفعل أو ما يحتاجه البرنامج الذي تكتبه في الواقع إن استخدام الداتا بيز في برامجنا سوف يضيف نوع من الصعوبة الي البرنامج الذي تصممه وهذا قد يؤدي الي شيئين لا ثالث لهما إما أن يكون البرنامج ناجحا أو فاشلا والسبب أنه عليك أن تتعامل مع أشياء كثيرة مثل Security و database Structure و كيفية الدخول الي الداتا بيز واستدعاء البيانات ثم عرضها ثم تخزينها مرة أخري إلي أخر مثل هذه الأشياء. ولكي لا نبخس ملفات الداتا بيز حقها تماما فإنه أحيانا يكون استخدام الداتا بيز هو أفضل اختيار ممكن استخدامه في عرض وتخزين البيانات داخل برامجنا لكن كل ذلك يعتمد علي حاجة البرنامج الذي نصممه وهل البيانات التي نتعامل معها كثيرة جدا أو تحديدا هل هي من النوع الي يطلق عليه Complex database عموما كل ذلك يعتمد علي الغرض من البرنامج الذي تصممه. أيضا هناك سؤال هام جدا علينا أن نسأله لأنفسنا وهو ماذا كان يفعل المبرمجون قبل وجود برامج مثل Oracle وMS Access و SQL وغيرهم. من المؤكد أنه كانت هناك طرق أخري لعرض البيانات بدون الحاجة إلي استخدام مثل هذه الأنظمة. عموما علينا أن لا ننسي أن هناك طرق أخري من الممكن إسخدامها لعرض البيانات وهي سوف تعوضنا عن استخدام الداتا بيز ومن هذه الطرق استخدام XML و Serialization و Text Files و Binary Files الي أخره من مثل هذه الأشياء ولكي لا أطيل عليك عزيز القارئ هيا بنا نكتشف كيفية الاستغناء عن ملفات الداتا بيز التقليدية ولنبدأ هنا بأسهل الطرق وهي عرض البيانات التي هي عبارة عن Read-Only وهي البيانات التي من الممكن إضافتها الي برامجنا كنوع من الداتا بيز ولكن ليس علي المستخدم التعديل بها الجزء الأول: عرض البيانات ReadOnly لنفتح مشروعا جديدا في الفيجوال استوديو ونطلق عليه dbReadsOnly مثلا ثم نضيف الي المشروع Class سوف نطلق عليه Students مثلا. طبعا ممكن إضافة الكلاس بشكل منفرد الي المشروع من قائمة Projects واختيار Add Class كما هوا موضح بالكود أدناه وهذه هي الطريقة الأفضل كود : Public Class Studentsكود : Public Class Form1طبعا من الممكن أن نضيف أي عدد من المتغيرات الأخري لكن لكي نعقد الأمر كثيرا سنضيف فقط المتغيرات التالية وهي ستكتب بالشكل التالي داخل الكلاس Students وكما تلاحظون أضفتها داخل Region Directive كنوع من التنظيم للكود ليس إلا كود : Public Class StudentsPublic Property FirstName () As String ثم نضغط علي مفتاح Enter وسيقوم الفيجوال استوديو بإضافة باق الكود بمجرد الضغط علي مفتاح Enter أي انه يضيف لها Get و End Get ثم (ByVal value As String) Set ثم End Set ثم أخيرا End Property وسيكون شكل Property كالأتي وهي كما نري لا تسترجع أي قيمة حتى الأن كود : Public Property FirstName() As Stringكود : Public Property FirstName() As Stringكود : Public Class Studentsسنلاحظ في الكلاس أعلاه أن هناك صفة قد تم إضافتها علي أنها Read Only Property وهي الصفة الخاصة بالاسم كاملا والهدف منها أننا لن نضيفها ولكنه ستظهر اتوماتيكيا داخل الفورم أو الكونترول الذي سوف نستخدمه لعرض البيانات وسيتم ذلك بمجرد تعريف المتغيران اللذان يعبران عن الاسم الأول والاسم الثاني علي التوالي أيضا سنلاحظ أننا قد أضفنا الكثير من Constructor الي الكلاس لتوضيح فقط كيف يتم ذلك الأن كيف نربط الكلاس Students ونستخدمه في عرض بيانات داخل الفورم تختلف عملية الربط بين الكلاس Students و الفورم بناء علي نوع الكونترول الذي سوف نستخدمه في إظهار البيانات للمستخدم وسوف أعطي أكثر من مثال لكي يتضح الأمر للقارئ طبعا أفترض أن قارئ هذا المقال لدية خلفية جيده في التعامل مع الكونترول المختلفة الموجودة داخل الفيجوال استوديو مثل الكومبوبوكس ComboBox و الداتا جريد فيو DataGridView و اللست بوكس ListBox إلي أخره من الكونترول مقال- كيفية الاستغناء عن الداتا بيز التقليدية في برامجنا – ألجزء الأول - RaggiTech - 06-10-12 مثال رقم 1 كيفية استخدام الكلاس Students مع DataGridView كل ما علينا فعله أن نضيف الي الفورم DataGridView Control وفي الحدث Load الخاص بالفورم نقوم بربط وتعريف الكلاس Students علي أنه DataSource الذي يخص هذا DataGridView ومن ثم نضع الأسماء والأرقام المسلسلة في Array والكود التالي يوضح كيفية ربط الكلاس مع DataGridViw1 التي أضفناها الي الفورم كود : Public Class Form1من الملاحظات الطريفة جدا في الكود اعلاه هو ترتيب الصفات Properties سنجد أن أول صفة هي الرقم المسلسل ID ثم الإسم الثاني ثم الإسم الأول ثم الإسم كاملا في الواقع هذا الترتيب مهم جدا وستري السبب عزيزي القارئ عندما نحاول أن نربط الكلاس Students مع بعض الكونترول وتحديدا DataGridView ستكتشف أن DatagridView سيعرض كل Property طبقا لترتيبها في الكلاس Students من الملاحظات الطريفة أيضا سنجد أن DataGridView كونترول يعرض الأسماء في Header Columns كما تم كتابتها مثلا يعرض كلمة FullName كما هي إذن كيف نقوم بإظهار أسماء الأعمدة بشكل صحيح لمن تابع الدروس الخاصة بموضوع تطوير الكونترول وتحديدا الموضوع الذي تحدثنا فيه عن Property Attributes ولقد ذكرت في هذا الموضوع أحد Attributes الهامة وهي DisplayName Attribute التي تسمح لنا بإضافة أي اسم نختاره الي Property وهي عبارة عن String مثلا لو قمنا بإضافة هذه Attribute الي أي Property موجودة داخل الكلاس Studentsفإن الإسم الذي سنضعه فيها هو الذي سيتم عرضه داخل DataGridView Header Column الكود التالي يوضح كيفية إضافة هذه Attribute إلي Property حيث أن كلمة "رقم" هي التي سوف تظهر داخل DatagridView1 Header Column كود : <DisplayName("رقم")> _في هذا المثال سنوضح كيف نربط بين الكلاس Student و ListView Control لذلك نضيف الي المشروع فورم جديد ونضيف لهذا الفورم أربعة من TextBox ثم نضيف أيضا ListView والكود التالي يوضح الأمر كود : Public Class Form2في هذا المثال سنوضح كيف نربط بين الكلاس Student و ComboBox Control لذلك نضيف الي المشروع فورم جديد ونضيف لهذا الفورم TextBox ثم نضيف أيضا ComboBox والكود التالي يوضح الأمر كود : Public Class Form3وأعتقد عزيزي القارئ يمكنك الأن أن تتبع نفس الأسلوب وتضيف هذا النوع من البيانات بسهولة الي الفورم أو الي أي كونترول حاول تجرب كيف تفعل ذلك مع الكونترول الأخري مثل TreeView و ListView الي أخره من الكونترول التي من الممكن استخدامها لعرض بيانات يمكنك انزال الكود كاملا من المرفقات الكود تم تنفيذه باستخدام نسخة الفيجوال استوديو 2008 بالتوفيق أخوكم عمر |