Какой самый быстрый способ обновить строки SQL значениями, основанными на значении в строке? - PullRequest
0 голосов
/ 27 августа 2018

У меня есть следующее table в SQL Server, которое называется tblProducts:

+-----------+--------------+-------------+
| pkProduct | fkProductID  |  intIssue   |
+-----------+--------------+-------------+
|     1     |     10       |      1      |
|     2     |     10       |      2      |
|     3     |     10       |      4      |
|     4     |     11       |      1      |
|     5     |     11       |      2      |
|     6     |     11       |      3      |
|     7     |     11       |      5      |
|     8     |     12       |      1      |
|     9     |     13       |      1      |
|     10    |     13       |      4      |
|     11    |     14       |      1      |
|     12    |     14       |      3      |
|     13    |     14       |      6      |
|     14    |     15       |      1      |
|     15    |     16       |      1      |
+-----------+--------------+-------------+

Со временем, когда по каким-либо причинам были удалены строки, теперь в номерах выпуска есть пробелы.Я хотел бы, чтобы номера выпусков работали по порядку, чтобы table выглядело так:

+-----------+--------------+-------------+
| pkProduct | fkProductID  |  intIssue   |
+-----------+--------------+-------------+
|     1     |     10       |      1      |
|     2     |     10       |      2      |
|     3     |     10       |      3      |
|     4     |     11       |      1      |
|     5     |     11       |      2      |
|     6     |     11       |      3      |
|     7     |     11       |      4      |
|     8     |     12       |      1      |
|     9     |     13       |      1      |
|     10    |     13       |      2      |
|     11    |     14       |      1      |
|     12    |     14       |      2      |
|     13    |     14       |      3      |
|     14    |     15       |      1      |
|     15    |     16       |      1      |
+-----------+--------------+-------------+

На данный момент я добавил table к своему DataSet и, используя этов vb.net коде я обновляю строки:

Dim currentProductsTable As tblProductsDataTable

Using taProduct As New tblProductsTableAdapter
    currentProductsTable = taProduct.GetData
End Using

Dim issueCounter As Integer = 1
Dim previousRow As tblProductsRow = Nothing

Using con As SqlConnection = New SqlConnection(My.Settings.MyConnectionString)
    Using cmd As New SqlCommand("UPDATE dbo.tblProducts SET [intIssue] = @issueCounter WHERE pkProduct = @ProductID", con)
        cmd.Connection = con 
        con.Open()
        For Each row As tblProductsRow In currentProductsTable.Rows
            If Not previousRow Is Nothing Then
                If row.fkProductID = previousRow.fkProductID Then
                    cmd.Parameters.Clear()
                    cmd.Parameters.Add("@issueCounter", SqlDbType.Int).Value = issueCounter
                    cmd.Parameters.Add("@ProductID", SqlDbType.Int).Value = row.pkProduct
                    previousRow = row
                Else
                    issueCounter = 1
                    cmd.Parameters.Clear()
                    cmd.Parameters.Add("@issueCounter", SqlDbType.Int).Value = issueCounter
                    cmd.Parameters.Add("@ProductID", SqlDbType.Int).Value = row.pkProduct
                    previousRow = row
                End If
            Else
                issueCounter = 1
                cmd.Parameters.Clear()
                cmd.Parameters.Add("@issueCounter", SqlDbType.Int).Value = issueCounter
                cmd.Parameters.Add("@ProductID", SqlDbType.Int).Value = row.pkProduct
                previousRow = row
            End If
            cmd.ExecuteNonQuery()
            issueCounter += 1
        Next
    End Using
End Using

Я заказал .GetData по fkProductID ASC и intIssue ASC, но это занимает очень много времени, так как вокруг30000 rows в table.

Интересно, есть ли более быстрый способ сделать такое обновление?

1 Ответ

0 голосов
/ 27 августа 2018

Я собираюсь догадаться, что вы используете SQL Server.Если это так, вы можете сделать все это одним запросом:

with toupdate as (
      select p.*,
             row_number() over (partition by fkProductID order by pkProduct) as new_intIssue
      from dbo.tblProducts p
     )
update toupdate
    set intIssue = new_intIssue
    where intIssue <> new_intIssue;
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...