Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2002.11.25;
Скачать: CL | DM;

Вниз

Помогите оптимизировать процедуру MSSQL2000   Найти похожие ветки 

 
Димон111   (2002-11-04 13:10) [0]

Нужно
1) вытащить из таблицы строчку,
2) Записать в другую табличку № этой строки,
3) вернуть ResulSet полученный в п.1

делаю так:

CREATE PROCEDURE DBO.PostsEvent
@FBarcode char(20)
AS
declare @fid int
SELECT @fid=ID FROM MyTable WHERE Barcode=@FBarcode
INSERT INTO LOG (CURRENT_TIMESTAMP, @fid ) // вставить значение из запроса
SELECT * FROM MyTable WHERE id=@fid
GO

приходится 2 раза открывать запрос, подскажите плиз , может как-нибудь лучше с курсором это сделать

спасибо


 
3JIA9I CyKA ©   (2002-11-04 13:16) [1]

Типа этого
declare
@p1 int,
@p2 varchar(10)
select
@p1 = id,
@p2 = [чё-то]
from [где-то]
where blablabla = "бу-бу-бу"

insert ....
select
ID = @p1,
[чё-то] = @p2


 
Димон111   (2002-11-04 13:22) [2]

2 3JIA9I CyKA ©

Проблема в том что, полей много, а одно из них вообще БЛОБ.

может что-то типа

DECLARE CURSOR MyCur
as select * from MyTable where Barcode=@Fbarcode
open MyCurr
INSERT INTO LOG (CURRENT_TIMESTAMP, MyCur.ID)
SELECT * FROM MyCurr



?


 
Димон111   (2002-11-04 14:14) [3]

Господа, есть ещё идеи?


 
Marcus   (2002-11-04 18:00) [4]

А чем тебя исходный вариант не устраивает. Все равно самая тормозная часть это SELECT @fid=ID FROM MyTable WHERE Barcode=@FBarcode, поскольку поиск по строке.
А выбор по id, да еще если это primary key, выполняется практически мгновенно. Так что это не поле для оптимизации



Страницы: 1 вся ветка

Текущий архив: 2002.11.25;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.014 c
1-82732
Jeka.
2002-11-15 06:23
2002.11.25
Scroll


7-83011
yurez
2002-09-24 10:59
2002.11.25
Access violation. в вин98 ошибки нет. в вин2000 -м выдается


14-83005
Красная Майка
2002-10-18 13:57
2002.11.25
Встреча мастаков в Московии.


1-82700
Comp
2002-11-14 12:46
2002.11.25
ShellAPI


14-82950
LamErP
2002-11-05 15:33
2002.11.25
Создание COM - dll