سیاوش نامه

توضیحات در مورد موضوعات گسسته‌ای که من باهاشون سر و کار دارم از قبیل موسیقی، حسابداری، برنامه‌نویسی و اجتماع

سیاوش نامه

توضیحات در مورد موضوعات گسسته‌ای که من باهاشون سر و کار دارم از قبیل موسیقی، حسابداری، برنامه‌نویسی و اجتماع

استفاده این بلاگ یکی نشر مطالب، نکات و تحلیل‌های علمی، اجتماعی یا حرفه‌ای خودم هست که حول محور موسیقی، حسابداری، برنامه‌نویسی میگرده و دیگر اینکه مطالب و مفاهیمی رو که از کتب و مقاله‌های مختلف می‌خونم به طور خلاصه اینجا درج کنم.

۲ مطلب با موضوع «ERP» ثبت شده است

  • ۰
  • ۰

برای این که بتونم بین گزینه‌هایی که داریم بهترین رو برای شرکت انتخاب کنم نیاز دارم که یه راهنما داشته باشم. چطور نرم افزار را بسنجم و چه شاخصهایی رو براش در نظر بگیرم.


یه چرخی زدم و به موارد زیر رسیدم.

اتکا پذیری: 

نرم افزار داده ها رو به طور صحیح ثبت و گزارش میکنه؟ 

آیا در سه لایه رابط کاربر، هسته و پایگاه داده کنترل برای صحت سنجی اطلاعات ورودی وجود داره؟

نرم افزار تحمل قطعی شبکه، برق و شرایط غیر منتظره رو داره؟


سرعت نرم افزار:

داده های بزرگ رو با چه سرعتی میخونه؟ مثلا یه سند ۱۰۰۰ سطری رو از روی اکسل با چه سرعتی ثبت میکنه؟

فرم‌ها روان باز و بسته میشن؟


یکپارچگی:

آیا ظاهر ماجولهای مختلف نرم افزار همسان است؟

آیا طریقه ارتباط کاربر با همه ماجولها یکسان است؟

آیا فرمت اطلاعات ورودی و خروجی در همه ماجولها یکسان است؟

آیا انتقال داده بین ماجولها به شکل Seamless است؟

آیا ماجولهای مختلف از یک محل واحد اطلاعات را می‌خوانند؟ آیا اطلاعاتی که در یک ماجول وارد میشود آنی در همه ماجولها در دسترس است؟


تکنولوژی ساخت:

آیا با توجه به نیاز به Scalability طراحی نرم افزار مناسب است؟

آیا از تکنولوژی روز برای ساخت نرم افزار استفاده شده؟

آیا تکنولوژی استفاده شده برای کاربری نرم افزار مناسب است؟ مثلا از یک زبان استریکت تایپ برای هسته سیستم استفاده شده؟


نگهداری:

تا چه عمقی یک کاربر عادی میتواند تنظیمات نرم‌افزار را تغییر دهد؟

تا چه حدودی یک کاربر وارد میتواند به امکانات برنامه اضافه کند؟

در کاربری روز مره چند مرتبه کاربر عادی به مشکلی برخورد میکند که قادر به رفع آن نیست؟


کاربری:

رابط کاربری برای استفاده نرم افزار مناسب است؟

تا چه حد کاربر دوست است؟

ورودی و خروجی به فرمتهای مختلف از جمله HTML، XML، JSON، CSV، و اکسل را دارد؟

نرم افزار ای پی آی در اختیار کاربر برای ارتباط با هسته قرار میدهد؟


امنیت:

اصول امنیتی در نرم افزار رعایت شده؟

  • سیاوش کسروی
  • ۰
  • ۰

سیستم‌هایی مثل رایورز و همکاران فایقد یکپارچگی هستند. در این سیستم‌ها برای مدول‌های مختلف پایگاه داده‌‌های مجزایی وجود دارد و برای انتقال داده ها بین مدول‌ها مکانیسمهایی وجود دارد که نهایتاً به اختلاف بین داده‌های مدول‌ها و گزارشات آن‌ها می‌گردد. {اضافه کنم که وقتی میگم پایگاه داده جدا منظورم دسته ای از جداول هست که با هم ارتباط (Relation) ندارن و در عمل ممکنه همه در یک پایگاه داده باشن}


در مقابل سیستم انبار نرم‌افزار سیاق با سیستم حسابداری یکپارچه است.


در سیستم‌های یکپارچه واقعی تغییر هر مقدار در سیستم برابر است با تغییر آن مقدار در تمام مدول‌های سیستم.


با مثال منظورم رو توضیح میدم.

جداول و ارتباط آن‌ها در سیستم یکپارچه انبار و حسابداری:

جدول انبار

شماره سند انبار-----نوع کالا-----تاریخ------تعداد--------فی----------ورود/خروج-----------شماره سند حسابداری*


جدول ارتباط حسابداری

نوع کالا-----کدینگ حسابداری


جدول اسناد حسابدار

شماره سند حسابداری*-----تاریخ-----شرح سند------شماره سند انبار ------------ شماره سند سیستم الف ------ ...


تحلیل: در این سیستم اسناد دو دسته هستند. دستی و سیستمی. برای اسناد دستی آرتیکلها در یک جدول جدا با شماره سند حسابداری همسان با جدول اسناد ایجاد و در زمان گذارشگیری در قالب اسناد واحد نمایش داده میشن. این در صورتی است که تمام ستون‌ها از شرح سند به بعد تهی باشن. در غیر این صورت یعنی زمانی که برای مثال شماره سند انبار مقدار داشته باشد، سیستم با استفاده از جزئیات درج شده در جدول انبار ویک شابلون، آرتیکلهای سند حسابداری مربوطه را به صورت مجازی ایجاد و در گزارشات وارد میکند. همچنین در این طراحی شماره سند حسابداری در تمام سیستمها ارتباط یک طرفه دارد. یعنی به ازای هر ردیفی که در جدول انبار وارد میشه باید یک شماره سند حسابداری ایجاد و یک ردیف با همان شماره در جدول شماره سند حسابداری ایجاد بشه.


حسنش این هست که هر زمان فی یا تعداد در جدول انبار تغییر کنه، به صورت آنی در همه سیستم تغییر میکنه و سند حسابداری مربوطه نیز تغییر خواهد کرد.

جداول و ارتباط ‌آن‌ها در سیستم غیر یکپارچه انبار و حسابداری:

جدول انبار

شماره سند انبار-----نوع کالا-----تاریخ------تعداد--------فی----------ورود/خروج-----------شماره سند حسابداری

جدول اسناد حسابدار

شماره سند حسابداری-----تاریخ-----شرح سند----- شماره سند انبار ------------ شماره سند سیستم الف


تحلیل: به نظر میرسد این رویکرد با رویکرد قبلی بی تفاوت باشد ولی در واقع تفاوتی اساسی دارد. در این سیستم زمانی که در سیستم انبار سندی ایجاد میشود هیچ تغییری در جدول اسناد حسابداری ایجاد نمیشه. حال یا به صورت خودکار یا با درخواست کاربر سیستم از روی سند انبار (از روی یک شابلون) ردیفی در جدول اسناد حسابداری و ردیفهایی در جدول آرتیکلها ایجاد میکند. در بهترین شرایط شماره سند حسابداری را در سند انبار و شماره سند انبار را در جدول اسناد حسابداری وارد می‌کند (عطف متقابل). در این حالت این دو سند به هیچ عنوان به هم ارتباطی ندارند و در سطح پایگاه داده تغییر در هیچ‌یک از این جداول تغییر متانسب در جدول دیگر را تضمین نمی‌کند. نگهداری این ارتباط باید توسط سطوح بالاتر نرم‌افزار حفظ شود که آن هم با توجه به پیچیدگی‌ها و تعدد جداول و فرم‌ها و همچنین محدودیت ذاتی سیستم عملاْ غیر ممکن است. مثلاْ سیستم نباید بگذارد اگر ردیفی در جدول اسناد حسابداری شماره سند انبار دارد تاریخ آن سند توسط کاربر تغییر یابد چون باعث مغایرت بین دو سیستم انبار و حسابداری می‌گردد. حال این که در سیستم قبلی تحت همین شرایط سیستم کلاْ تاریخی بابت اسنادی که به سیستم‌های دیگه لینک هستند ایجاد نمی‌کند و مدار این فیلد همیشه تهی خواهد بود. تاریخی که به عنوان تاریخ سند به کاربر نشان داده می‌شود تاریخ سند انبار خواهد بود و تغییر آن به راحتی امکان‌پذیر است (شما تاریخ سند را تغییر میدهید ولی سیستم در واقع تاریخ سند انبار را تغییر می‌دهد).


توجه کنید که در مثال‌های بالا من جدول آرتیکل‌ها رو (که در هردو رویکر مشترک است) از روی تنبلی شرح ندادم.


یک نکته ای که هست این که شماره اسناد که در مثال‌های قبلی عنوان شد الزاماْ همان شماره سندی نیست که کاربر می‌بیند بلکه شماره ردیف سند در جداول پایگاه داده است که حتی با پاک‌کردن اسناد هم ممکن است حفظ شود.


لطفاْ اگر مساله گنگ هست یا اشکالی در آن می‌بینید کامنت بذارید.





  • سیاوش کسروی