Nie jesteś zalogowany.
Jeśli nie posiadasz konta, zarejestruj je już teraz! Pozwoli Ci ono w pełni korzystać z naszego serwisu. Spamerom dziękujemy!

Ogłoszenie

Prosimy o pomoc dla małej Julki — przekaż 1% podatku na Fundacji Dzieciom zdazyć z Pomocą.
Więcej informacji na dug.net.pl/pomagamy/.

#1  2017-09-07 14:49:20

  debbie - Użytkownik

debbie
Użytkownik
Zarejestrowany: 2006-09-19

SQL i Uptade do tabeli wyników z selecta

Witam

mam taką zagwozdkę.

Robię zapytanie selectem do paru tabel
( zwykły select ) który wystawia mi dane.

Oczywiście stworzyłem nową tabelę uzywając INTO w zapytaniu selecta.
Nowa tabela posiada wszystkie dane które wyrzucił mi ten select.

kombinuje nad UPDATE'em teraz w taki sposób aby wynik z tego selecta
dodawał do nowej tabeli tylko to co doszło nowego.

Select oraz stworzenie na jego podstawie nowej tabeli:

Kod:

select 
a.ID as a.id_user,
a.Nazwisko as Nazwisko_pracownika,
a.Imie as Imie_pracownika,
a.Email as Email_pracownika, 
a.loginas Login_pracownika,
c.ID as ID_Stanowiska, c.Nazwa as Nazwa_stanowiska,
e.ID_Pion as ID_Pion_1, e.Pion as Nazwa_Pionu_1,
a.IDoddzial as ID_Dzial_1, b.Nazwa as Nazwa_Dzialu_1,

-- into dla nowej tabeli
INTO nowa_tabela 

from pracownik a
left join dzial1 b on a.IDOddzial = b.ID
left join stanow1 c on a.IDStanowisko = c.ID
left join PRACDANE1 d on a.ID = d.IDPracownik
left join pion1 e on a.IDOddzial = e.ID
where c.Nazwa is not null

oraz select który wyswietla mi dane
z tabel...
chodzi o to...żeby dane były aktualizowane
do tej nowej tabeli... ( tylko to co jest nowe )

Kod:

select 
a.ID as a.id_user,
a.Nazwisko as Nazwisko_pracownika,
a.Imie as Imie_pracownika,
a.Email as Email_pracownika, 
a.loginas Login_pracownika,
c.ID as ID_Stanowiska, c.Nazwa as Nazwa_stanowiska,
e.ID_Pion as ID_Pion_1, e.Pion as Nazwa_Pionu_1,
a.IDoddzial as ID_Dzial_1, b.Nazwa as Nazwa_Dzialu_1,

from pracownik a
left join dzial1 b on a.IDOddzial = b.ID
left join stanow1 c on a.IDStanowisko = c.ID
left join PRACDANE1 d on a.ID = d.IDPracownik
left join pion1 e on a.IDOddzial = e.ID
where c.Nazwa is not null

Ma ktoś pomysł na to?

Ostatnio edytowany przez debbie (2017-09-07 14:56:53)


debbie
Wrócę jak zjem zupę i drugie danie - tyle
a oto ta zupa:

Offline

 

#2  2017-09-07 15:07:48

  ethanak - Użytkownik

ethanak
Użytkownik
Skąd: Ungwenor
Zarejestrowany: 2010-07-19
Serwis

Re: SQL i Uptade do tabeli wyników z selecta

Rozumiem że to jest jedyny znany Ci silnik DB (mianowicie MySQL).
Po pierwsze: pisz jakieś ego silnika używasz (bo za chwilę ktoś poda rozwuązanie do Oracla albo MSSQL i będziesz siedział i nogi moczył).
Po drugie: w Postgresie to prosty trigger.


Nim mechaniczne larum zagrasz mi, kanalio,
głosząc nadejście Javy - śmiertelnego wroga!
Zespół Adwokacki Dyskrecja

Offline

 

#3  2017-09-07 15:15:12

  debbie - Użytkownik

debbie
Użytkownik
Zarejestrowany: 2006-09-19

Re: SQL i Uptade do tabeli wyników z selecta

to MSSQL ...


debbie
Wrócę jak zjem zupę i drugie danie - tyle
a oto ta zupa:

Offline

 

#4  2017-09-08 09:53:32

  debbie - Użytkownik

debbie
Użytkownik
Zarejestrowany: 2006-09-19

Re: SQL i Uptade do tabeli wyników z selecta

To może inaczej....

Mam dwie tabele - tabela1 i tabela2

obie tabele zawierają takie same dane
ale tylko tabela1 uzupełniana jest o nowe dane.

Potrzebuję więc wykonać update... tabela2
ale tylko o nowe dane z tabela1.


debbie
Wrócę jak zjem zupę i drugie danie - tyle
a oto ta zupa:

Offline

 

#5  2017-09-08 10:27:32

  ponury_kostek - Użytkownik

ponury_kostek
Użytkownik
Skąd: Wałbrzych
Zarejestrowany: 2007-01-02
Serwis

Re: SQL i Uptade do tabeli wyników z selecta

Nie możesz po prostu zrobic truncate na tabele2 i wgrac do niej na nowo dane tym zapytaniem?

Offline

 

#6  2017-09-08 10:36:46

  debbie - Użytkownik

debbie
Użytkownik
Zarejestrowany: 2006-09-19

Re: SQL i Uptade do tabeli wyników z selecta

Myslę, że mogłoby to być mało optymalne w przyszłości...
dlatego myślę nad updatem... chyba, że jest jeszcze inna forma


debbie
Wrócę jak zjem zupę i drugie danie - tyle
a oto ta zupa:

Offline

 

#7  2017-09-08 10:57:25

  ponury_kostek - Użytkownik

ponury_kostek
Użytkownik
Skąd: Wałbrzych
Zarejestrowany: 2007-01-02
Serwis

Re: SQL i Uptade do tabeli wyników z selecta

To powinno być dla Ciebie idealne https://stackoverflow.com/a/108420/5361130

Offline

 

#8  2017-09-09 14:53:13

  ethanak - Użytkownik

ethanak
Użytkownik
Skąd: Ungwenor
Zarejestrowany: 2010-07-19
Serwis

Re: SQL i Uptade do tabeli wyników z selecta

Hm... Nie znam mssqlizmów, nie wiem ile tam masz rekordów, ale w każdej bazie danych masz jakiś sposób obsługi wyjątków. Więc po po prostu pchasz dane do tabeli, a jakiś trigger/rule dba o to, aby dane się nie powtarzały.
Czyli jakiś constraint na dane, i "do nothing" jeśli się powtarzają.


Nim mechaniczne larum zagrasz mi, kanalio,
głosząc nadejście Javy - śmiertelnego wroga!
Zespół Adwokacki Dyskrecja

Offline

 

#9  2017-09-12 17:59:25

  jezoo - Dzięcioł

jezoo
Dzięcioł
Skąd: Z lasu
Zarejestrowany: 2005-09-02

Re: SQL i Uptade do tabeli wyników z selecta

Numero Uno: https://docs.microsoft.com/en-us/sql/t-sql/statemen … -transact-sql
Numero duo: https://stackoverflow.com/a/16870672/1506848
tre: http://mmulawa.blogspot.com/2011/04/triggery-dml-w-ms-sql-server.html

Quatro już nie ma bo mi sie nie "kciało"

Tak jak ethanak napisał to są triggery anie jakieś zombi czy gnomy


LRU #480459

Offline

 

Stopka forum

Powered by PunBB
© Copyright 2002–2005 Rickard Andersson
Nas ludzie lubią po prostu, a nie klikając w przyciski ;-)