2

これが私のコードです:

string cmdstr = "UPDATE itemsordered i " +
                "INNER JOIN"+
                    "(  SELECT itemsOrdered_quantity, itemsOrdered_ID,  "+
                            "IF itemsOrdered_quantity = '"+quantityTxtBox.Text+"' SELECT 'EQUAL' "+
                            "IF itemsOrdered_quantity < '" + quantityTxtBox.Text + "' SELECT 'LESS' " +
                            "IF itemsOrdered_quantity > '" + quantityTxtBox.Text + "' SELECT 'MORE'  " +
                        "END AS r "+
                        "FROM itemsordered "+
                    ") res ON i.itemsOrdered_ID = res.itemsOrdered_ID "+
               "INNER JOIN stocksdb s ON s.stock_ID = i.stock_ID " +
               "SET s.stock_quantity = (s.stock_quantity + i.itemsOrdered_quantity), " +
                   "s.stock_dateUpdated = '" + DateTime.Now.ToString("yyyy-MM-dd hh:mm:ss") + "', " +
                   "i.itemsOrdered_status = 'RECEIVED', " +
                   "i.itemsOrdered_dateReceived = '" + DateTime.Now.ToString("yyyy-MM-dd hh:mm:ss") + "'" +
                   "WHERE i.itemsOrdered_ID = '" + idTxtBox.Text + "' AND res.r = 'EQUAL'";
cmd = new MySqlCommand(cmdstr, db.mycon);
cmd.ExecuteNonQuery();

MessageBox.Show("ITEM RESTOCKED!");

私が実際にやりたいのは、itemsOrdered_quantityがの値と等しい場合、現在の金額にの金額を追加することによってをquantityTxtBox更新することです。s.stock_quantityitemsOrdered_quantity

私が作りたい他のIF句もあります。しかし、私は最初にこのジレンマを解決したいと思います。

エラーを返し、cmd.ExecuteNonQueryIFステートメントの近くにあるSQL文字列を指します。

4

3 に答える 3

1

MySQLはそのためにCASEステートメントを使用します。基本的な構文は次のとおりです。

SELECT CASE WHEN a = b THEN c ELSE d END CASE

あなたもすることができます

SELECT CASE WHEN a = b THEN c 
            WHEN a > b THEN e
            ELSE d END CASE
于 2013-01-10T12:30:57.817 に答える
0
select (case when  itemsOrdered_quantity= '"+quantityTxtBox.Text+"'then 'EQUAL' else (case when itemsOrdered_quantity<  '"+quantityTxtBox.Text+"' then 'LESS' else  'MORE' end ) end) as r from itemsordered 
于 2013-01-10T12:53:49.953 に答える
0

はいuはステートメントの場合に使用できます

   SELECT IF(1<2,'yes','no');
   //output  -> 'yes'
  //if 1<2 is true then return  `yes` if not true return `no`
于 2013-01-10T12:39:15.567 に答える