giovedì 2 aprile 2009

MySQL: Generare una chiave primaria per una tabella

Oggi ho avuto la necessità di generare una chiave primaria per una tabella. Siccome non ho molto in simpatia l'uso degli autoincrement ho deciso di costruirla sulla base di un campo varchar(30).

Una delle problematiche è che in una fase di insert massivo (il sistema riesce ad inserire alcune migliaia di record in un secondo) la generazione di questa stringa non è stata semplicissima.
Vediamo comunque le strategie usate partendo dal risultato finale.
SET @numero = 1;

SELECT CONCAT('DVBH',DATE_FORMAT(NOW(),'%Y%m%d%H%i%s'),LPAD(FLOOR(1 + RAND() * 999999),7,0),LPAD(@numero := @numero + 1,5,0)) AS RecordId
Leggendo così a primo colpo può quasi spaventare, ma vediamola passo passo.
La Set iniziale servirà più avanti e per ora evito di trattarla.
Innanzi tutto per ottenere una stringa avremo bisogno ci concatenare gli elementi che useremo per andare a formare la stringa.
SELECT CONCAT('DVBH',DATE_FORMAT(NOW(),'%Y%m%d%H%i%s'),LPAD(FLOOR(1 + RAND() * 999999),7,0),LPAD(@numero := @numero + 1,5,0)) AS RecordId
Come primo elemento aggiungiamo un prefisso (in questo caso di 4 lettere) che ci identifica la tabella o qualsiasi altra cosa vi possa venire in mente.
SELECT CONCAT('DVBH',DATE_FORMAT(NOW(),'%Y%m%d%H%i%s'),LPAD(FLOOR(1 + RAND() * 999999),7,0),LPAD(@numero := @numero + 1,5,0)) AS RecordId
Per la seconda parte utilizziamo la data attuale con precisione al secondo in tale maniera ogni volta che creeremo la chiave primaria si già diversa in dipendenza del tempo.
SELECT CONCAT('DVBH',DATE_FORMAT(NOW(),'%Y%m%d%H%i%s'),LPAD(FLOOR(1 + RAND() * 999999),7,0),LPAD(@numero := @numero + 1,5,0)) AS RecordId
A questo punto siccome in un secondo possono esserci anche migliaia di inserimenti che manderebbero in violazione di chiave la nostra operazione aggiungiamo il terzo e quarto elemento. Il terzo sarò un numero randomico generato come già spiegato in un latro post secondo una formula matematica.
SELECT CONCAT('DVBH',DATE_FORMAT(NOW(),'%Y%m%d%H%i%s'),LPAD(FLOOR(1 + RAND() * 999999),7,0),LPAD(@numero := @numero + 1,5,0)) AS RecordId
Ultima parte un numero sequenziale, che io nel caso gli ho passato da una variabile @numero, ma che si può tranquillamente immagazzinare in una tabella e richiamare a piacere, aumentando il suo valore ad ogni passaggio.
SELECT CONCAT('DVBH',DATE_FORMAT(NOW(),'%Y%m%d%H%i%s'),LPAD(FLOOR(1 + RAND() * 999999),7,0),LPAD(@numero := @numero + 1,5,0)) AS RecordId
Il risultato che si ottiene è qualcosa come questo:
DVBH20090402133508062740800002
Ecco fatto!

Wsc

martedì 24 marzo 2009

JasperServer e iReport: Tabelle a nome variabile nei dataset

Oggi ho avuto una nuova problematica da affrontare nell'utilizzo di JasperServer e iReport.

Avevo necessità che l'utente potesse in qualche modo parametrizzare tutto o in parte in nome di una tabella sulla quale far girare il report. Nel caso specifico sul lavor creiamo delle tabelle giornaliere che hanno un nome formato come segue:
DataBase.Piattaforma _090324
Quindi il problema era passare la data al report in modo che l'utente potesse con un singolo report, e senza create procedure particolari al livello di db, interrogare più di una tabella a secondo del giorno di interesse.
La cosa più ovvia era che la parte variabile venisse passata tramite un parametro al report e quindi gioco forza il primo tentativo è stato quello di provare la seguente sintassi, dove il parametro veniva passato come stringa:
SELECT * FROM DataBase.Piattaforma _$P{DataTabella}
Ovviamente l'esperimento ha prodotto un errore, ma devo dire che la soluzione era a portata di mano. Il trucco sta nell'aggiungere un "!" dopo $P:
SELECT * FROM DataBase.Piattaforma _$P!{DataTabella}
Così facendo il tutto funziona perchè il motore effettua la sostituzione del parametro con il suo valore inserito dall'utente prima di inviare la query.

Spero di avervi aiutato anche questa volta.

Wsc

mercoledì 18 marzo 2009

MySQL: Generare numeri casuali in un intervallo

L'altro giorno mi sono imbattuto nella necessità di rielaborare dei dati creando un dataset simile ma rielaborando secondo funzioni statistiche dei campi numerici.

Avendo precedentemente calcolato Media e Varianza di questo set di dati (funzioni AVG() e STD()) quello che si desiderava fare era:
Media + (NumeroRandom * Varianza)
così facendo si sarebbe lavorato sulla media dei valori aggiungendogli una deviazione fornita dal numero randomico (compreso tra -0,8 e 0,8) moltiplicato la varianza.

L'inica funzione MySQL che genera numeri casuali è RAND(), però questa funzione produce numeri in virgola mobile compresi tra 0 e 1.
La sola funzione non riusciva a risolvere la problematica, quindi andava ulteriormente elaborata.
Googlando ho trovato per ottenere un numero intero variabile in un intervallo, mettiamo 1 e 3, si può applicare la seguente formula dove 1=i e 3=j:
FLOOR(i + RAND() * (j – i))
La formula di venta:
FLOOR(1 + RAND() * 2)
A questo punto non è stato necessario altro che effettuare una sostituzione per ottenere la formula finale dell'intervallo a cui ero interessato:
CEILING(Media + (-0.8 + (RAND() * 1.6)) * Varianza)
Ho usato il CEILING() in quanto a mi serviva arrotondare all'intero superiore contrariamente al FLOOR().
Spero che questo piccolo promemoria possa essere utile ad altri. Continuate a seguirmi.

Wsc

lunedì 16 marzo 2009

JasperServer e iReport: linkare i report tra di loro

Utilizzando Google Analytics ho notato che all'interno del mio blog gli articoli più interessanti per il pubblico siano quelli incentratti sull'argomento Jasper Server e iReport.

Altra funzione che ho usato ultimamente è la possibilità di poter linkare tra loro diversi report.
iReport ci permette di inserire dei link legati ai vari oggetti che compongono il nostro template. Si possono precificare delle URL e quindi possiamo linkare tra loro report già realizzati.

Si procede molto velocemente creando un capo di testo. Dalle "Proprietà" dell'oggetto si sceglie la linguetta "Link ipertestuale" e quindi è possibile inserire il link al report.
Di solito i link ai report sono di questo tipo:
http://NOME_SERVER/jasperserver/flow.html?_flowId=viewReportFlow&reportUnit=/reports/NOME_REPORT&standAlone=true&ParentFolderUri=/reports
Quindi è sufficiente dopo aver deciso la tipologia del link (nel nostro caso Blank e Reference) indicare nella linguetta "Riferimento" l'indirizzo.
Da notare che è anche possibile passare dei parametri se il report destinazione lo prevede passati del report chiamante.
Nel qualcaso un'esempio di link potrebbe essere questo:
"http://NOME_SERVER/jasperserver/flow.html?_flowId=viewReportFlow&reportUnit=/reports/NOME_SOTTOCARTELLA_REPORT/NOME_REPORT&standAlone=true&ParentFolderUri=/reports/NOME_SOTTOCARTELLA_REPORT&SelectFromDateTime="+$V{SelectFrom_STRING}+"&SelectToDateTime="+$V{SelectTo_STRING}
La parte in neretto ci consente di passare ai parametri del report chiamato SelectFromDateTime e SelectToDateTime i valori delle Variabili $V{SelectFrom_STRING} e $V{SelectTo_STRING}.
In questo caso stiamo passando delle date con ora per cui dovendo passare un text alla stringa dell'indirizzo abbiamo usato la seguente espressione per formattarle:
new java.text.SimpleDateFormat("yyyyMMddHHmmss").format($P{SelectFromDateTime})
Come potete vedere a loro volta le variabili erano state costruite da uno dei parametri immessi nel report chiamante.

Spero che anche questa spiegazione sia utile. Se qualcosa non fosse chiaro usate i commenti per porre delle domande.
Alla prossima.

Wsc

giovedì 12 marzo 2009

Scoprire chi ci visita e come: Google Analytics

Spesso e volentieri il successo di un sito o di un network è dovuto al fatto di capire chi ci visita e assecondarlo.

L'altro giorno incuriosito ho installato sul questo blog per capire quanto in profondità vada questo tipo di tools, e ovviamente sono rimasto sorpreso dalla completezza delle informazioni che garantisce.

Ricordo quasi con tenerezza i tempi dei "Contatori" con i quali ci vantavamo con gli amici per il numero di accessi che il nostro sito riusciva a raggiungere. Poi arrivò shiny stat che iniziava a darti anche informazioni geografiche (ovviamente solo a livello nazionale).

Come sempre però Google sorprende. Ci si può stupire di tutto quello che ci può dire dei nostri visitatori.
Tra le cose più sorprendenti sicuramente sono gli accessi che arrivano dai motori di ricerca in cui possiamo vedere le keywords usate dagli utenti per le ricerche.

Altre curiosità possono essere soddisfatte con la georeferenziarione degli accessi per vedere da che zona ci guardano o da che città.

Poi ovviamente ci sono parti molto utili per analizzare come il traffico sul nostro sito si muove.univocità delle utenze, quanti utenti ritornano, quanto tempo passano sul nostro sito, cosa viene visto maggiormente, etc.

Insomma buona scoperta a tutti i webmaster dei vostri lettori...

Wsc

mercoledì 11 marzo 2009

Ripartire: dal Web 1.0 al Web 2.0

Oggi vorrei rifar partire un vecchio progetto che per molto tempo è rimasto chiuso nel cassetto, anche se al tempo vi erano stati profusi sforzi non solo miei.
Far rinascere un sito, precisamente Ateleta.com, il mio paese di origine.

Quanti ricordi... si partì al tempo in 2 era il 29 Agosto 2001, Eleuterio ed io e poi un piccolo manipolo di collaboratori Laura, per le treduzioni, e Gianni, come corrispondente.

Ricordo con piacere l'entusiasmo, la proattività per far crescere questo piccolo cucciolo. Purtroppo ci si scontro con una visione miope e riuscimmo trovare in tutto il paese un solo sponsor, che ci aiutò a pagare almeno il canone del dominio.
L'attività vivacchio sino a circa il 2004 quando visti gli impegni personali e la poca risposta da parte dell'utenze lasciamo al suo destino il sito.

Oggi sono tornato a fare un giro... ho visto "E' in fase di testing il nuovo portale di Ateleta.com!" e incuriosito sono andato a vedere. Credo che Eleuterio abbia buttato su un csm. Da qui la nuova proposta e la speranza di rinascita. Ripartire da un web 1.0 e grazie a csm o a piattaforme come WordPress ricostruire sulle ceneri usando tutti i nuovi mezzi che 8 anni fa erano molto da venire.
Già una volta si scriveva l'HTML praticamente a mano o aiutandosi con strumenti che non andavano molto oltre.

Ho scritto ad Eleuterio, attendo sue risposte.
Rivoluzioniamo il vecchio mondo con il web 2.0. E avanti così!
Wsc

Ps: Chi ha voglia di aiutarci si faccia avanti!

lunedì 9 marzo 2009

Il social network delle buone azioni sta arrivando... la fiera del buonismo?

Stavo leggendo i miei soliti siti e mi sono imbattuto in questo articolo.

Si parla di questo nuovo social network in cui ognuno partecipa dicendo cosa farebbe se potesse comandare il mondo. Messa giù così e da come l'hanno intesa in molti non si potrà tramutare in altro che nella fiera del buonismo. Mi sembra di tornare indietro ai tempi del Catechismo e dei pensierini che andavano scritti per poi essere letti alla preghiera dei fedeli la domenica successiva.

Ma siamo ridotti così male? Esprimere comunque ora un giudizio definitivo non è facile visto che gli elementi di valutazione sono praticamente inesistenti, ma si è ottenuto sicuramente il risultato (come sempre un po' provocatorio) di farne parlare e quindi di accrescere la curiosità intorno a questo oggetto.

A questo punto più che con una domanda risponderei con un'affermazione:
STUPITECI!
Già stiamo a vedere cosa si inventeranno effettivamente e la speranza sarà quella che il tutto non diventi la fiera del buonismo ricolma di inutili utopie!

Rimaniamo in attesa.

Wsc