как да създадете необвързана колона, свързана с чужд ключ вътре в мрежа

бих искал да създам динамично необвързана колона в Xtragrid контрол devexpress; има сценарий: имам мрежа, обвързана с данни от Payment Datatable, полетата са "Payment_ID, Customer_ID" и така нататък и така нататък, това, което бих искал да направя, е вместо да имам Customer_ID, което е чуждото в тази таблица, искате да имате в него име на клиент, свързано с идентификатор на клиент, за да избегнете объркване. някой Помощ Благодаря (с помощта на winforms C#). използван код по-долу; за попълване на мрежата

          using System;
          using System.Collections.Generic;
          using System.ComponentModel;
          using System.Drawing;
          using System.Data;
          using System.Linq;
          using System.Text;
          using System.Windows.Forms;
          using System.Data.SqlClient;

          namespace YoungWoman
            {
               public partial class Payment2 : UserControl
                   {
                          DataSet ds3 = new DataSet();
                          SqlDataAdapter dapayment = new SqlDataAdapter();
                          SqlConnection conne = SqlCoonectionSEtup.GetConnection;
                          BindingSource PaymentBinding = new BindingSource();

               public Payment2()
                {
                   InitializeComponent();
                }

               private void AddPayment_Click(object sender, EventArgs e)
            {
               Paymentfrm payent = new Paymentfrm(Utils.Formtype.add, 0);
               payent.PaymentEvent += new EventHandler(RefreshingGrid);
               payent.PayentlabelsEvent += new EventHandler(RefresHlabels);

               payent.ShowDialog();

            }

               private void EditPayment_Click(object sender, EventArgs e)
              {
                 Paymentfrm pyt = new Paymentfrm(Utils.Formtype.edit, 1);
               pyt.ShowDialog();
              }
                   void RefreshingGrid(object sender, EventArgs e)
             {
                  ds3.Tables["tblPaymentYW"].Clear();
                  SqlCommand cmd = new SqlCommand("SELECT * FROM PaymentYW", conne);

                       dapayment.SelectCommand = cmd;
                        dapayment.Fill(ds3, "tblPaymentYW");
                        DgPaymentYW.DataSource = ds3.Tables["tblPaymentYW"];
                        DgPaymentYW.RefreshDataSource();
             }
    void RefresHlabels(object sender, EventArgs e)
    {
        LoadData();
    }


    private void Payment2_Load(object sender, EventArgs e)
    {
        LoadData();



    }

    private void LoadData()
    {
        SqlCommand cmd = new SqlCommand("SELECT *FROM PaymentYW ORDER BY PaymentId ", conne);
        dapayment.SelectCommand = cmd;
        ds3.Clear();
        dapayment.Fill(ds3, "tblPaymentYW");
        PaymentBinding.DataSource = ds3.Tables["tblPaymentYW"];
        DgPaymentYW.DataSource = PaymentBinding;

        this.PaymentIdlabelContro.DataBindings.Clear();
        this.PaymentIdlabelContro.DataBindings.Add(new Binding("Text", PaymentBinding, "PaymentId"));
        ReservationIdlabelControl.DataBindings.Clear();
        this.ReservationIdlabelControl.DataBindings.Add(new Binding("Text", PaymentBinding, "ReservationId"));
        LesseeIdlabelControl.DataBindings.Clear();
        this.LesseeIdlabelControl.DataBindings.Add(new Binding("Text", PaymentBinding, "LesseeId"));

        DatelabelControl.DataBindings.Clear();

        this.DatelabelControl.DataBindings.Add(new Binding("Text", PaymentBinding, "PaymentDate"));
        AmountlabelControl.DataBindings.Clear();
        this.AmountlabelControl.DataBindings.Add(new Binding("Text", PaymentBinding, "AmountPaid"));
        BalancelabelControl.DataBindings.Clear();
        this.BalancelabelControl.DataBindings.Add(new Binding("Text", PaymentBinding, "Balance"));
        gridView1.Columns[1].Visible = false;
        gridView1.Columns[6].Visible = false;


        DevExpress.Utils.FormatInfo fi = new DevExpress.Utils.FormatInfo();
        fi.FormatType = DevExpress.Utils.FormatType.Numeric;
        fi.FormatString = "c2";
        gridView1.Columns[5].DisplayFormat.Assign(fi);
        gridView1.Columns[4].DisplayFormat.Assign(fi);
        Rowcount();
        Priveleges();


    }

    void Rowcount()
    {
        RecordlabelControl.Text = " Records : " + (gridView1.RowCount);

    }
    void Priveleges()
    {
        if (SqlCoonectionSEtup.Priveleges == "User")
        {
            AddPayment.Enabled = false;
            EditPayment.Enabled = false;
            CancelBtn.Enabled = false;
        }
        else
        {

            AddPayment.Enabled = true;
            EditPayment.Enabled = true;
            CancelBtn.Enabled = true;

        }
    }

}

}


person Derek Eminence Lombela    schedule 15.08.2012    source източник
comment
Какво имате предвид под създаване на динамично необвързана колона?   -  person paparazzo    schedule 15.08.2012
comment
под Създаване на динамична необвързана колона имам предвид създаване чрез код на колона, идваща от друга таблица, свързана с нейния първичен ключ, който е външен ключ в определена таблица.   -  person Derek Eminence Lombela    schedule 15.08.2012
comment
Подходът на Джери трябва да работи. Все още бих го нарекъл обвързана колона.   -  person paparazzo    schedule 15.08.2012


Отговори (2)


Във вашето извлечение Select бихте ли могли да обедините таблицата PaymentYW с таблицата Customer в полето customer_ID? Тогава всички полета за клиенти ще бъдат налични и можете да включите колоната Customer_Name в DataGrid.

person Jerry    schedule 15.08.2012

ако разбирам правилно, искате да покажете еквивалентно customer_name на мястото на customner_id. Можете да постигнете това поведение, като използвате RepositoryItemLookUpEdit.

Първо добавете repositoryItemLookUpEdit като редактор на колони към колоната, съпоставена с „Customer_ID“

Вземете информация за клиента от таблицата с клиенти и я присвоете към източник на данни repositoryItemLookUpEdit.

"Select Customer_ID,Customer_Name from Customers" - По този начин можете да получите информация за клиентите си.

Добавете две колони към repositoryItemLookUpEdit за id(Customer_ID) и name(Customer_Name) и им дайте подходящи имена на полета. Присвоете полето „Customer_ID“ като член стойност и полето „Customer_name“ като показван член към хранилищетоItemLookUpEdit. Това ще задоволи вашите изисквания.

За по-добро представяне можете да направите видимостта на id колоната фалшива в repositoryItemLookUpEdit.

person Krishnakumar    schedule 22.08.2012