Tengo una estructura de tabla simple como esta:
Tabla tempData
╔══════════╦═══════╗
║ NAME ║ MARKS ║
╠══════════╬═══════╣
║ Narendra ║ 80 ║
║ Ravi ║ 85 ║
║ Sanjay ║ 90 ║
╚══════════╩═══════╝
Y también tengo otros nombres de tablas como tempDataView como este
╔══════════╦═══════╗
║ NAME ║ MARKS ║
╠══════════╬═══════╣
║ Narendra ║ ║
║ Narendra ║ ║
║ Narendra ║ ║
║ Narendra ║ ║
║ Ravi ║ ║
║ Ravi ║ ║
║ Sanjay ║ ║
╚══════════╩═══════╝
Quiero actualizar la tabla tempDataView , estableciendo las Marcas de acuerdo con tempDataView - Nombre en comparación con tempData - Nombre
Sí, déjame mostrarte lo que intenté, intenté resolver esto usando el Cursor y se resolvió perfectamente, pero estoy encontrando la manera de resolverlo usando la Subconsulta
Aquí está:
Declare @name varchar(50),@marks varchar(50)
Declare @cursorInsert CURSOR
set @cursorInsert = CURSOR FOR
Select name,marks from tempData
OPEN @cursorInsert
FETCH NEXT FROM @cursorInsert
into @name,@marks
WHILE @@FETCH_STATUS = 0
BEGIN
UPDATE tempDataView set marks = @marks where name = @name
FETCH NEXT FROM @cursorInsert
INTO @name,@marks
END
CLOSE @cursorInsert
DEALLOCATE @cursorInsert
En realidad, es como una tarea para mí resolverlo usando la Subconsulta.