-
September 27th, 2010, 01:48
#1
عضو جدید
جدول هاي ديتابيس
سلام
دوستان ميخواهم يك اسكريپت بنويسم
براي بخش ثبت نام سه نوع كاربر دارم
مدير,كاربر معمولي(مشتري),كاربري كه سفارش مشتري ها رو دريافت ميكنه
حالا اينجا ميخواهم بتونم به يك سري از كاربران هم يك سري دسترسي هاي مديريت بدم مثل ناظم و ...
به نظر شما جداول رو چطوري درست كنم
يك جدول براي همه ؟
دو جدول يكي براي كاربران يكي هم براي مديران ؟
چون ميخواهم بعدش توي ارتقا برنامه به مشكل خاصي بر نخورم
به نظر شما ساده ترين كار كدام هستش ؟
-
-
September 27th, 2010 01:48
# ADS
-
September 27th, 2010, 02:06
#2
عضو جدید
پاسخ : جدول هاي ديتابيس
می تونی یه جدول برای کاربران بسازی یعنی این که کل کاربران تو یه جدول یا یه تیبل باشن
بعدش بیای یه row ایجاد کنی مثلا به نام Level !
حالا میای Level رو تو یه جدول دیگه تعریف می کنی بر فرض مثال 3 تا لول می سازی با دسترسی هایی که دوست داری یکی برای مدیر 1 ، یکی برای مدیر 2 و یکی هم برای کاربر
حالا میای تو تیبل یوزر ها برای هر یوزر تو row لول سطح دسترسیش رو با تیبل Level تعریف می کنی
امیدوارم متوجه شده باشی
!... Security is never complete
-
تعداد تشکر ها از S4n470n به دلیل پست مفید
-
September 27th, 2010, 02:11
#3
عضو جدید
پاسخ : جدول هاي ديتابيس
راستش متوجه نشدم درست
اگر ميشه يك نمونه از ساختار تيبل رو بذارين
-
-
September 27th, 2010, 06:17
#4
عضو دائم
پاسخ : جدول هاي ديتابيس
ببين اگر خودم باشم ترجيح ميدم كار آسون تر رو انتخاب كنم !
من ميام يك جدول براي همه مي سازم
يك جدول پرميشن هم ميسازم
اگر بخش هاي برنامه قرار نيست هر روز تغيير كنند و يك سري امكانات ثابت مثل ارسال تيكت و .. هست خيلي راحت اين كار جواب ميده
در جدول پرميشن يك ستون user id و يك سري ستون براي اختيارات دلخواه تعريف مي كني
حتي بعدا ميتوني در صورت اضافه شدن بخش جديد يك ستون ديگه به جدول اضافه يا كم كني
البته اگر قرار باشه زياد بخش ها تغيير كنه ،تغيير ساختار جدول در هر نوبت زياد جالب نيست و بايد يكم حرفه اي تر عمل كرد !
يعني مثلا يك جدول پرميشن داريم با ستون هاي :
id
شناسه كاربر (user id)
نام پرميشن (permission)
* نام پرميشن : ميتونيم براي هر بخش يا عمليات يك نام در نظر بگيريم براي اين كار ميتونيم در اول يا اون بخش از كدمون يك ثابت مثلا به نام permission_name در نظر بگيريم
حالا اگر خواستيم كاربري به فلان بخش دسترسي داشته باشه يك سطر جديد در جدول permission درج مي كنيم و نام پرميشن رو بربر نام ثابت اون منطقه يا عمليات و شناسه كاربر رو هم كه مشخصه ؛ مي ذاريم
و اگر خواستيم پرميشني رو از كاربر بگيريم مي تونيم سطر مربوطه رو حذف كنيم
-
تعداد تشکر ها از Rezash به دلیل پست مفید
-
September 27th, 2010, 15:31
#5
عضو جدید
پاسخ : جدول هاي ديتابيس
يك مورد ديگه هم هستش
چون من الان از هر يوزري يك سري اطلاعات ميخواهم
مثلا كاربر معمولي احتاجي به درج خيلي از مشخصات رو نداره شايد مثلآ 5 فيلد
ولي كاربر حرفه اي بايد اطلاعات بيشتري رو درج كنه مثلا 12 فيلد
خوب با روش شما كه يك جدول يوزر باشه بايد كل اطلاعات كاربران در اين يك جدول درج بشه
-
-
September 29th, 2010, 15:02
#6
عضو دائم
پاسخ : جدول هاي ديتابيس

نوشته اصلی توسط
texas
يك مورد ديگه هم هستش
چون من الان از هر يوزري يك سري اطلاعات ميخواهم
مثلا كاربر معمولي احتاجي به درج خيلي از مشخصات رو نداره شايد مثلآ 5 فيلد
ولي كاربر حرفه اي بايد اطلاعات بيشتري رو درج كنه مثلا 12 فيلد
خوب با روش شما كه يك جدول يوزر باشه بايد كل اطلاعات كاربران در اين يك جدول درج بشه
اصولا يوزرها بهتر هست پروفايل يكسان ولي پرميشن ها مجزايي داشته باشند
اين فيلد ها رو اگه مثال بزني مه چي هستند ميشه بهتر نظر داد.
-
تعداد تشکر ها از Rezash به دلیل پست مفید
-
September 29th, 2010, 15:33
#7
عضو جدید
پاسخ : جدول هاي ديتابيس

نوشته اصلی توسط
hello
اصولا يوزرها بهتر هست پروفايل يكسان ولي پرميشن ها مجزايي داشته باشند
اين فيلد ها رو اگه مثال بزني مه چي هستند ميشه بهتر نظر داد.
ببين رضا جان اين همون پروژه هستش كه قبلا بهت گفتم
كاربراي معمولي اجازه دانلود و استفاده از سايت رو دارن
ولي كاربر حرفه اي براي تاييد صلاحيت بايد يك سري اطلاعات كه نياز هستش رو در اختيار ما بذاره كه شايد اين اطلاعات زياد باشن
-
-
October 13th, 2010, 20:45
#8
عضو دائم
پاسخ : جدول هاي ديتابيس

نوشته اصلی توسط
texas
ببين رضا جان اين همون پروژه هستش كه قبلا بهت گفتم
كاربراي معمولي اجازه دانلود و استفاده از سايت رو دارن
ولي كاربر حرفه اي براي تاييد صلاحيت بايد يك سري اطلاعات كه نياز هستش رو در اختيار ما بذاره كه شايد اين اطلاعات زياد باشن
با شرايطي كه ميگي به نظرم استفاده از روش دوم بهتر هست:
يعني مثلا يك جدول پرميشن داريم با ستون هاي :
id
شناسه كاربر (user id)
نام پرميشن (permission)
* نام پرميشن : ميتونيم براي هر بخش يا عمليات يك نام در نظر بگيريم براي اين كار ميتونيم در اول يا اون بخش از كدمون يك ثابت مثلا به نام permission_name در نظر بگيريم
حالا اگر خواستيم كاربري به فلان بخش دسترسي داشته باشه يك سطر جديد در جدول permission درج مي كنيم و نام پرميشن رو بربر نام ثابت اون منطقه يا عمليات و شناسه كاربر رو هم كه مشخصه ؛ مي ذاريم
و اگر خواستيم پرميشني رو از كاربر بگيريم مي تونيم سطر مربوطه رو حذف كنيم
-
تعداد تشکر ها ازRezash به دلیل پست مفید