我使用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);
}
}
答案 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 |