PDA

نسخه کامل مشاهده نسخه کامل : اتصال دو جدول به صورت یک به چند



ahmad_r
07-12-2009, 10:49
آیا امکان دارد دو جدول را با دو ارتباط "یک به چند" به هم متصل کرد؟؟؟

مثال:
من یک جدول پروژه ها دارم که در آن انواع فیلدها وجود دارد که 2 تای آنها برایم مهم است: 1ـ مسئول پیگیری که در آن کد فردی که قرار است پیگیر کننده پروژه باشد ذخیره می شود. 2ـ معرف که در آن کد فردی که این پروژه را معرفی کرده ذخیره می شود

همان طور که می بینید اطلاعات مسئول پیگیری و معرف شبیه هم بوده (مانند: نام و نام خانوادگی و...) لذا یک جدول دیگر با نام کارمندان داریم که این اطلاعات در آنها ذخیره می شود

مشکل: اگر دو ارتباط بین کد در جدول کارمند با معرف و مسئول پیگیری برقرار شود و اطلاعات وارد شده در مسئول پیگیری و معرف برابر نباشد در موقع گزارش گیری هیچ گونه اطلاعاتی نمایش نمی دهد (یعنی اگر ما نام و فامیل مسئول پیگیری و نام و فامیل معرف را بخواهیم چیزی نمایش نمی دهد چون هر دو به یک جدول متصل اند)

از طرفی اگر دو جدول برای این منظور در نظر بگیریم باید اطلاعات نام و فامیل و... در دو جدول وارد کرده که هم مدیریت آنها برای برابر بودن اطلاعاتشان سخت است هم اطلاعات تکراری در سیستم ذخیره می شود.

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

با تشکر

_H2_
08-12-2009, 11:42
سلام
با همان یک جدول مشکل شما حل خواهد شد و مشکل پیاده سازی ندارد.
ولی برای کمک در جهت رفع ایراد ...
1) با چه ابزاری از دیتابیس گزارش میگیرید؟
2) دستور SQLچیست و کجا آن را ساخته اید؟ در برنامه یا در ابزار گزارشگیری؟

شما در واقع باید دستور SQL را اصلاح کنید و دو Join به دو فیلد به یک جدول (با دو نام مجازی) ایجاد کنید.
اگر جواب دو سوال فوق را بدانم راحت تر میتوالنم کمکتان کنم.
موفق باشید.

ahmad_r
14-12-2009, 11:00
خیلی ممنون مشکلم حل شد
اشتباهم اونجایی بود که از همون ارتباطات پیش فرضم استفاده می کردم در صورتی که باید با کلمه AS عملا یک جدول مشابه از پرسنلی ایجاد می کردم یعنی کد زیر:

SELECT TOP (100) PERCENT dbo.Project.ID, dbo.Project.Name as N1, dbo.Company.Name As N2 , moaref.Name as MoarefName, moaref.Famil AS FamilMoaref, Peigir.Name AS NamePeigir, Peigir.Famil AS FamilPeigir,

FROM dbo.Project INNER JOIN
dbo.Employe AS Moaref ON moaref.ID = dbo.Project.MoarefID INNER JOIN
dbo.Employe AS Peigir ON Peigir.ID = dbo.Project.PeigiriID

اما حالا دو تا سوال دیگه دارم:
1ـ کدPERCENT Top(100) به چه دردی می خورد (دیتا بیسم اس کیو اله)
و 2ـ چطوری می توان برای یک گزارش کریستال ردیف گذاشت

(نحوه اتصال من به کریستال ریپورت)

CReport1 CR1 = new CReport1();
CR1.SetDataSource(db.select(Report.strReport1));
crystalReportViewer1.ReportSource = CR1;

توضیح: متغیر strReport1 همان کد بالاست و Creport1 هم کلاس کریستال ریپورتی است که قبلا و بر اساس نیاز ساخته شده

(سوال دومیم مهمتره... منتظرم)

با تشکر

_H2_
16-12-2009, 02:28
سلام


مشکلم حل شد

انشا ا.. همواره مشکلاتتان ساده و سریع حل شود.



1ـ کدPERCENT Top(100) به چه دردی می خورد (دیتا بیسم اس کیو اله)

دستوری که 100% نتایج پرس و کو را بر میگرداند.
با کاهش این عدد میتوانید تعداد سطرهای خروجی را محدود کنید.



2ـ چطوری می توان برای یک گزارش کریستال ردیف گذاشت

خود کریستال هم شاید امکانش را داشته باشد، ولی چون مدت زیادی است کار نکرده ام دیگر درست به ذهنم مطمئن نیستم ... !

اگر از بانک اطلاعاتی SQL Server 2005 با بالا استفاده میکنید یک راه حل سریع و ساده دارد.
شما به صورت عادی دستوری مثل این برای استخراج اطلاعات از بانک دارید:

برای مشاهده محتوا ، لطفا وارد شوید یا ثبت نام کنید
(حالا این دستور میتوانید بسیار پیچیده تر هم شود ولی ذاتش فرقی نمیکند)

برای اضافه کردن یک عدد ترتیبی (که البته من باشم اضافه نمیکنم!) میتوانید کدی مثلب این بنویسید:

برای مشاهده محتوا ، لطفا وارد شوید یا ثبت نام کنید
دستور فوق یک ستون یا فیلد با نام ID_Row_Number به اول مجموعه نتیجه اضافه میکند که حاوی عدد های پشت سر هم برای ردیف ها است.
این دستور در کلیه نسخه های SQL Server 2005/2008 کار خواهد کرد.

موفق باشید.

bad_boy_2007
16-12-2009, 21:39
با اجازه استاد H2
براي گذاشتن شماره رديف در كريستال چند راه داري :

1- همانطور كه استاد H2 گفتند ميتوانيد از طريق ديتابيس اين شماره را بگيريد و به گزارشتان بفرستيد همانند باقي مشخصات (البته محاسبه شده)

2- در كريستال از متغيير Global استفاده كنيد و اين مقدار را يك واحد يك واحد افزايش دهيد ، اين روش كمي مشكل است ولي من از آن جهت آن را دوست دارم كه هيچ محوديتي ندارد . مثلا اگر بخواهيد از 100 ركورد به 100 ركورد عدد را ريست كنيد و مجدد از شماره 1 شروع شود يا در مواردي كه ميخواهيد براي چاپ ليستهاي مثل ليست كالا ها براي هر گروه از كالا ها يك شماره رديف منحصر به فرد داشته باشيد يا اينكه براي هر صفحه شماره از 1 شروع شود و ...
[براي برخي از موارد فوق خود كريستال امكان ريست كردن فيلدهاي شمارنده را ميدهد ، مثلا براي گروه و شماره صفحه ولي در كل متغيير Global‌هيچ محدوديتي ندارد]

3- استفاده از RunTime Total Field ها ، براي اين فيلدها ميتوان شرطهاي پيچيده اي اعمال كنيد ، كار كردن با آنها ساده است و از سرعت خوبي برخوردارند . من براي شماره رديف Type اين فيلدها را در بخش Detail بر روي Count قرار ميدهم .