私のアプリケーションでは、select (MSSQL) で TADOQuery を使用し、TClientDataSet とリンクしています。約 100 万件のレコードと ApplyUpdates を挿入する必要があります。
では、SQL Server Profiler には何が表示されるのでしょうか? 挿入された行ごとに、3 つのクエリがあることがわかります。挿入スクリプトの sp_prepare、いくつかの値を指定した sp_execute、および sp_unprepare です。
挿入する前にすべてのレコードに対してSQLを1回準備し、後で準備を解除したいだけです。どうすればいいですか?
の後に追加:
クエリには、ストアド プロシージャを実行するためのスクリプトがあります。
tmpQuery := DefineQuery(FConnection, [
'exec up_getOperatorDataSet ',
' @tablename = :tablename, ',
' @operator = :operator, ',
' @forappend = :forappend, ',
' @withlinksonly = :withlinksonly, ',
' @ids = :ids '
], [
Param(ftString, sTableName),
Param(ftInteger, FOperatorId),
Param(ftBoolean, opForAppendOnly in OpenParams),
Param(ftBoolean, opOnlyWithModelLinks in OpenParams),
Param(ftString, sIds)
], Result);
いくつかのパラメーターを使用して、テーブルsTableNameからすべてのフィールドを選択します。
プロファイラーから挿入する例:
ステップ1:
declare @p1 int
set @p1=486
exec sp_prepare @p1 output,N'@P1 int,@P2 int,@P3 datetime,@P4 int,@P5 int,@P6 int,@P7 int,@P8 int,@P9 varchar(128),@P10 bit,@P11 numeric(19,4),@P12 smallint,@P13 smallint,@P14 smallint,@P15 smallint',N'insert into parser_prices
(operator_id, request_id, date, nights, model_hotel_id, model_meal_id, model_room_id, model_htplace_id, spo, hotelstop, price, frout_econom, frout_business, frback_econom, frback_business)
values
(@P1, @P2, @P3, @P4, @P5, @P6, @P7, @P8, @P9, @P10, @P11, @P12, @P13, @P14, @P15)
',1
select @p1
ステップ2:
exec sp_execute 486,21,2000450,'2009-12-04 00:00:00',14,2118,22,-9555,18,'2009-10.MSK.Bali.13.10.09-27.03.10',0,15530.0000,3,3,3,3
ステップ 3:
exec sp_unprepare 486
それはすべての新しい行のためのものです。