Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Nuova frontiera per i robot tagliaerba, con Ecovacs GOAT O1200 LiDAR Pro che riconosce l'ambiente in maniera perfetta, grazie a due sensori LiDAR, e dopo la falciatura può anche rifinire il bordo con il tagliabordi a filo integrato
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Equilibrio e potenza definiscono il Samsung Galaxy S26+, un flagship che sfida la variante Ultra e la fascia alta del mercato con il primo processore mobile a 2nm. Pur mantenendo l'hardware fotografico precedente, lo smartphone brilla per un display QHD+ da 6,7 pollici d'eccellenza, privo però del trattamento antiriflesso dell'Ultra, e per prestazioni molto elevate. Completano il quadro la ricarica wireless a 20W e, soprattutto, un supporto software settennale
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti
Zeekr sbarca ufficialmente in Italia con tre modelli elettrici premium, X, 7X e 001, distribuiti da Jameel Motors su una rete di 52 punti vendita già attivi. La Zeekr X parte da 39.900 euro, la 7X da 54.100: piattaforma a 800V, chip Snapdragon di ultima generazione, ricarica ultraveloce e un'autonomia dichiarata fino a 615 km WLTP. Le prime consegne sono previste a metà aprile
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 24-01-2011, 14:16   #1
xirc85
Member
 
L'Avatar di xirc85
 
Iscritto dal: Sep 2007
Città: Trento
Messaggi: 91
Oracle: ricerca su tutte le tabelle si uno schema

Ciao a tutti,
avrei bisogno di ricercare in maniera efficiente il valore massimo utilizzato all'interno di uno schema come chiave primaria su tutte le tabelle. Il campo ha lo stesso nome e lo stesso tipo per tutte le tabelle.. Ho fatto alcune prove ma non riesco a venirne a capo.. qualcuno sa dirmi come si può fare?
xirc85 è offline   Rispondi citando il messaggio o parte di esso
Old 24-01-2011, 20:43   #2
gokan
Senior Member
 
L'Avatar di gokan
 
Iscritto dal: Apr 2002
Città: Palermo
Messaggi: 4913
magari esistono particolari funzioni, però potresti provare a :
- farti dare tutte le tabelle di uno schema (
- successivamente per ogni tabella fare una ricerca del max(column)

Non so se questa cosa la devi infilare dentro un programma che risiede sul db oppure devi realizzarla in un altro linguaggio di programmazione.

ciao
__________________
Sun Certified Java Programmer - Sun Certified Web Component Developer - Sun Certified Business Component Developer
gokan è offline   Rispondi citando il messaggio o parte di esso
Old 24-01-2011, 21:04   #3
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
Trucchi valgono?

Codice:
SELECT 'SELECT chiaveprimaria FROM  '||name||' UNION ALL ' FROM tab
Questa ti restituisce una lunga stringa tipo

Codice:
SELECT chiaveprimaria FROM ordini
UNION ALL
SELECT chiaveprimaria FROM clienti
UNION ALL
...
SELECT chiaveprimaria FROM fatture
UNION ALL
Ti bastera' quindi prendere questo risultato, giustapporci
SELECT MAX(chiaveprimaria) FROM (

cancellare l'ultimo UNION ALL
e postporre una parentesi chiusa )

per ottenre quindi
Codice:
SELECT MAX(chiaveprimaria) FROM (
SELECT chiaveprimaria FROM ordini
UNION ALL
SELECT chiaveprimaria FROM clienti
UNION ALL
...
SELECT chiaveprimaria FROM fatture
)
Ti ritroverai con una nuova query, che potrai lanciare ed ottenere il risultato.
Togli eventuali riferimenti a tabelle che non servono.

Ovvero, fai scrivere le query dal database.
e, in generale, fai scrivere quanto piu' codice possibile da generatori di codice, eventualmente scritti da te.
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto.
E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test.

Ultima modifica di gugoXX : 24-01-2011 alle 21:06.
gugoXX è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2011, 07:54   #4
xirc85
Member
 
L'Avatar di xirc85
 
Iscritto dal: Sep 2007
Città: Trento
Messaggi: 91
Grazi mille,
adesso provo a fare la query, ma sarà alquanto lunga, dato che sono più di 140 tabelle
xirc85 è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2011, 08:42   #5
xirc85
Member
 
L'Avatar di xirc85
 
Iscritto dal: Sep 2007
Città: Trento
Messaggi: 91
uhm.. ho provato con la prima query (SELECT 'SELECT id FROM '||name||' UNION ALL ' FROM tab) però mi da ORA-00904: "NAME": invalid identifier...
xirc85 è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2011, 09:01   #6
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
Quote:
Originariamente inviato da xirc85 Guarda i messaggi
uhm.. ho provato con la prima query (SELECT 'SELECT id FROM '||name||' UNION ALL ' FROM tab) però mi da ORA-00904: "NAME": invalid identifier...
allora, "Name" come nome di colonna della tabella "tab" l'ho sparato, perche' non ricordo e non ho un'istanza oracle.
PRova
SELECT * from tab
e deduci da te il nome della colonna che contiene i nomi delle tabelle.
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto.
E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test.
gugoXX è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2011, 09:16   #7
xirc85
Member
 
L'Avatar di xirc85
 
Iscritto dal: Sep 2007
Città: Trento
Messaggi: 91
Ho fatto così:
SELECT 'SELECT id FROM '||tname||' UNION ALL ' FROM tab
e adesso funziona a meraviglia

Grazie mille!!!
xirc85 è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2011, 09:17   #8
shinya
Senior Member
 
L'Avatar di shinya
 
Iscritto dal: Jul 2005
Città: Bologna
Messaggi: 1130
Oh, non l'ho testata eh! Per compilare compila... prova un po'!
Codice:
create or replace function max_tables_pk (p_owner in varchar2)
  return number
is
  l_max number := 0;
  l_candidate number;
  l_query varchar2(2000); 
begin
  for table_list in (select table_name from all_tables where owner = p_owner)
  loop
    l_query := 'select max(nome_campo_pk) from ' || table_list.table_name;
    execute immediate l_query into l_candidate;
    if l_candidate > l_max then
      l_max := l_candidate;
    end if;
  end loop;
  
  return l_max;
exception
  when others then
    raise_application_error(-20000, 'Holy shit! ' || sqlerrm);
end max_tables_pk;
/
Ovviamente alla riga 10 sostituisci 'nome_campo_pk' con il nome vero...
In input prende l'owner dello schema delle tabelle che ti interessano.

edit: niente, ho visto che hai risolto! Troppo tardi! Tempismo perfetto come al solito
shinya è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato Ecovacs Goat O1200 LiDAR Pro: la prova del robot...
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere? Recensione Samsung Galaxy S26+: sfida l'Ultra, m...
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti Zeekr X e 7X provate: prezzi, autonomia fino a 6...
Marathon: arriva il Fortnite hardcore Marathon: arriva il Fortnite hardcore
HP Imagine 2026: abbiamo visto HP IQ all’opera, ecco cosa può (e non può) fare HP Imagine 2026: abbiamo visto HP IQ all’opera, ...
Nuove fotografie dagli astronauti di Art...
La toilette della capsula Orion Integrit...
GeForce NOW: ecco tutte le novità in arr...
Il Realme 16 5G debutta sul mercato glob...
HONOR svela tre nuovi tablet: il più int...
Tineco Floor One S9 Master: aspira e pul...
Vivo X300 Ultra, il lancio globale è ini...
Offerte robot aspirapolvere Amazon: ECOV...
L'AI genera codice in 8 minuti e i senio...
Ring Intercom Audio a 44,99€ su Amazon: ...
Apple iPhone 16 crolla a 689€: ecco perc...
Google Pixel 9 a 449,90€ con caricatore ...
Ecco la top 7 delle offerte Amazon, aggi...
Ex ingegnere ammette il sabotaggio: migl...
I coupon nascosti di Amazon si rinnovano...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 23:50.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v