Форум программистов, компьютерный форум, киберфорум
Microsoft SQL Server
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
7 / 0 / 0
Регистрация: 31.10.2013
Сообщений: 3
1

Перемещение внутри дерева

11.11.2013, 17:49. Показов 721. Ответов 0
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Здравствуйте!я начинающий программист, поэтому может логика быть сформулирована не так как нужно.
Мне необходимо написать хранимку, выполняющая перемещение узлов внутри дерева. всего у меня 7 уровней. Получаю id, P0,P1,...,P7.Как можно это реализовать?
Нужно ли мне использовать курсор или можно обойтись без него?
Вот попытки для одного уровня, но они не увенчались успехом, так как перемещать в узел могу узел только такого же типа и после обновления все возвращается на свое место:
T-SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
USE [ProjectA2]
GO
/****** Object:  StoredProcedure [a74].[account_tree_move]    Script Date: 11/11/2013 12:54:57 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
ALTER procedure [a74].[account_tree_move]
@et int,
@pk int,
@id int,
@p0 int = 0,
@p1 int = 0,
@p2 int = 0,
@p3 int = 0,
@p4 int = 0,
@p5 int = 0,
@p6 int = 0,
@p7 int = 0,
@shtcut bit = 0
 
as
set nocount on
begin tran
 
declare @tbl nvarchar(32)
declare @sql nvarchar(1024)
declare @prm nvarchar(255)
 
exec apx_et_treename @et, @tbl OUT
if @tbl is null
  begin
    rollback tran
    raiserror (N'Недопустимое значение аргумента',16,-1)
    return 0
  end
 
if @pk = 0
  begin
    select @sql = N'insert into ' + @tbl + N'(ID,P0,P1,P2,P3,P4,P5,P6,P7,SHORTCUT) ' +
          N'VALUES (@id,@p0,@p1,@p2,@p3,@p4,@p5,@p6,@p7,@shtcut)'
    select @prm = N'@id int, @p0 int, @p1 int, @p2 int, @p3 int, @p4 int, @p5 int, @p6 int, @p7 int, @shtcut bit'
    execute sp_executesql @sql, @prm, @id, @p0,@p1,@p2,@p3,@p4,@p5,@p6,@p7,@shtcut
  end
else
  begin
    select @sql = N'update ' + @tbl + N' set P0=@p0,P1=@p1,P2=@p2,P3=@p3,' +
                  N'P4=@p4,P5=@p5,P6=@p6,P7=@p7,SHORTCUT=@shtcut ' +
          N'where PK=@pk '
    select @prm = N'@pk int, @p0 int, @p1 int, @p2 int, @p3 int, @p4 int, @p5 int, @p6 int, @p7 int, @shtcut bit'
    execute sp_executesql @sql, @prm, @pk, @p0,@p1,@p2,@p3,@p4,@p5,@p6,@p7,@shtcut
  end
commit tran
Спасибо заранее за внимание.
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
11.11.2013, 17:49
Ответы с готовыми решениями:

Перемещение внутри Bootstrap
Есть код с использованием Bootstrap , но как переместить элемент чуть левее? И я не буду выходить...

Перемещение внутри shelllistview
Всем доброго времени суток. Прошлый вопрос по обновлению внутри shelllistview после редактирования...

Перемещение внутри формы
Подскажите, а можно ли при нажатии на кнопку, переходить на уровень ниже (чтобы там например ещё...

Перемещение PictureBox внутри TableLayoutPanel
Есть TableLayoutPanel разбитая на шесть равных строк и столбцов. В случайной позиции должен...

0
11.11.2013, 17:49
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
11.11.2013, 17:49
Помогаю со студенческими работами здесь

Перемещение картинки внутри прямоугольника
Есть приложение с background image. В середине background image есть прямоугольник. В данный...

Перемещение картинки внутри Image
Есть картинка (допустим) 100x100 пикселей Есть Image (на нашей форме) (допустим) 50х50 пикселей ...

Перемещение элементов внутри deque
Пытаюсь реализовать класс чекера прокси . Логика примерно такая : Объекты прокси хранятся в deque...

Перемещение картинки внутри Image
итак, вот что мне в голову пришло, зачемто: есть Image1, в который загружена картинка, больше...

Перемещение внутри многомерного массива
Есть многомерный массив. Надо сделать чтобы можно было нажимая на кнопку сортировать по алфавиту...

Перемещение элемента внутри массива
подскажите как сделать движение "*" по массиву без управления клавиотурой


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru