jjafferr قام بنشر منذ 11 ساعات قام بنشر منذ 11 ساعات السلام عليكم بمناسبة هذه الايام المباركة ، حبيت اشارك بهذه الجزئية المستقطعة من احد برامجي 🙂 في بعض الاحيان ما يقدر المبرمج من سد جميع ثغرات البرنامج لمنع المستخدم من عمل خطأ في ادخال البيانات ، فتكون نفس المعلومة مكتوبة بعدة طرق ، مثلا: . ومثال من جدول آخر . عادة يُطلب من المبرمج تنظيف هذه البيانات ، جدول جدول / حقل حقل / معلومة معلومة ، والمشكلة في هذا العمل هو معرفة الحقول المطلوب تنظيفها ، ثم معرفة البيانات الخطأ والبيانات الصحيحة (لإستبدالها) ، وهذا العمل يتطلب وجود المبرمج والمستخدم لمعرفته بالبيانات الخطأ والصحيحة. وبعد هذا التنظيف ، وبعد مرور مدة ، يجب تكرار العملية طبيعتي ، لما اشوف فيه تكرار لعمل معين ، اقوم ببرمجته ، وهذا اللي حصل في هذا المشروع 🙂 الان المستخدم (طبعا المسؤول) هو الذي يقوم بهذا العمل من خلال نموذج. انت محتاج الى نقل هذه الكائنات الى قاعدة بياناتك للقيام بالعمل ، ثم تشغيل النموذج frm_Clean_Data . 1. عند دخول النموذج ، تجد اسماء جميع الجداول في حقل اسم الجدول ، وبعد ان تختار اسم الجدول ، تجد اسماء جميع حقول الجدول في حقل اسم الحقل ، ثم تختار الحقل المطلوب تنظيف بياناته ، فتأتيك البيانات بدون تكرار . . 2. يجب عمل تصفية في اختيار "القيمة الحالية" للبيانات المطلوب تنظيفها ، وتختار "القيمة الجديدة" لها ، . 3. ثم تنقر على زر "جميع الاسماء المختار" ، فتاتيك رسالة تأكيد لعملية التنظيف التي سيقوم بها البرنامج ، وعند التأكد من هذا العمل والنقر على "نعم" ، فسيقوم البرنامج بعمل التغييرات المطلوبة ، ولا يوجد تراجع . 3. فنحصل على هذه النتيجة . 4. ونستمر بإختيار القيمة التالية من هذا الحقل ، او اختيار جدول/حقل آخر ، التغيير لقيمة الحقل كاملة وليست لجزء من الحقل يجب اعطاء هذا البرنامج للمسؤول ، ويجب ان يعرف عواقب العمل ، وقبل كل شيئ يجب اخذ نسخة من قاعدة البيانات Clean_Data.zip 3
منتصر الانسي قام بنشر منذ 7 ساعات قام بنشر منذ 7 ساعات عمل رائع وسأكون أول من يستخدمه فأنا أعاني من هذه المشكلة ولكن مع إختلاف بسيط فأنا غالبا ما أقوم بمطابقة البيانات بين نظامين واكون بحاجة لمطابقة القيم ليسهل الربط والمطابقة لذلك فلو أمكن إضافة خيار لنوع الإجراء هل سيتم على نفس الجدول أم مع جدول آخر فإذا كان الخيار نفس الجدول يتم العمل بنفس الآلية الحالية وإلا يتم تعبئة قائمة القيم القديمة من جدول وقائمة القيم الجديدة من جدول آخر بهذا الشكل ليتم تحديث الجدول على اليسار ببيانات الجدول على اليمين ولكن قد يتطلب هذا التعديل إضافة بعض الضوابط مثل التأكد من تطابق نوع البيانات للحقلين ولكن فكما قد وضحت في كلامك 4 ساعات مضت, jjafferr said: يجب اعطاء هذا البرنامج للمسؤول ، ويجب ان يعرف عواقب العمل ، وقبل كل شيئ يجب اخذ نسخة من قاعدة البيانات ففي الأخير سيكون على من يستخدم هذا التطبيق الحذر الشديد سواء كان العمل على جدول أو جدولين تحياتي 1
jjafferr قام بنشر منذ 4 ساعات الكاتب قام بنشر منذ 4 ساعات حسب تجربتي ، اعمل العمل بالطريقة التي تناقشها مع المستخدم ، و اتركه يستعمل البرنامج ، وبعد فترة ستجد افكار جديدة تنقلك الى النسخة التالية ، والتالية ... 🙂 وهكذا عينا لما تشارك الفكرة مع الخبراء 🙂 طيب سؤال: كلما اردت استعمال هذه الاداء على بيانات قاعدة بيانات ، اضطر الى نسخ الكائنات اليها !! ليش ما اعمل برنامج خارجي مستقل بهذه الكائنات ، كما عملته في التعامل مع ملفات الاكسل: . وبهذه الطريقة تعطي المستخدم برنامج واحد ، وهو يستعمله لكل برامجه (ما ادري ليش حسيت بقشعريرة و شعر جسمي كله وقف )
Moosak قام بنشر منذ 2 ساعات قام بنشر منذ 2 ساعات سلمت يمناك عمنا العزيز @jjafferr 🙂🌼 طبعا وبما أنك قلت : 1 ساعه مضت, jjafferr said: وبعد فترة ستجد افكار جديدة تنقلك الى النسخة التالية ، والتالية ... 🙂 خطر في بالي أفكار وملاحظة .. أما الملاحظة هي : ماذا لو كان القيمة الجديدة المطلوبة ليست من ضمن الخيارات الموجودة على القائمة اليسار ؟ .. هنا سنحتاج إضافة خيار الاستبدال بقيمة يكتبها المستخدم .. أما الأفكار فهي كالتالي : 1- بالنسبة لخيار أن تكون الأداة مستقلة عن قاعدة البيانات .. فيخطر في بالي خيار أن يستورد الملف وبشكل مؤقت جداول القاعدة المستهدف كجداول مرتبطة ليسهل التعامل معها .. وشيء قريب من هذا أنا كنت عامل أداة تسهل علي التعامل مع الجداول المرتبطة بمختلف الأشكال : 2- الفكرة الثانية : بما أن المستخدم هو اللي راح يتعامل معا الجداول فأقترح أن تظهر القوائم المنسدلة أسماء الجداول بطريقة صديقة للمستخدم بحيث تكون القائمة لها عمودين [ الاسم البرمجي للجدول | والأسم البديل بالعربي (مثلا) ] ويتم التعامل برمجيا مع العمود الأول 🙂 .. ويمكن الاستفادة من خاصية Description الموجودة في خصائص الجدول لإعطاء الجدول اسم مفهوم ويمكن استدعؤه لاحقا من الخاصية لتعبئة القائمة .. وسلامتك 🙂
منتصر الانسي قام بنشر منذ 2 ساعات قام بنشر منذ 2 ساعات (معدل) 2 ساعات مضت, jjafferr said: ليش ما اعمل برنامج خارجي مستقل بهذه الكائنات صراحة أنا فكرتي كانت أبسط وهي أن يقوم المستخدم بإنشاء إرتباط مع الجداول المطلوبة فقط ولكن قد تكون فكرتك أكثر شمولية 2 ساعات مضت, jjafferr said: ما ادري ليش حسيت بقشعريرة و شعر جسمي كله وقف ليش مافي شي يستاهل 😅 إذا أنت أصلاً قمت بما هو أصعب وهو مثال الاكسل المذكور ولا أعتقد أن العمل مع أكسس سيكون أصعب بعد أن قمت بإضافة المشاركة فوجئت بأن الأستاذ @Moosak قام بالرد وكانت فكرته ترجمة للفكرة التي ذكرتها وهي ربط الجداول المطلوبة فقط وياريت يشاركنا الأداة التي ذكرها تم تعديل منذ 2 ساعات بواسطه منتصر الانسي
jjafferr قام بنشر منذ 1 ساعه الكاتب قام بنشر منذ 1 ساعه 2 ساعات مضت, jjafferr said: وبهذه الطريقة تعطي المستخدم برنامج واحد ، وهو يستعمله لكل برامجه (ما ادري ليش حسيت بقشعريرة و شعر جسمي كله وقف ) 1 ساعه مضت, منتصر الانسي said: ليش مافي شي يستاهل 😅 إذا أنت أصلاً قمت بما هو أصعب وهو مثال الاكسل المذكور ولا أعتقد أن العمل مع أكسس سيكون أصعب لأن الموضوع صار سهل ، فأخاف من الخطأ ، وخطأ واحد و وايلاه ، لهذا السبب حسيت بقشعريرة وشعر جسمي كله وقف 42 دقائق مضت, Moosak said: ماذا لو كان القيمة الجديدة المطلوبة ليست من ضمن الخيارات الموجودة على القائمة اليسار ؟ جميل ، اذن نحسب حساب : اذا القيمة مو موجودة على القائمة اليمين ايضا . منذ ساعه, Moosak said: أما الأفكار فهي كالتالي : 1- بالنسبة لخيار أن تكون الأداة مستقلة عن قاعدة البيانات .. فيخطر في بالي خيار أن يستورد الملف وبشكل مؤقت جداول القاعدة المستهدف 2- الفكرة الثانية : القائمة لها عمودين [ الاسم البرمجي للجدول | والأسم البديل بالعربي (مثلا) ] 1. اعتقد ممكن القيام بالعمل بدون استيراد شيء ، الكل بيشتغل في مكانه ، 2. ما اعتقد يمكن عمل هذا ، لأن قواعد البيانات اللي نتعامل معاها مو جديدة ، نحن نتعامل مع تعديل/تنظيف بيانات الجداول فقط.
الردود الموصى بها
انشئ حساب جديد او قم بتسجيل دخولك لتتمكن من اضافه تعليق جديد
يجب ان تكون عضوا لدينا لتتمكن من التعليق
انشئ حساب جديد
سجل حسابك الجديد لدينا في الموقع بمنتهي السهوله .
سجل حساب جديدتسجيل دخول
هل تمتلك حساب بالفعل ؟ سجل دخولك من هنا.
سجل دخولك الان