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
[color=blue]Wrócę jak zjem zupę i drugie danie - tyle[/color]
[color=blue]a oto ta zupa:[/color]

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!
[i]Zespół Adwokacki Dyskrecja[/i]

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
[color=blue]Wrócę jak zjem zupę i drugie danie - tyle[/color]
[color=blue]a oto ta zupa:[/color]

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
[color=blue]Wrócę jak zjem zupę i drugie danie - tyle[/color]
[color=blue]a oto ta zupa:[/color]

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
[color=blue]Wrócę jak zjem zupę i drugie danie - tyle[/color]
[color=blue]a oto ta zupa:[/color]

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!
[i]Zespół Adwokacki Dyskrecja[/i]

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/statements/create-trigger-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


[img]http://intershock.pl/images/icons/freebsd.jpg[/img] [img]http://www.the-eleven.com/site_media/static/img/postgresql_powered.png[/img] [img]http://www.wwgmc.com/images/badge_php.gif[/img]
LRU #480459

Offline

 

Stopka forum

Powered by PunBB
© Copyright 2002–2005 Rickard Andersson
Możesz wyłączyć AdBlock — tu nie ma reklam ;-)

[ Generated in 0.017 seconds, 11 queries executed ]

Informacje debugowania

Time (s) Query
0.00011 SET CHARSET latin2
0.00004 SET NAMES latin2
0.00074 SELECT u.*, g.*, o.logged FROM punbb_users AS u INNER JOIN punbb_groups AS g ON u.group_id=g.g_id LEFT JOIN punbb_online AS o ON o.ident='3.236.108.61' WHERE u.id=1
0.00409 UPDATE punbb_online SET logged=1593888312 WHERE ident='3.236.108.61'
0.00046 SELECT * FROM punbb_online WHERE logged<1593888012
0.00210 SELECT topic_id FROM punbb_posts WHERE id=314186
0.00074 SELECT id FROM punbb_posts WHERE topic_id=29891 ORDER BY posted
0.00063 SELECT t.subject, t.closed, t.num_replies, t.sticky, f.id AS forum_id, f.forum_name, f.moderators, fp.post_replies, 0 FROM punbb_topics AS t INNER JOIN punbb_forums AS f ON f.id=t.forum_id LEFT JOIN punbb_forum_perms AS fp ON (fp.forum_id=f.id AND fp.group_id=3) WHERE (fp.read_forum IS NULL OR fp.read_forum=1) AND t.id=29891 AND t.moved_to IS NULL
0.00008 SELECT search_for, replace_with FROM punbb_censoring
0.00125 SELECT u.email, u.title, u.url, u.location, u.use_avatar, u.signature, u.email_setting, u.num_posts, u.registered, u.admin_note, p.id, p.poster AS username, p.poster_id, p.poster_ip, p.poster_email, p.message, p.hide_smilies, p.posted, p.edited, p.edited_by, g.g_id, g.g_user_title, o.user_id AS is_online FROM punbb_posts AS p INNER JOIN punbb_users AS u ON u.id=p.poster_id INNER JOIN punbb_groups AS g ON g.g_id=u.group_id LEFT JOIN punbb_online AS o ON (o.user_id=u.id AND o.user_id!=1 AND o.idle=0) WHERE p.topic_id=29891 ORDER BY p.id LIMIT 0,25
0.00395 UPDATE punbb_topics SET num_views=num_views+1 WHERE id=29891
Total query time: 0.01419 s