如何使用SELECT命令获取新添加列的列值

时间:2018-01-11 15:37:44

标签: c# sql select datagridview datatable

我使用Windows窗体创建了客户订单。客户可以使用他的ID登录。登录后,DataGridView将显示文章表,其中包含哪些文章可用且可以订购的信息。数据来自SQL数据库。您可以在下面查看创建表格的方法以及表格的外观。正如您所看到的,在将数据加载到表中之后,我向表中添加了附加列(“Bestellmenge”),这是客户想要订购的文章数量。金额将由客户输入。 在他输入要订购的文章的金额并点击表单上的订单按钮后,我希望DataGridView只显示一个包含他订购的文章的表,其中包含列文章ID,名称,订购金额,价格和全价(每篇文章)。要计算全面价格,我需要件数和价格。但是,有序数量不是SQL数据库中表的一部分,它是使用附加列创建的。我的问题是,用SQL SELECT命令以某种方式可以获得金额并计算全部价格吗?

    private string tableName = "Artikel";
    private bool update = false;

    DataGridTableStyle dgTabStyle = new DataGridTableStyle();
    string sqlCmd = "SELECT * FROM artikel";

    private void ArtikelLaden()
    {
        DataTable thisTable = dataSet.Tables[tableName];
        if (thisTable != null)
        {
            thisTable.Clear();
        }


        try
        {
            odbcDataAdapter.SelectCommand = new OdbcCommand(sqlCmd, odbcConnection);
            odbcDataAdapter.Fill(dataSet, tableName);
            dataGrid.SetDataBinding(dataSet, tableName);
            if (!update)
            {
                //Neue Spalte Bestellmenge hinzufügen:
                dataSet.Tables[tableName].Columns.Add("bestellmenge");

                dgTabStyle.MappingName = tableName;

                DataGridTextBoxColumn dgtCol1 = new DataGridTextBoxColumn();
                dgtCol1.MappingName = "id";
                dgtCol1.ReadOnly = true;
                dgtCol1.HeaderText = "Artikel-ID";
                DataGridTextBoxColumn dgtCol2 = new DataGridTextBoxColumn();
                dgtCol2.MappingName = "name";
                dgtCol2.ReadOnly = true;
                dgtCol2.HeaderText = "Artikel";
                dgtCol2.Width = 100;
                DataGridTextBoxColumn dgtCol3 = new DataGridTextBoxColumn();
                dgtCol3.MappingName = "beschreibung";
                dgtCol3.ReadOnly = true;
                dgtCol3.HeaderText = "Beschreibung";
                dgtCol3.Width = 100;
                DataGridTextBoxColumn dgtCol4 = new DataGridTextBoxColumn();
                dgtCol4.MappingName = "groesse";
                dgtCol4.ReadOnly = true;
                dgtCol4.HeaderText = "Größe";
                DataGridTextBoxColumn dgtCol5 = new DataGridTextBoxColumn();
                dgtCol5.MappingName = "farbe";
                dgtCol5.ReadOnly = true;
                dgtCol5.HeaderText = "Farbe";
                DataGridTextBoxColumn dgtCol6 = new DataGridTextBoxColumn();
                dgtCol6.MappingName = "preis";
                dgtCol6.Format = "c";
                dgtCol6.Alignment = HorizontalAlignment.Center;
                dgtCol6.ReadOnly = true;
                dgtCol6.HeaderText = "Preis";
                DataGridTextBoxColumn dgtCol7 = new DataGridTextBoxColumn();
                dgtCol7.MappingName = "menge";
                dgtCol7.Alignment = HorizontalAlignment.Center;
                dgtCol7.ReadOnly = true;
                dgtCol7.HeaderText = "lieferbar";
                DataGridTextBoxColumn dgtCol8 = new DataGridTextBoxColumn();
                dgtCol8.MappingName = "bestellmenge";
                dgtCol8.NullText = "";
                dgtCol8.Alignment = HorizontalAlignment.Center;
                dgtCol8.HeaderText = "Bestellmenge";
                dgtCol8.Width = 100;


                dgTabStyle.GridColumnStyles.Add(dgtCol1);
                dgTabStyle.GridColumnStyles.Add(dgtCol2);
                dgTabStyle.GridColumnStyles.Add(dgtCol3);
                dgTabStyle.GridColumnStyles.Add(dgtCol4);
                dgTabStyle.GridColumnStyles.Add(dgtCol5);
                dgTabStyle.GridColumnStyles.Add(dgtCol6);
                dgTabStyle.GridColumnStyles.Add(dgtCol7);
                dgTabStyle.GridColumnStyles.Add(dgtCol8);
                dataGrid.TableStyles.Add(dgTabStyle);

                update = true;
                // default-Button ändern:
                this.AcceptButton = this.buttonBestellen;
            }
        }
        catch (Exception ex)
        {
            MessageBox.Show(ex.GetType() + Environment.NewLine + ex.Message);
        }
    }

1 个答案:

答案 0 :(得分:1)

您是否询问如何在select语句中计算2列的乘积,例如

| quantity| price|
|---------|------|
| 2       | 4    |
| 5       | 8    |
| 7       | 1    |

SELECT quantity,price,value1 * value2 AS total FROM example;

| quantity | price  | total |
|----------|--------|-------|
| 2        | 4      | 8     |
| 5        | 6      | 30    |
| 7        | 8      | 56    |