我正在寫更新聲明,我需要用增量日期一次更新所有項目列表。增量值是用戶定義的。我在http://haacked.com/archive/2004/02/28/sql-auto-increment.aspx發現了一個與我的需求非常相似的示例,但不知道如何實現它。這例子是:使用一條語句在SQL中用增量日期更新列表?
DECLARE @counter int
SET @counter = 0
UPDATE #tmp_Users
SET @counter = counter = @counter + 1
我現在的說法是:
strSQL.CommandText = "Update tblItem set item_timed_close=convert(datetime, @item_timed_close),item_timed_start=convert(money, case when item_est_lo < 500 then ((convert(int,item_est_lo+25)/50)*50) when item_est_lo < 1000 then ((convert(int,item_est_lo+50)/100)*100) when item_est_lo < 3000 then ((convert(int,item_est_lo+125)/250)*250) when item_est_lo < 5000 then ((convert(int,item_est_lo+250)/500)*500) else ((convert(int,item_est_lo+12.5)/25)*25) end) Where [email protected]_sale_id";
strSQL.Parameters.Add(new SqlParameter("@item_timed_close", SqlDbType.VarChar, 100, ParameterDirection.Input, true, 0, 0, "item_timed_close", DataRowVersion.Current, datetime_Var.AddMinutes(minutes_Var += Increments_var)));
strSQL.Parameters.Add(new SqlParameter("@item_sale_id", SqlDbType.VarChar, 100, ParameterDirection.Input, true, 0, 0, "item_sale_id", DataRowVersion.Current, itemSaleId3_Var));
datetime_Var是用戶定義的,並且是一個DateTime
格式。 minutes_Var等於零開始。 Increments_var是用戶定義的。無論Increments_var
設置爲什麼,我都需要item_timed_close
來遞增。
編輯
結果我找了會是這樣的:
用戶指定的2012-01-08 12:00:00 PM
起始日期和10
秒的增量。對於每一行更新,日期將如下所示:
2012-01-08 12:00:00 PM
2012-01-08 12:00:10 PM
2012-01-08 12:00:20 PM
2012-01-08 12:00:30 PM
2012-01-08 12:00:40 PM
2012-01-08 12:00:50 PM
2012-01-08 12:01:00 PM
2012-01-08 12:01:10 PM
2012-01-08 12:01:20 PM
第一次約會甚至已經加入到它的所有我們關心的增加值,只要它遞增。我可以通過代碼改變最初的開始日期。
更新
與海軍的建議下,我嘗試了子查詢。首先,我將所有日期字段設置爲NULL。然後,我運行以下查詢:
strSQL3.CommandText = "Update tblItem set item_timed_close=DATEADD(minute,((Select count(*) as Count From tblItem Where [email protected]_sale_id And item_timed_close Is NULL) * @increment),convert(datetime, @item_timed_close)),item_timed_start=convert(money, case when item_est_lo < 500 then ((convert(int,item_est_lo+25)/50)*50) when item_est_lo < 1000 then ((convert(int,item_est_lo+50)/100)*100) when item_est_lo < 3000 then ((convert(int,item_est_lo+125)/250)*250) when item_est_lo < 5000 then ((convert(int,item_est_lo+250)/500)*500) else ((convert(int,item_est_lo+12.5)/25)*25) end) Where [email protected]_sale_id";
strSQL3.Parameters.Add(new SqlParameter("@item_timed_close", SqlDbType.VarChar, 100, ParameterDirection.Input, true, 0, 0, "item_timed_close", DataRowVersion.Current, datetime_Var));
strSQL3.Parameters.Add(new SqlParameter("@item_sale_id", SqlDbType.Int, 5, ParameterDirection.Input, true, 0, 0, "item_sale_id", DataRowVersion.Current, itemSaleId3_Var));
strSQL3.Parameters.Add(new SqlParameter("@increment", SqlDbType.Int, 5, ParameterDirection.Input, true, 0, 0, "increment", DataRowVersion.Current, Increments_var));
我希望我可以在傳遞的變量乘以子查詢,但如預期沒有奏效。它似乎將每個字段的@increment
乘以1。我已經單獨運行select語句,它返回471.所以我知道該部分正常工作。我是否需要將Count
作爲整數或其他東西?
DONE
我終於得到它。我應該首先想到這一點....我必須改變我的更新字符串的常規Set
序列中的計數器變量。這是我的工作查詢。
Declare @auto Int
Set @auto = 0
Update tblItem
set item_timed_close = DATEADD(minute, (@auto * @increment), convert(datetime, @item_timed_close))
, item_timed_start = convert(money,
case when item_est_lo < 500 then ((convert(int, item_est_lo+25)/50)*50)
when item_est_lo < 1000 then ((convert(int, item_est_lo+50)/100)*100)
when item_est_lo < 3000 then ((convert(int, item_est_lo+125)/250)*250)
when item_est_lo < 5000 then ((convert(int, item_est_lo+250)/500)*500)
else ((convert(int,item_est_lo+12.5)/25)*25) end)
, @auto = (@auto + 1)
Where [email protected]_sale_id
所以我用我找到了原來的例子,只是拿出最後Set @counter
部分並將它放入我的更新字符串的set
參數。
你寫的查詢看起來有瑕疵......它運行正確嗎? – Naval 2012-01-05 17:22:04
@Naval是的,它是正確運行的。我只需要它也按照用戶指定的分鐘數遞增日期。 – James 2012-01-05 17:45:01