تبلیغات :
ماهان سرور
آکوستیک ، فوم شانه تخم مرغی ، پنل صداگیر ، یونولیت
دستگاه جوجه کشی حرفه ای
فروش آنلاین لباس کودک
خرید فالوور ایرانی
خرید فالوور اینستاگرام
خرید ممبر تلگرام

[ + افزودن آگهی متنی جدید ]




نمايش نتايج 1 به 5 از 5

نام تاپيک: اتصال دو جدول به صورت یک به چند

  1. #1
    اگه نباشه جاش خالی می مونه
    تاريخ عضويت
    Oct 2005
    پست ها
    350

    پيش فرض اتصال دو جدول به صورت یک به چند

    آیا امکان دارد دو جدول را با دو ارتباط "یک به چند" به هم متصل کرد؟؟؟

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

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

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

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

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

    با تشکر

  2. #2
    ناظر انجمن .NET Framework _H2_'s Avatar
    تاريخ عضويت
    Feb 2007
    محل سكونت
    یک جایی بین Framework و نارمک!
    پست ها
    4,746

    پيش فرض

    سلام
    با همان یک جدول مشکل شما حل خواهد شد و مشکل پیاده سازی ندارد.
    ولی برای کمک در جهت رفع ایراد ...
    1) با چه ابزاری از دیتابیس گزارش میگیرید؟
    2) دستور SQLچیست و کجا آن را ساخته اید؟ در برنامه یا در ابزار گزارشگیری؟

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

  3. #3
    اگه نباشه جاش خالی می مونه
    تاريخ عضويت
    Oct 2005
    پست ها
    350

    پيش فرض

    خیلی ممنون مشکلم حل شد
    اشتباهم اونجایی بود که از همون ارتباطات پیش فرضم استفاده می کردم در صورتی که باید با کلمه 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 هم کلاس کریستال ریپورتی است که قبلا و بر اساس نیاز ساخته شده

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

    با تشکر

  4. #4
    ناظر انجمن .NET Framework _H2_'s Avatar
    تاريخ عضويت
    Feb 2007
    محل سكونت
    یک جایی بین Framework و نارمک!
    پست ها
    4,746

    پيش فرض

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

    1ـ کدPERCENT Top(100) به چه دردی می خورد (دیتا بیسم اس کیو اله)
    دستوری که 100% نتایج پرس و کو را بر میگرداند.
    با کاهش این عدد میتوانید تعداد سطرهای خروجی را محدود کنید.

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

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

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

    موفق باشید.

  5. #5
    پروفشنال bad_boy_2007's Avatar
    تاريخ عضويت
    Aug 2006
    محل سكونت
    ایران
    پست ها
    803

    پيش فرض

    با اجازه استاد H2
    براي گذاشتن شماره رديف در كريستال چند راه داري :

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

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

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

Thread Information

Users Browsing this Thread

هم اکنون 1 کاربر در حال مشاهده این تاپیک میباشد. (0 کاربر عضو شده و 1 مهمان)

User Tag List

قوانين ايجاد تاپيک در انجمن

  • شما نمی توانید تاپیک ایحاد کنید
  • شما نمی توانید پاسخی ارسال کنید
  • شما نمی توانید فایل پیوست کنید
  • شما نمی توانید پاسخ خود را ویرایش کنید
  •