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

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




صفحه 1 از 2 12 آخرآخر
نمايش نتايج 1 به 10 از 13

نام تاپيک: چاپ یک رکورد از دیتا بیس؟

  1. #1
    اگه نباشه جاش خالی می مونه M-B-M's Avatar
    تاريخ عضويت
    Mar 2006
    محل سكونت
    ایران - مشهد
    پست ها
    371

    14 چاپ یک رکورد از دیتا بیس؟

    زمانی که یک کاربر جدید به سیستم اضافه می شود می خواهیم یک برگ حاوی مشخصاتی از وی که در سیستم ثبت شده است به او تحویل دهیم.
    برای این کار چه راه حلی پیشنهاد می کنید؟
    1. چاپ همین فرم روی برگه (آیا در C# چنین قابلیتی وجود دارد؟)
    2. چاپ با استفاده از CrystalReport (چگونه می توان همین بک رکورد را به CrystalReport فرستاد؟)

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

    پيش فرض

    سلام
    1-
    با روش های نه چندان جالبی میتوان از Form ها پرینت گرفت، ولی اینکار اصلاً صحیح نیست و با dpi پایین انجام میشود.
    کلاً شما به ذات در دات نت سه راه چاپ دارید.
    Crystal و MsReport و ترسیمات مستقیم.

    2-
    یک DataTable که فقط یک سطر دارد ! چندان گیج کننده نیست.

  3. #3
    اگه نباشه جاش خالی می مونه M-B-M's Avatar
    تاريخ عضويت
    Mar 2006
    محل سكونت
    ایران - مشهد
    پست ها
    371

    14

    با این دستورات من کل رکوردهای ثبت شده را بازیابی می کنم اما چگونه می شود یک رکورد را بازیابی کنم
    //FrmMain
    private void BtnShowCustomer_Click(object sender, EventArgs e)
    {
    FrmReport FR = new FrmReport(markazDBDataSet);
    FR.ShowDialog();
    }


    //FrmReport
    private MarkazDBDataSet MDB;
    public FrmReport(MarkazDBDataSet Mdb)
    {
    InitializeComponent();
    MDB = Mdb;
    }

    private void FrmReport_Load(object sender, EventArgs e)
    {
    Customer1.SetDataSource(MDB);
    }
    از این Query هم برای بازیابی این رکورد استفاده می کنم اما نمی دانم چگونه این رکورد بازیابی شده را به CrystalReportبفرستم
    SELECT CuId, Date, Time, FName, LName, Gen, Position, Type FROM Customer WHERE (CuId = @CuId)
    Last edited by M-B-M; 16-07-2008 at 22:35.

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

    پيش فرض

    سلام
    در پستهایتان میتوانید کدهایتان را در تگ code قرار دهید تا بهتر نمایش داده شوند.

    آیا Customer1 نمونه ای از گزارش کریستال است؟؟؟


    توجه کنید، هیچ فرقی بین یک سطر با هزار سطر نیست، شما همانطور که هطار سطر دیتا را در قالب یک DataTable یا یک DataSet به کریستا میدهید، باید یک سطر را هم بدهید، واقعاً نکته ابهامی وجود ندارد!!

  5. #5
    اگه نباشه جاش خالی می مونه M-B-M's Avatar
    تاريخ عضويت
    Mar 2006
    محل سكونت
    ایران - مشهد
    پست ها
    371

    پيش فرض

    سلام
    در پستهایتان میتوانید کدهایتان را در تگ code قرار دهید تا بهتر نمایش داده شوند.

    آیا Customer1 نمونه ای از گزارش کریستال است؟؟؟


    توجه کنید، هیچ فرقی بین یک سطر با هزار سطر نیست، شما همانطور که هطار سطر دیتا را در قالب یک DataTable یا یک DataSet به کریستا میدهید، باید یک سطر را هم بدهید، واقعاً نکته ابهامی وجود ندارد!!

    سلام دوست عزیز
    من هنوز راه حل منطقی برای این کار پیدا نکردم
    من کدخودم را کامل برای شما نوشتم، با این روش من کل رکوردهایی که تابحال ثبت شده است را بازیابی می کنم
    اما می خواهم زمانی که یک مشتری جدید در سیستم ثبت می شود اطلاعات همین مشتری را بازیابی کنم و پرینت بگیرم. نمی دانم چگونه این کار را انجام دهم(بله Customer نمونه ای از گزارش است)

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

    پيش فرض

    سلام
    شما یک سطر اطلاعات میخواهید،
    اگر دیتاست شما با نام markazDBDataSet از قبل پر شده و در RAM موجود است و مخصوص چاپ این گزارش آن را پر و Fill نکرده اید،
    میتوانید از همین استفاده کنید و یک دیتاست خالی و جدید در کد تعریف کنید و سطر مورد نظر از markazDBDataSet را کپی گرفته و با Table.Rows.Add به دیتاست خالی جدید اضافه کنید.


    اگر دیتاست markazDBDataSet را مخصوص این گزارش پر و Fill کرده اید، که کارتان چندان جالب نبوده و شما باید شرط WHERE ای را به DataAdapter اضافه کنید.
    اگر از نوع سفارشی DataAdapter های موجود در TypedDataSet استفاده میکنید. روی DataAdapter راست کلید کنید و فرمان AddQuery بدهید و دستور و متد جدیدی با شرط WHERE به ان اضافه کنید.
    کد:
    برای مشاهده محتوا ، لطفا وارد شوید یا ثبت نام کنید
    اگر هم خودتان دستی DataAdapter را میسازید که فقط کافیست شرط مورد نظر را به دستور SQL-SELECT اضافه کنید.
    Last edited by _H2_; 31-07-2008 at 18:53.

  7. #7
    اگه نباشه جاش خالی می مونه M-B-M's Avatar
    تاريخ عضويت
    Mar 2006
    محل سكونت
    ایران - مشهد
    پست ها
    371

    پيش فرض

    اگر دیتاست شما با نام markazDBDataSet از قبل پر شده و در RAM موجود است و مخصوص چاپ این گزارش آن را پر و Fill نکرده اید، میتوانید از همین استفاده کنید و یک دیتاست خالی و جدید در کد تعریف کنید و سطر مورد نظر از markazDBDataSet را کپی گرفته و با Table.Rows.Add به دیتاست خالی جدید اضافه کنید.
    لطفا در صورت امکان دستورات تعریف DataSet بوسیله کد را بنویسید
    ممنون

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

    پيش فرض

    سلام
    مثل بقیه اشیا در دنیای شی گرایی، با یک کلمه new ناقابل!
    کد:
    برای مشاهده محتوا ، لطفا وارد شوید یا ثبت نام کنید
    در این مورد و تحویل دادن منبع به کریستال یا MsReport باید نوع دیتاست با نوع مورد نیاز و استفاده شده در آنجا همخوانی داشته باشد.

  9. #9
    اگه نباشه جاش خالی می مونه M-B-M's Avatar
    تاريخ عضويت
    Mar 2006
    محل سكونت
    ایران - مشهد
    پست ها
    371

    14

    سلام
    منظورتان را از "همخوانی بین نوع دیتاست با نوع مورد نیاز و استفاده شده" متوجه نشدم، چون طبق تعریفی که شما نوشته اید نوعی برای دیتاست معرفی نمی شود؛ لطفا بیشتر توضیح دهید
    و اینکه می توان برای اضافه کردن سطر مورد نظر به دیتابیس از این دستور استفاده کرد؟

    کد:
    برای مشاهده محتوا ، لطفا وارد شوید یا ثبت نام کنید

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

    پيش فرض

    سلام
    کد:
    برای مشاهده محتوا ، لطفا وارد شوید یا ثبت نام کنید
    در زمان طراحی msReport و قرار دادن جدول، شما احتمالاً فیلدهای یک TypedDataSet خاص را که در پروژه داشته اید، برای source فیلدهای نمایشی استفاده کرده اید،
    منظورم آن بود که دیتاسیتی که new میکنید از همان نوع باشد.
    کد:
    برای مشاهده محتوا ، لطفا وارد شوید یا ثبت نام کنید

    می توان برای اضافه کردن سطر مورد نظر به دیتابیس از این دستور استفاده کرد؟
    فرمایشاتی میفرمائید برادر!
    واضح است که این کد شما اصلاً مشکل سینتکس دارد چه رسد به منطقی.

    دستور sqlمورد نظر را میتوانید به همراه رشته اتصال یا همان ConnectionString تحویل DataAdapter ای دهید و با متد Fill آن عمل خواندن و پر کردن را انجام دهید.

    پیشنهاد میکنم، کمی کار و تست عملی کنید، اگر مشکلی داشتید در خدمت هستم.

صفحه 1 از 2 12 آخرآخر

Thread Information

Users Browsing this Thread

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

User Tag List

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

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