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

Вниз

Коллеги! Помогите написать процедурку обновления....   Найти похожие ветки 

 
BCPP_Builder_Dev ©   (2002-10-09 15:26) [0]

Собственно имеется 2 таблицы:
MassMedia в которой есть текстовое "PubHouse";
и MassMediaPubHouses - с двумя полями:
MMPHID - integer
PubHousename - varchar.

Надобно написать процедурку осуществляющую нормализацию, т.е. в Massmedia.Phouse должно быть значение ключа из MassMediaPubHouses.

Так как раньше никогда не делал, возникли сложности с использованием переменных, как собственно передать переменные из выборки курсора дальше для обновления данных?

CREATE PROCEDURE [dbo].[sp_GENERAL_UPDATER] AS

DECLARE @PH INT
DECLARE @PHN VARCHAR
DECLARE MMPH CURSOR FOR

SELECT * FROM MassMediaPubHouses

OPEN MMPH

FETCH NEXT FROM MMPH


WHILE (@@FETCH_STATUS = 0)
BEGIN
SET @PH = MMPH.MMPHID
SET @PHN = MMPH.PubHouseName
UPDATE MassMedia SET PubHouse = @PH WHERE PubHouse = @PHN
FETCH NEXT FROM MMPH
END

CLOSE MMPH
DEALLOCATE MMPH
GO


 
BCPP_Builder_Dev ©   (2002-10-09 17:23) [1]

Ну неужели никто не поможет????!!!!


 
still ©   (2002-10-09 17:28) [2]

еще раз другими словами объясни, плз


 
BCPP_Builder_Dev ©   (2002-10-09 17:34) [3]

Таблицу засосал из екселя, ес-но там все поля текстовые. Разбиваю структуру на СУБД.
Делаю таблицу типа: список возможных значений с двумя полями: ключ и текстовое поле с названием.
а в основной табличке делаю ключ вместо текстового поля. Разумеется перегон всего этого дела требует усилий (не руками же енто делать).

В моем случае основная таблица А, в ней есть поле х типа текст
Дочерняя таблица-свойство х - В, в ней ключ К и название свойства Н.

CREATE PROCEDURE [dbo].[sp_GENERAL_UPDATER] AS

DECLARE @PH INT
DECLARE @PHN VARCHAR
DECLARE MMPH CURSOR FOR

SELECT * FROM В

OPEN MMPH

FETCH NEXT FROM MMPH


WHILE (@@FETCH_STATUS = 0)
BEGIN
SET @PH = MMPH.MMPHID
SET @PHN = MMPH.PubHouseName
UPDATE А SET х = @PH WHERE х = @PHN
FETCH NEXT FROM MMPH
END

CLOSE MMPH
DEALLOCATE MMPH
GO



 
Best Before 2024   (2002-10-09 17:36) [4]



CREATE PROCEDURE [dbo].[sp_GENERAL_UPDATER] AS

DECLARE @VAR1 INT
DECLARE @VAR2 VARCHAR
DECLARE MMPH CURSOR FOR
SELECT FVAR1, FVAR2 FROM MassMediaPubHousesOPEN MMPH

FETCH NEXT FROM MMPH INTO @VAR1, @VAR2

WHILE (@@FETCH_STATUS = 0)
BEGIN
UPDATE MassMedia SET PubHouse = @PH WHERE PubHouse = @PHN
FETCH NEXT FROM MMPH INTO @VAR1, @VAR2
END

CLOSE MMPH
DEALLOCATE MMPH
GO


 
wicked ©   (2002-10-09 20:27) [5]

это что, каждый раз так надо делать?....
если это одноразовая акция, то можно обойтись парой запросов... только структуру таблиц приведи хоть немного...



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

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

Наверх




Память: 0.48 MB
Время: 0.01 c
1-101327
Treiber
2002-10-20 16:03
2002.10.31
Rasbivka stringa na reals


1-101206
brestmarket
2002-10-21 11:38
2002.10.31
Почему может не работать этот код на некоторых PC: Windows или IE


3-101176
Serginio
2002-10-11 12:29
2002.10.31
1С на Delphi


4-101589
Klev.J
2002-09-09 19:30
2002.10.31
Hints исключительно на WIN API


1-101270
DimonForever :)
2002-10-19 00:51
2002.10.31
Обработка событий для компонентов, созданных в Run-Time