2012-12-21 21 views
7

INNER JOINS kullanan kendi SQL dizelerini yaptım. Ben birden fazla değere sahip olacağını stocksList ListViewrecipeList ListView üzerine bir Öğe tıkladığımda Sorun,SQL dizesi nedeniyle çoğaltma değerleri?

string cmdstr = @"SELECT s.*, mdb.menu_name 
        FROM stocksdb s, recipelist rl 
        INNER JOIN menudb mdb ON rl.menu_ID = mdb.menu_ID 
        WHERE rl.stock_ID = '" + stockID + "'"; 

var cmd = new MySqlCommand(cmdstr, db.mycon); 
var dr = cmd.ExecuteReader(); 
while (dr.Read()) 
{ 
    var menuname = dr["menu_name"].ToString(); 

    stockIDTxtbox.Text = stockID; 
    nameTxtBox.Text = dr["stock_name"].ToString(); 
    availableTxtbox.Text = dr["stock_quantity"].ToString(); 
    pricePerPieceTxtbox.Text = dr["stock_pricePerPiece"].ToString(); 
    limitTxtBox.Text = dr["stock_limit"].ToString()); 

    recipeList.Items.Add(new ListViewItem(new[] { menuname }); 
} 

: İşte benim fonksiyonudur. Aynı değerlerin 5 veya daha fazla satırı gibi.

+0

Ayrıca SQL sözdizimi ile ilgili sorunlar için lütfen beni düzeltin –

+0

Bazı örnek veriler sağlayabilir misiniz? – Trisped

cevap

5

Stocksdb ile birleştirme eksik. Bunun gibi bir şey:

SELECT s.*, mdb.menu_name 
    FROM stocksdb s 

    INNRER JOIN recipelist rl 
    ON s.stock_ID= r1.stock_ID <== this join was missing 

    INNER JOIN menudb mdb 
    ON rl.menu_ID = mdb.menu_ID 
    WHERE rl.stock_ID = '" + stockID 
+0

Bu birkaç tweaks ile harika çalıştı :) çok teşekkürler! –

+0

@JohnErnestGuadalupe Cevabı kabul etmeyi unutmayın. – Trisped