Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Ecovacs Deebot X12 OmniCyclone: lava grazie a FocusJet
Ecovacs Deebot X12 OmniCyclone: lava grazie a FocusJet
Il nuovo Deebot X12 OmniCyclone abbina un sistema di raccolta dello sporco senza sacchetto, un rullo di lavaggio esteso e la tecnologia FocusJet per intervenire più efficacemente sulle macchie più persistenti. Un robot completo e preciso che aiuta a tenere puliti i pavimenti di casa con il minimo sforzo
Narwal Flow 2: la pulizia di casa con un mocio a nastro
Narwal Flow 2: la pulizia di casa con un mocio a nastro
Narwal Flow 2 implementa un mocio a nastro che esegue una pulizia dettagliata del pavimento di casa, in abbinamento ad un potente motore di aspirazione della polvere: un prodotto ideale per gestire in autonomia e con grande efficacia le necessità di pulizia dei pavimenti di casa
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
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


Ecovacs Deebot X12 OmniCyclone: lava grazie a FocusJet Ecovacs Deebot X12 OmniCyclone: lava grazie a Fo...
Narwal Flow 2: la pulizia di casa con un mocio a nastro Narwal Flow 2: la pulizia di casa con un mocio a...
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...
Samsung ed Sk hynix, i bonus per gli ope...
Windows 11 velocizza Esplora File: ecco ...
Funzioni nascoste nelle librerie ADLX Ra...
Itala rinasce: lo storico marchio automo...
Huawei Watch Fit 5 e 5 Pro ufficiali: di...
ECOVACS DEEBOT T90 PRO OMNI vs Roborock ...
Fastweb scompare dai partner Starlink Mo...
Huawei anticipa tutti con Pura X Max: il...
Amazon Tech Week 2026: RTX 5000, process...
Grandi offerte Amazon su scope elettrich...
Amazon e Anthropic rafforzano la partner...
Elden Ring: il film arriverà fra ...
Mercato PC, +3,2% nel Q1 2026: Lenovo se...
Corsair Platform: scrivanie gaming modul...
Assassin's Creed Black Flag Resynced: Ub...
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: 12:49.


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