التخطي إلى المحتوى الرئيسي

التحكم بصلاحيات المستخدمين لكل نموذج او تقرير بشكل مستقل في مايكروسوفت اكسس مع مثال عملي





1- انشاء جدول للمستخدمين يحتوي على رقم واسم المستخدم وكلمة المرور (ونوعهما نص قصير)  

يمكنكم مشاهدة الفيديو او الاستمرار في قرأة الموضوع




2- انشاء جدول للصلاحيات يحتوي على انواع الصلاحيات بالاضافة الى حقل كومبوبوكس بياناته مرتبطة بالمستخدمين (رقم المستخدم واسمه) وحقل كومبوبوكس مرتبط بكائنات البرنامج عن طريق استخدام جدول Msysobjects  (ستجدون الطريقة في الفيديو)

 3- انشاء نموذج للدخول الى قاعدة البيانات وليكن باسم Login
عندما يقوم المستخدم بادخال اسم وكلمة مرور صحيحين يقوم البرنامج بفتح لوحة التحكم او النموذج الرئيسي للعمل كما يقوم بتسجيل رقم المستخدم في المتغير usrID الذي تم تعريفة في الموديل (الموجود في الخطوة 4)
للمزيد يمكن الرجوع الى موضوع انشاء نموذج للدخول الى قاعدة البيانات (انقر هنا) ، ونقوم باضافة جميع الحقول الخاصة بالصلاحيات الية في تذييل النموذج ونجعل التذييل مخفي 


4انشاء دالة يتم استدعاؤها عند فتح اي نموذج نريد ان نضيف له الصلاحيات ( او ادراج كود الصلاحيات في النموذج بشكل مباشر بدون انشاء الدالة
VBA
Public usrID As Integer ' سنستخدم هذا المتغير للاحتفاظ برقم المستخدم


Public Function Privilege(frm As Form)
'------------------------------------------------------------------------------------
'االتاكد من صلاحية اضافة سجل وتفعيلها او تعطيلها
If DLookup("cadd", "TblPrivilege", "StUser=" & usrID & "AND StForm ='" & frm.Name & "'") = False Or IsNull(DLookup("cadd", "TblPrivilege", "StUser=" & usrID & "AND StForm ='" & frm.Name & "'")) Then
frm.AllowAdditions = False
End If

'االتاكد من صلاحية حذف سجل وتفعيلها او تعطيلها
If DLookup("cdell", "TblPrivilege", "StUser=" & usrID & "AND StForm ='" & frm.Name & "'") = False Or IsNull(DLookup("cdell", "TblPrivilege", "StUser=" & usrID & "AND StForm ='" & frm.Name & "'")) Then
frm.AllowDeletions = False
End If

'االتاكد من صلاحية تعديل سجل وتفعيلها او تعطيلها

If DLookup("CEdit", "TblPrivilege", "StUser=" & usrID & "AND StForm ='" & frm.Name & "'") = False Or IsNull(DLookup("CEdit", "TblPrivilege", "StUser=" & usrID & "AND StForm ='" & frm.Name & "'")) Then
frm.AllowEdits = False
End If

End Function



نعود الى النماذج التي نريد تطبيق الصلاحيات عليها وعند فتح النموذج نقوم باستدعاء الدالة Privilege التي انشأناها  بالكود التالي
VBA
Private Sub Form_Open(Cancel As Integer)
Call Privilege(Me)
End Sub


تعليقات

  1. السلام عليكم كيف استدعي اسم المستخدم Public usrID As Integer في فاتورة

    ردحذف
  2. بارك الله فيك أخي على الدرس الأكثر من الرائع

    ردحذف
  3. السلام عليكم ورحمه الله وبركاته، أخى لكريم شكراً لمجهودك، لكن أنا مش عارف أجيب منين Table "MsysObject"، أرجو الأجابة وشكراً لمجهودك الكريم

    ردحذف
  4. جزاك الله خير على الشرح الممتاز
    وكذلك يجيزك خير انك ارفقة المثال

    ردحذف
  5. الله يجزاك كل خير علي الشرح الوافي منذ متي وانا ابحث عن تلك الموضوع وان سمحت لي سؤال يارب يارب تتذكرني وتضع لي الاجابة
    كيف يمكن عمل الكود في الوحدة النمطية لخاصية الفتح
    وعملت رسالة بعدم الفتح مثل ما حضرتك اشرت ولكنه يفتح
    اريد معرفة كود فتح او عدم فتح النموذج

    ردحذف
  6. ممكن شرح خاص للديلوك اب على الماكرو بنفس طريقه الكود حاولت ماضبطت معي

    ردحذف
  7. ممكن شرح خاص للديلوك اب على الماكرو بنفس طريقه الكود حاولت ماضبطت معي

    ردحذف
  8. ممكن شرح خاص للديلوك اب على الماكرو بنفس طريقه الكود حاولت ماضبطت معي

    ردحذف

إرسال تعليق

المشاركات الشائعة من هذه المدونة

انشاء الجداول في اكسس

انشاء الجداول في اكسس بعد انشاء ملف اكسس جديد فان الخطوة الاولى ستكون انشاء الجداول، ولانشاء الجداول نتبع ما يلي: 1- اختيار create  كما في الصورة 2- نقوم باختيار Table او Table Design والامر متروك للمستخدم، وانا بشكل شخصي افضل Table Design 3- بعد اختيار Table Design ستفتح لنا نافذة تصميم الجدول كما في الصورة 4- الحقل الاول Field Name يتم فية ادخال عناوين الاعمدة (الحقول) 5- الحقل الثاني Data Type يتم فية تحديد نوع المتغير (رقم ، نص ، تاريخ ...الخ) 6- الحقل الثالث Description وهو حقل اختياري ويتم فية ادخال وصف لهذا العمود 7- في كل جدول يجب تحديد المفتاح الاساسي ويجب ان يحتوي هذا الحقل على قيمة فريدة لا تتكرر مع اي حقل اخر. 8 - بعد الانتهاء نقوم باغلاق الجدول وعندها ستظهر نافذة لتحديد اسم الجدول وحفظة . 9- بعد فتح الجدول سيكون شكله كما في الصورة 10- نلاحظ ان عنوان العمود الاول ظهر كما تم كتابتة في التصميم اما العمود الثاني فقد ظهر اسمة باللغة العربية والسبب انه تم اضافة تسمية للعمود من خصائص الحقل اثناء تصميم الجدول كما في الصورة وبذلك يكو...

انشاء نموذج للدخول باسم مستخدم وكلمة مرور الى برنامج اكسس

انشاء نموذج للدخول باسم مستخدم وكلمة مرور الى برنامج اكسس عندما يكون البرنامج متاح لاكثر من شخص للعمل علية فلا بد من حماية البرنامج من المستخدمين غير المصرح لهم من خلال اضافة نموذج للدخول الى قاعدة الببيانات، ولانشاء نموذج الدخول الى البرنامج نتبع الخطوات التالية: انشاء جدول للمستخدمين يتم فيه تخزين اسماء المستخدمين وكلمات مرورهم ويحتوي على حقل لاسم المستخدم وحقل لكلمة المرور انشاء نموذج للدخول ويحتوي على مربعي نص غير مستندة الى مصدر بيانات، وزري امر واحد للالغاء والثاني للدخول  اضافة الكود التالي في حدث عند النقر في زر موافق   VBA   If pas = DLookup("userpass", "tusers", "usernam='" & [usr] & "'") Then DoCmd.OpenForm "Form1" Else MsgBox "يوجد خطأ في اسم المستخدم او كلمة المرور" End If

الشروط في الاستعلامات

الشروط في الاستعلامات يمكن اضافة الشروط في تصميم الاستعلام وعند اضافة الشرط فان الاستعلام سيقوم باظهار السجلات التي ينطبق عليها الشرط فقط، ويجب الانتباه الى انواع الحقول في الجدول قبل و ض ع الشرط لان صيغة الشرط في النص يختلف عنة اذا كنا نتعامل مع ارقام او تاريخ وسنتطرق الى هذة الانواع في هذا الموضوع. الصورة ادناة تخص تصميم الجدول الذي سنتعامل معه حيث يحتوي على اربع حقول من ظمنها اسم الطالب ونوعه نص قصير، وتاريخ الميلاد ونوعه تاريخ ووالنتيجة ونوعه رقم تم انشاء المثال اعلاة وتم تسميه الحقول باللغة العربية لتسهيل فهم الموضوع ، مع التاكيد على استخدام اللغة الانجليزية لكتابة المسميات يمكنك مشاهدة الفيديو للحصول على ايضاحات اكثر او الاستمرار بقراءة الموضوع 1-     الشروط في الحقل الذي يحتوي على نص او ارتباط تشعيبي: حسب الصورة اعلاة  لتصميم الجدول الخاص بنتائج الطلاب نلاحظ ان نوع البيانات في الحقل الثاني (اسم الطالب)    هو نص " Short Text "  وللتعامل مع هذا الحقل في الاستعلامات ،   في تصميم الاستعلام يمكننا ان نظع الشروط وكم...