Torna indietro   Hardware Upgrade Forum > Software > Programmazione

DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta
DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta
DLSS 4.5 introduce Dynamic Multi Frame Generation e MFG 6X, permettendo fino a cinque frame generati per ogni frame renderizzato. I test su Cyberpunk 2077 e 007 First Light mostrano forti incrementi di FPS e riduzione della latenza su RTX 5090 Laptop. Migliorano fluidità, stabilità e qualità visiva.
Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere)
Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere)
Quattro modi di indossarlo, stessa app del Plaud Note Pro e integrazione con il desktop. Il registratore IA da indossare di Plaud eccelle in mobilità, ma resta vincolato all'abbonamento ed è facile da perdere
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro
Xiaomi ha portato Redmi Watch 6 anche sul mercato italiano, puntando su un display AMOLED da 2,07 pollici con picco di luminosità a 2000 nit, frame in alluminio da 9,9mm e un'autonomia dichiarata di 12 giorni. Lo smartwatch gira su HyperOS 3 e integra GPS, Bluetooth 5.4 e oltre 150 sport mode. Il tutto a meno di 100 euro
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 03-11-2007, 15:33   #1
das
Senior Member
 
Iscritto dal: Jan 2001
Città: Livorno
Messaggi: 1388
[C] mysql api

Volevo sapere se esiste tra le api del c di mysql (possibilmente 4) una funzione che restituisce true o false se esiste o meno un dato valore.

Adesso sto facendo in questo modo:

select * from ciao where campo1 = valoreX limit 1

Se mi restituisce almeno un valore la funzione restituisce true altrimenti false.

il problema è che questo sistema non è sicuramente il più veloce. Infatti quando le operazioni sono migliaia il programma è di una lentezza estenuante.

Grazie
das è offline   Rispondi citando il messaggio o parte di esso
Old 04-11-2007, 19:01   #2
das
Senior Member
 
Iscritto dal: Jan 2001
Città: Livorno
Messaggi: 1388
up
das è offline   Rispondi citando il messaggio o parte di esso
Old 08-11-2007, 07:52   #3
das
Senior Member
 
Iscritto dal: Jan 2001
Città: Livorno
Messaggi: 1388
up
das è offline   Rispondi citando il messaggio o parte di esso
Old 08-11-2007, 08:22   #4
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Messaggi: 5206
Quote:
Originariamente inviato da das Guarda i messaggi
Volevo sapere se esiste tra le api del c di mysql (possibilmente 4) una funzione che restituisce true o false se esiste o meno un dato valore.

Adesso sto facendo in questo modo:

select * from ciao where campo1 = valoreX limit 1

Se mi restituisce almeno un valore la funzione restituisce true altrimenti false.

il problema è che questo sistema non è sicuramente il più veloce. Infatti quando le operazioni sono migliaia il programma è di una lentezza estenuante.
Rispondo io, anche se premetto che non sono espertissimo di MySQL.
La questione principale è che con le API del MySQL (e questo varrebbe anche per altri DB, credo), puoi solamente eseguire delle query ed ottenere un "record-set".

Per dirla in altri termini, non ci sono funzioni per sapere se esiste o meno un dato valore ... tutto passa attraverso una query SQL e attraverso l'utilizzo di un result-set (anche per altre informazioni .. non solo per i dati veri e propri).

Se dici che quella query impiega molto tempo, posso pensare che 'campo1' non sia in chiave. Se lo fosse, sarebbe certamente molto molto più veloce.
__________________
Andrea, Senior Java developerSCJP 5 (91%) • SCWCD 5 (94%)
Java Versions Cheat Sheet
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 08-11-2007, 08:37   #5
das
Senior Member
 
Iscritto dal: Jan 2001
Città: Livorno
Messaggi: 1388
Ok,grazie.

Non sapevo se il mio metodo fosse il più 'elegante' possibile.

A quanto pare sì.

Comunque ora ho un altro problema:
La mia applicazione è multithread. Quando ogni thread inserisce dati nel database deve conoscere l'ID del dato che esso stesso ha inserito, e lo può sapere tramite mysql_insert_id() .

Solo che quella funzione restituisce l'ID dell'ultimo dato immesso, che potrebbe essere quello immesso da un altro thread e non dallo stesso che usa mysql_insert_id() .

Come potrei risolvere il problema ?

Ciao

Ultima modifica di das : 08-11-2007 alle 08:41.
das è offline   Rispondi citando il messaggio o parte di esso
Old 08-11-2007, 09:10   #6
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Quote:
Originariamente inviato da das Guarda i messaggi
Ok,grazie.

Non sapevo se il mio metodo fosse il più 'elegante' possibile.

A quanto pare sì.

Comunque ora ho un altro problema:
La mia applicazione è multithread. Quando ogni thread inserisce dati nel database deve conoscere l'ID del dato che esso stesso ha inserito, e lo può sapere tramite mysql_insert_id() .

Solo che quella funzione restituisce l'ID dell'ultimo dato immesso, che potrebbe essere quello immesso da un altro thread e non dallo stesso che usa mysql_insert_id() .

Come potrei risolvere il problema ?

Ciao
Benvenuto in uno dei difetti principali di MySQL. Non mi risulta esserci fino alla versione attuale una soluzione sicura al problema. Quello che faccio io è creare la query di inserimento seguita immediatamente da una "select max(pk)".

Comunque per quanto riguarda la query iniziale, io eseguireri
Codice:
select count(*) from ciao where campo1 = valoreX
dove campo1 è preferibilmente una chiave o indice della tabella ciao.
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 08-11-2007, 10:23   #7
trallallero
Senior Member
 
L'Avatar di trallallero
 
Iscritto dal: May 2006
Città: Wursteland
Messaggi: 1749
Quote:
Originariamente inviato da das Guarda i messaggi
Ok,grazie.

Non sapevo se il mio metodo fosse il più 'elegante' possibile.

A quanto pare sì.

Comunque ora ho un altro problema:
La mia applicazione è multithread. Quando ogni thread inserisce dati nel database deve conoscere l'ID del dato che esso stesso ha inserito, e lo può sapere tramite mysql_insert_id() .

Solo che quella funzione restituisce l'ID dell'ultimo dato immesso, che potrebbe essere quello immesso da un altro thread e non dallo stesso che usa mysql_insert_id() .

Come potrei risolvere il problema ?

Ciao
per il primo problema potresti usare una stored procedure

per il secondo perchè non un mutex ?
__________________
Nintendo WIII 4d Turbo Intercooler - Sestium X 666 99,312 GHz - 6.984 Ram Σ(9999) MHz - HDD SATA 97e^(10) bytes 93³ rpm - ATI biberon X900z Mb - Win Eight SP (1 > yours) 16 Valve
trallallero è offline   Rispondi citando il messaggio o parte di esso
Old 08-11-2007, 10:28   #8
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Quote:
Originariamente inviato da trallallero Guarda i messaggi
per il secondo perchè non un mutex ?
Perchè il mutex lo dovresti mettere sul server MySQL!
Se un altro processo scrive sul db, mysql_insert_id() ti restituisce l'id inserito da quel processo su cui non hai certo controllo.
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 08-11-2007, 10:29   #9
trallallero
Senior Member
 
L'Avatar di trallallero
 
Iscritto dal: May 2006
Città: Wursteland
Messaggi: 1749
Quote:
Originariamente inviato da tomminno Guarda i messaggi
Perchè il mutex lo dovresti mettere sul server MySQL!
Se un altro processo scrive sul db, mysql_insert_id() ti restituisce l'id inserito da quel processo su cui non hai certo controllo.
si ma è lui che scrive tramite i vari 3ds quindi potrebbe benissimo lockarli. Una scrittura alla volta
__________________
Nintendo WIII 4d Turbo Intercooler - Sestium X 666 99,312 GHz - 6.984 Ram Σ(9999) MHz - HDD SATA 97e^(10) bytes 93³ rpm - ATI biberon X900z Mb - Win Eight SP (1 > yours) 16 Valve
trallallero è offline   Rispondi citando il messaggio o parte di esso
Old 08-11-2007, 10:31   #10
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Quote:
Originariamente inviato da trallallero Guarda i messaggi
si ma è lui che scrive tramite i vari 3ds quindi potrebbe benissimo lockarli. Una scrittura alla volta
I suoi processi si, ma tutto il resto del mondo che accede al database non può essere bloccato da un mutex sui suoi processi.
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 08-11-2007, 11:48   #11
trallallero
Senior Member
 
L'Avatar di trallallero
 
Iscritto dal: May 2006
Città: Wursteland
Messaggi: 1749
Quote:
Originariamente inviato da tomminno Guarda i messaggi
I suoi processi si, ma tutto il resto del mondo che accede al database non può essere bloccato da un mutex sui suoi processi.
ovvio, ma davo per scontato che la tabella in questione la usasse solo lui
__________________
Nintendo WIII 4d Turbo Intercooler - Sestium X 666 99,312 GHz - 6.984 Ram Σ(9999) MHz - HDD SATA 97e^(10) bytes 93³ rpm - ATI biberon X900z Mb - Win Eight SP (1 > yours) 16 Valve
trallallero è offline   Rispondi citando il messaggio o parte di esso
Old 08-11-2007, 12:01   #12
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Quote:
Originariamente inviato da trallallero Guarda i messaggi
ovvio, ma davo per scontato che la tabella in questione la usasse solo lui
Non è solo per la tabella in questione, mysql_insert_id() è relativo a tutto il database.
Chiunque, su qualunque tabella del database scriva, causa una modifica del valore restituito da mysql_insert_id().

Un pò troppo azzardata come ipotesi.
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 08-11-2007, 12:06   #13
trallallero
Senior Member
 
L'Avatar di trallallero
 
Iscritto dal: May 2006
Città: Wursteland
Messaggi: 1749
Quote:
Originariamente inviato da tomminno Guarda i messaggi
Non è solo per la tabella in questione, mysql_insert_id() è relativo a tutto il database.
Chiunque, su qualunque tabella del database scriva, causa una modifica del valore restituito da mysql_insert_id().

Un pò troppo azzardata come ipotesi.
a beh, bella funzione, utilissima direi
__________________
Nintendo WIII 4d Turbo Intercooler - Sestium X 666 99,312 GHz - 6.984 Ram Σ(9999) MHz - HDD SATA 97e^(10) bytes 93³ rpm - ATI biberon X900z Mb - Win Eight SP (1 > yours) 16 Valve
trallallero è offline   Rispondi citando il messaggio o parte di esso
Old 08-11-2007, 12:15   #14
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Quote:
Originariamente inviato da trallallero Guarda i messaggi
a beh, bella funzione, utilissima direi
Infatti è un difetto grosso come una casa di MySQL e sinceramente non capisco perchè non facciano una funzione ad hoc per risolvere il problema, non mi sembra una cosa molto complicata, oltretutto pensando alla basilarità dell'operazione.
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 08-11-2007, 12:29   #15
trallallero
Senior Member
 
L'Avatar di trallallero
 
Iscritto dal: May 2006
Città: Wursteland
Messaggi: 1749
Quote:
Originariamente inviato da tomminno Guarda i messaggi
Infatti è un difetto grosso come una casa di MySQL e sinceramente non capisco perchè non facciano una funzione ad hoc per risolvere il problema, non mi sembra una cosa molto complicata, oltretutto pensando alla basilarità dell'operazione.
è open source ... falla tu
__________________
Nintendo WIII 4d Turbo Intercooler - Sestium X 666 99,312 GHz - 6.984 Ram Σ(9999) MHz - HDD SATA 97e^(10) bytes 93³ rpm - ATI biberon X900z Mb - Win Eight SP (1 > yours) 16 Valve
trallallero è offline   Rispondi citando il messaggio o parte di esso
Old 09-11-2007, 16:22   #16
das
Senior Member
 
Iscritto dal: Jan 2001
Città: Livorno
Messaggi: 1388
Quote:
Originariamente inviato da tomminno Guarda i messaggi
Non è solo per la tabella in questione, mysql_insert_id() è relativo a tutto il database.
Chiunque, su qualunque tabella del database scriva, causa una modifica del valore restituito da mysql_insert_id().

Un pò troppo azzardata come ipotesi.
Vorrà dire che faccio così:
Prima inserisco il dato.
Dopo vado a ricercarlo e leggo l'ID.

Lento ma sicuro.

Che tu sappia glia ltri database stile SQL non open, hanno lo stesso difetto ?
das è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta DLSS 4.5: con Dynamic Frame Generation e MFG 6X ...
Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere) Plaud NotePin S, il registratore IA si fa indoss...
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro Redmi Watch 6 in prova: lo smartwatch con ampio ...
Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ADV, ma con molti più pulsanti Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ...
Radeon RX 9070 GRE, AMD la porta in tutto il mondo | Recensione Gigabyte Gaming OC Radeon RX 9070 GRE, AMD la porta in tutto il mon...
Cina pronta a investire 295 miliardi di ...
Gli israeliani di NSO Group continuano a...
AMD scommette 2 miliardi di sterline sul...
WhatsApp annuncia la fine del supporto p...
La batteria miracolosa di Donut Lab potr...
Instagram introduce a livello globale la...
Google aggiorna Chrome: chiusa la quinta...
Il presidente è sicuro: "BYD...
La Commissione europea approva un piano ...
Roborock Qrevo Edge 2 a 699,99€: LDS ret...
Una sviluppatrice ottiene l'esenzione pe...
Oltre 340 testate locali bloccano Intern...
Un round di finanziamento da 1 milione p...
Pan-Good ha creato il motore elettrico a...
Lexar avverte: i prezzi della RAM potreb...
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: 13:49.


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