Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless
Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless
MSI FORGE GK600 TKL WIRELESS: switch lineari hot-swap, tripla connettività, display LCD e 5 strati di fonoassorbimento. Ottima in gaming, a 79,99 euro
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici
DJI porta un importante aggiornamento alla sua linea di gimbal camera tascabili con Osmo Pocket 4: sensore CMOS da 1 pollice rinnovato, gamma dinamica a 14 stop, profilo colore D-Log a 10 bit, slow motion a 4K/240fps e 107 GB di archiviazione integrata. Un prodotto pensato per i creator avanzati, ma che convince anche per l'uso quotidiano
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Il primo headset open-back della linea INZONE arriva a 200 euro con driver derivati dalle cuffie da studio MDR-MV1 e un peso record di soli 199 grammi
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 24-05-2011, 15:59   #1
holyfather
Junior Member
 
Iscritto dal: May 2011
Messaggi: 21
[SQL] Funzioni

Salve,
volevo chiervi è possibile definire delle funzioni in SQL ( MySql) ad esempio ipotizziamo abbia banalmente un campo x in tab, io vorrei scrivere una funzione power che preso in ingresso x me ne faccia il quadrato

select power( x ) from tab;

( l'esempio con power è per semplicità , ovviamente mi serve per task più complicati)

E' possibile fare la cosa direttamente in SQL ??

grazie !
holyfather è offline   Rispondi citando il messaggio o parte di esso
Old 24-05-2011, 22:19   #2
oNaSsIs
Member
 
L'Avatar di oNaSsIs
 
Iscritto dal: Apr 2007
Messaggi: 182
Certo che si.
oNaSsIs è offline   Rispondi citando il messaggio o parte di esso
Old 25-05-2011, 07:08   #3
holyfather
Junior Member
 
Iscritto dal: May 2011
Messaggi: 21
Quote:
Originariamente inviato da oNaSsIs Guarda i messaggi
Ok hai qualche link utile per cortesia visto che non riesco a trovarne ?
holyfather è offline   Rispondi citando il messaggio o parte di esso
Old 25-05-2011, 09:31   #4
WarDuck
Senior Member
 
L'Avatar di WarDuck
 
Iscritto dal: May 2001
Messaggi: 12966
Quote:
Originariamente inviato da holyfather Guarda i messaggi
Ok hai qualche link utile per cortesia visto che non riesco a trovarne ?
Quello che ti ha postato E' UN LINK .
WarDuck è offline   Rispondi citando il messaggio o parte di esso
Old 25-05-2011, 10:33   #5
holyfather
Junior Member
 
Iscritto dal: May 2011
Messaggi: 21
Quote:
Originariamente inviato da WarDuck Guarda i messaggi
Quello che ti ha postato E' UN LINK .
Lol se sono stordito :-) grazie :-) ora guardo
holyfather è offline   Rispondi citando il messaggio o parte di esso
Old 25-05-2011, 13:21   #6
holyfather
Junior Member
 
Iscritto dal: May 2011
Messaggi: 21
Quote:
Originariamente inviato da holyfather Guarda i messaggi
Lol se sono stordito :-) grazie :-) ora guardo
Ho guardato , ho capito come funzionano ma non riesco ad adattarle al mio scopo :-(

Con questo ad esempio mi mette nella variabile globale x la conversione in inch del primo valore di lunghezza, come faccio a farlo per tutta la colonna ??
Anche riuscendo a iterare la cosa, poi non so dove salvare i valori di conversione !

CREATE PROCEDURE converti (OUT rx INT)
BEGIN
DECLARE x INT;
DECLARE sp1_cursor CURSOR FOR SELECT lunghezza FROM tab;
OPEN sp1_cursor;
FETCH sp1_cursor INTO x;
CLOSE sp1_cursor;
SET rx = x/2.2;
END |

Grazie per l'aiuto !
holyfather è offline   Rispondi citando il messaggio o parte di esso
Old 25-05-2011, 15:02   #7
holyfather
Junior Member
 
Iscritto dal: May 2011
Messaggi: 21
Scusate mi sono dimenticato di diverlo comunque, ipotizziamo io abbia una tabella prova in cui vi è un campo lunghezza in cm.

Ora voglio convertire in inch con una store procedure;
Ho pensato quindi di fare una tabella conversione con un campo lunghezza dove andare ad inserire il valore convertito.

Nello specifico il codice sotto mi va in loop sul primo elemento T_T

Codice:
create procedure conv() 
begin declare finito int default 0;
declare x int; 
declare curl cursor for select lunghezza from prova; 
declare continue handler for sqlstate '02000' 
   set finito = 1;
open curl;
fetch curl into x; 
ciclo: while not finito do 
   insert into conversione (lunghezza) values (x/2.2); 
end while ciclo; end;|
holyfather è offline   Rispondi citando il messaggio o parte di esso
Old 25-05-2011, 15:07   #8
holyfather
Junior Member
 
Iscritto dal: May 2011
Messaggi: 21
Ho risolto ! mancava il fetch interno per passare al record successivo !
Mi sono accorto che però io volevo fare una roba del tipo

select conv( lunghezza) from prova; Come posso fare ? Dovrei mettere il campo lunghezza e la tabella prova come variabili incognite per la procedura e poi
effettuare una chiamata call conv(lunghezza,prova), però non so come metterle in incognita .. qualcuno sa aiutarmi ?? grazie !



Codice:
create procedure conv() 
begin declare finito int default 0;
declare x int; 
declare curl cursor for select lunghezza from prova; 
declare continue handler for sqlstate '02000' 
   set finito = 1;
open curl;
fetch curl into x; 
ciclo: while not finito do 
   insert into conversione (lunghezza) values (x/2.2); 
   fetch curl into x;
end while ciclo; end;|

Ultima modifica di holyfather : 25-05-2011 alle 15:19.
holyfather è offline   Rispondi citando il messaggio o parte di esso
Old 25-05-2011, 22:09   #9
oNaSsIs
Member
 
L'Avatar di oNaSsIs
 
Iscritto dal: Apr 2007
Messaggi: 182
Forse il Prepared Statement fa al caso tuo.
Qui c'è anche un esempio su come potresti utilizzarlo.
Codice:
SET @s := CONCAT('SELECT AVG(' , 'Population' , ') FROM ' , 'City');
SELECT @s;
+----------------------------------+
| @s |
+----------------------------------+
| SELECT AVG(Population) FROM City |
+----------------------------------+
Codice:
PREPARE stmt FROM "SELECT AVG(Population) FROM City";
EXECUTE stmt;
+-----------------+
| AVG(Population) |
+-----------------+
| 350468.2236 |
+-----------------+
oNaSsIs è offline   Rispondi citando il messaggio o parte di esso
Old 27-05-2011, 10:25   #10
holyfather
Junior Member
 
Iscritto dal: May 2011
Messaggi: 21
Quote:
Originariamente inviato da oNaSsIs Guarda i messaggi
Forse il Prepared Statement fa al caso tuo.
Qui c'è anche un esempio su come potresti utilizzarlo.
Codice:
SET @s := CONCAT('SELECT AVG(' , 'Population' , ') FROM ' , 'City');
SELECT @s;
+----------------------------------+
| @s |
+----------------------------------+
| SELECT AVG(Population) FROM City |
+----------------------------------+
Codice:
PREPARE stmt FROM "SELECT AVG(Population) FROM City";
EXECUTE stmt;
+-----------------+
| AVG(Population) |
+-----------------+
| 350468.2236 |
+-----------------+
Bella ! grazie !
holyfather è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless Tastiera gaming MSI GK600 TKL: switch hot-swap, ...
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici DJI Osmo Pocket 4: la gimbal camera tascabile cr...
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori Sony INZONE H6 Air: il primo headset open-back d...
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA Nutanix cambia pelle: dall’iperconvergenza alla ...
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta Recensione Xiaomi Pad 8 Pro: potenza bruta e Hyp...
Annunciata la tuta di volo di Vast che s...
Vast presenta il nuovo Large Docking Ada...
Una denuncia getta ombre sulle batterie ...
DJI Avata 2 Fly Smart Combo a 526€: il d...
Alla guida della nuova auto elettrica ci...
GeForce RTX 3060 12 GB a giugno di nuovo...
Apple Music sarà sponsor ufficiale di Po...
The Mandalorian & Grogu: trailer fin...
Fedeltà record: Apple blinda gli utenti,...
Volkswagen ID.3 Neo: fino a 630 km di au...
GPU-Z mette i dati personali a rischio? ...
La PS6 potrebbe essere retrocompatibile ...
Amazfit Cheetah 2 Pro arriva in Italia: ...
Duolingo ammette l'errore dopo un anno: ...
Samsung Galaxy Tab S10 Lite a 249€: il t...
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: 00:06.


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