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

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




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

نام تاپيک: یک اشکال خیلی مهم در کار با بانک اطلاعاتی در سی شارپ

  1. #1
    پروفشنال aliaghaaaaa's Avatar
    تاريخ عضويت
    Feb 2008
    محل سكونت
    فارس/آباده
    پست ها
    518

    14 یک اشکال خیلی مهم در کار با بانک اطلاعاتی در سی شارپ

    سلام.
    من یه دستور تو اس کیو ال تو سی شارپ نوشتم ولی برام پیغام زیر رو میده.
    میشه کمکم کنید؟
    ممنون.

  2. #2
    داره خودمونی میشه behnam25214's Avatar
    تاريخ عضويت
    Nov 2008
    پست ها
    81

    پيش فرض

    به نظرم مشکل تو دستور Select هست یه بار چک کن.
    فیلد Code که نوشتی اگه از نوع عددی باشه از تک کوتیشن استفاده نکن.

  3. #3
    پروفشنال anvar.net's Avatar
    تاريخ عضويت
    Apr 2007
    محل سكونت
    IRAN
    پست ها
    648

    پيش فرض

    من حس می کنم کل دستور Select شما یه جورایی غیر طبیعیه.

    Select Name, Min Baghimande From Cus_name
    فکر می کنید دستور بالا چی رو برگشت می ده : لیستی از نام ها و حداقل باقیمانده برای آن نام به شرطی که شهرش X باشه.

    ولی در واقع در ستون نام ها گیر می کنه, چون نمی تونه یک نام رو بگیره و احینا اگر چندین رکورد با این نام داشت بتونه حداقل باقیمانده رو برای نام فوق برگشت بده.

    ولی اگر بیایم و یاقیمانده ها رو بذاریم تو یک جدول دیگه و یک ID مشترک با جدولی که نام ها در اون قرار دارن بذاریم می تونیم. نام ها رو از جدول نام ها بگیریم و با همون ID ماکزیمم باقیمانده ها رو از جدول دوم بدست بیاریم و همه رو در یک جدول نشون بدیم.

    من با روش شما هر کاری کردم جواب نداد.

    من فکر می کنم یک اشتباه دیگه در پشت کادر پیام هم احیانا وجود داره که تو عکس دیده نمیشه ...

  4. #4
    در آغاز فعالیت paradoxical's Avatar
    تاريخ عضويت
    May 2009
    پست ها
    11

    پيش فرض

    در انتهای دستور Select باید group by name را اضافه کنی

  5. #5
    پروفشنال aliaghaaaaa's Avatar
    تاريخ عضويت
    Feb 2008
    محل سكونت
    فارس/آباده
    پست ها
    518

    پيش فرض

    سلام.
    من خودم تصمیم داشتم کاری که دوست خوبم anvar.net گفت رو انجام بدم.
    ولی میشه در مورد روش دوستمون paradoxicalیه کم توضیح بدین؟
    یا کد رو بنویسین؟
    ممنون
    Last edited by aliaghaaaaa; 04-05-2010 at 15:11.

  6. #6
    پروفشنال anvar.net's Avatar
    تاريخ عضويت
    Apr 2007
    محل سكونت
    IRAN
    پست ها
    648

    پيش فرض

    منظور ایشان اینه که نتایج برگشتی رو بر حسب نام ها تو گروههایی دسته بندی کنیم

    بعد از دستور Where بذار Group By Name

    من مطمئن نیستم که جواب میده خودتون تست کنید شاید موفقیت امیز بود.

    اگه روش بالا نشد, میشه خود این جدول رو با خودش Join کنیم که در این صورت نیازی به 2 جدول مستقل نیست

  7. #7
    در آغاز فعالیت paradoxical's Avatar
    تاريخ عضويت
    May 2009
    پست ها
    11

    پيش فرض

    دوست عزیز اگر به سوالی که در پست اول پرسیدی دقت کنی دلیل خطا بود که خیلی واضح است و یک اشکال خیلی مهم و اساسی هم نیست
    در حالت کلی دو روش برای استفاده از aggregate function ها وجود دارد
    اول فقط aggregate function ها را بعد از دستور select بنویسی
    کد:
    برای مشاهده محتوا ، لطفا وارد شوید یا ثبت نام کنید
    که این روش بر روی کلیه سطرهای بانک عمل می کند البته شما می توانید در where سطر ها را فیلتر کرده و حاصل aggregate function هارا بر روی سطرهای دلخواهتان ببینید
    دوم علاوه aggregate function ها نام ستونهای دیگری هم در select تان باشد
    کد:
    برای مشاهده محتوا ، لطفا وارد شوید یا ثبت نام کنید
    در این حالت به هر تعداد نام ستون که در select است باید عینا در group by که در انتهای دستور می آید قرار بگیرد پس اگر شما در انتهای دستور Select خود group by name را اضافه کنی جواب می دهد
    ولی اینکه جواب مورد نظر شما است یا خیر متاسفانه من نه از طراحی بانک شما خبر دارم و نه می دانم شما با اجرای این select می خواهی به چه اطلاعاتی دست پیدا کنی
    فقط اگر ارتباط بین code و name یک به یک باشد یک سطر بر می گرداند مگر نه ممکن است چندین سطر برگرداند
    پیشنهاد می کنم برنامه را به هر طریقی تغییر دادی ابتدا نتایج حاصل از query را در خود SQL Server مشاهده کنی چون با این روش شما اگر هر کجا چندین سطر هم جواب برگردد شما متوجه نخواهی شد و فقط اطلاعات سطر اول را می خوانی

  8. #8
    اگه نباشه جاش خالی می مونه pezhmax's Avatar
    تاريخ عضويت
    May 2007
    محل سكونت
    رشت
    پست ها
    333

    پيش فرض

    واژه name یک کلمه کلیدی رزرو شده در sql-server است. ممکن است این ایراد مروبط به استفاده از این واژه کلیدی باشد. برای رفع آن به جای select name از select [name[ استفاده کنید(واژه name باید بین دو کروشه [ ] قرار داده شود). شاید جواب بگیرید.

Thread Information

Users Browsing this Thread

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

User Tag List

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

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