2014-01-22 50 views
1

如何加快這裏的速度並更快地更新行? 我知道這不應該是這樣,任何人都可以推薦一個更好的做法。如何在VB.net中更快速地查詢和更新

謝謝

Public Sub searchUpdate() 
    strSQL = "*Large query, including 3 tables" 

    cmd = New MySqlCommand(strSQL, CONNECTION) 
    dr = cmd.ExecuteReader() 
    ListView1.Items.Clear() 

    Do While dr.Read() 
     a = (dr.Item("users").ToString()) 
     b = (dr.Item("b1").ToString() & "," & dr.Item("b2").ToString() & "," & dr.Item("b3").ToString() & "," & dr.Item("b4").ToString() & "," & dr.Item("b5").ToString() & "," & dr.Item("b6").ToString()) 
     won = (dr.Item("number").ToString) * (dr.Item("input").ToString()) 
     qt = (dr.Item("input").ToString) 
     updateForSearch(a, won, qt) 

    Loop 
    dr.Close() 
    cmd.Dispose() 
    CONNECTION.Close() 
    TextBox1.Text = Val(TextBox1.Text) + 1 
    Timer2.Stop() 

End Sub` 

功能更新:

Public Function updateForSearch(ByVal a As String, ByVal won As Integer, ByVal qt As Integer) As Integer 
    dr.Close() 
    strSQL = "UPDATE users SET status=2, qt='" & qt & "', bcvd='" & won & "' WHERE acvd='" & a & "'" 
    Dim da As New MySqlDataAdapter(strSQL, CONNECTION) 
    da.Fill(ds) 
    dr = cmd.ExecuteReader() 

End Function 

回答

1

這個例子說明了如何可以甚至沒有去VB.net如果運行更新

UPDATE users u 
    JOIN tbl1 t1 on u.col1 = t1.col1 
    JOIN tbl2 c on t1.col2 = t2.col2 
    -- join more tables 
SET 
    u.col_a = t1.col3, ...... 
WHERE .... 

基本上,你可以將你的更新表加入你的選擇中的大連接 - 你可以做到這一點,而不會使數據離開數據庫。這會提高性能,大的時間,首先 - 因爲數據不是旅行,第二 - 因爲現在這是批量與排一個一個

可能是您創建視圖的最佳方式您的複雜查詢,然後使用該視圖進行更新。規則僅爲3:

1 - 您的視圖必須返回用於「用戶」中字段分配的字段。

2 - 您的視圖必須返回用於與「用戶」連接的字段。

3 - 您的觀點可能需要彙總,你必須有不超過然後在內部一個匹配值加入

+0

順便說一句,這是我的查詢:HTTP://pastebin.com/cTM1TgTj – user3224535

+0

這是引擎收錄和我的查詢是2000字符太長回覆這裏 – user3224535

+0

@ user3224535好的。該查詢對我來說並不合適,而且我發現與問題無關。有問題的你選擇「用戶」,「b2」,「數字」,「輸入」。可能對你來說最好的辦法是從複雜查詢中創建一個'View',然後使用該視圖進行更新。規則僅爲3:1 - 您的視圖必須返回用於「用戶」中字段分配的字段。 2 - 您的視圖必須返回用於與「用戶」加入的字段。 3.你的視圖可能需要被聚合,你必須在'inner join'中有一個以上的匹配值。然後它會工作 –