Torna indietro   Hardware Upgrade Forum > Software > Programmazione

OPPO Find X9 Pro: il camera phone con teleobiettivo da 200MP e batteria da 7500 mAh
OPPO Find X9 Pro: il camera phone con teleobiettivo da 200MP e batteria da 7500 mAh
OPPO Find X9 Pro punta a diventare uno dei riferimenti assoluti nel segmento dei camera phone di fascia alta. Con un teleobiettivo Hasselblad da 200 MP, una batteria al silicio-carbonio da 7500 mAh e un display da 6,78 pollici con cornici ultra ridotte, il nuovo flagship non teme confronti con la concorrenza, e non solo nel comparto fotografico mobile. La dotazione tecnica include il processore MediaTek Dimensity 9500, certificazione IP69 e un sistema di ricarica rapida a 80W
DJI Romo, il robot aspirapolvere tutto trasparente
DJI Romo, il robot aspirapolvere tutto trasparente
Anche DJI entra nel panorama delle aziende che propongono una soluzione per la pulizia di casa, facendo leva sulla propria esperienza legata alla mappatura degli ambienti e all'evitamento di ostacoli maturata nel mondo dei droni. Romo è un robot preciso ed efficace, dal design decisamente originale e unico ma che richiede per questo un costo d'acquisto molto elevato
DJI Osmo Nano: la piccola fotocamera alla prova sul campo
DJI Osmo Nano: la piccola fotocamera alla prova sul campo
La nuova fotocamera compatta DJI spicca per l'abbinamento ideale tra le dimensioni ridotte e la qualità d'immagine. Può essere installata in punti di ripresa difficilmente utilizzabili con le tipiche action camera, grazie ad una struttura modulare con modulo ripresa e base con schermo che possono essere scollegati tra di loro. Un prodotto ideale per chi fa riprese sportive, da avere sempre tra le mani
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 17-06-2011, 17:46   #1
Necrolord
Member
 
L'Avatar di Necrolord
 
Iscritto dal: Nov 2004
Città: R.E.
Messaggi: 222
[Mysql] Match con regular expression e ritorno stringa

Ciao a tutti ho un DB mysql su macchina redhat, tale DB contiene una tabella chiamata TabellaLog così descritta
+-------------------+--------------+------+-----+---------+----------+
| Field | Type | Null | Key | Default | Extra |
+-------------------+--------------+------+-----+---------+----------+
| id | int(11) | NO | PRI | NULL | auto_increment |
| timestamp | int(14) | NO | MUL | 0 | |
| filename | varchar(255) | NO | MUL | | |
| log | longtext | NO | | NULL | |
| exit_code | varchar(4) | NO | | | |
+-------------------+--------------+------+-----+---------+-----------+

il campo "log" contiene vari dati tra cui la dimensione (tramite un "ls -l" della shell)di un file trasferito.
ad esempio l'inizio del log potrebbe inziare come
-rwxrwxr-x 1 user user 67550 Jun 17 17:30 /var/tmp/file1.txt

Avrei necessità di sapere se esiste un comando (simile al grep) per eseguire una query che mi restituisca il match trovato in base ad una regular expression.
Se ad esempio eseguo la query
Codice:
select id, log REGEXP 'user\ +user\ +[0-9]' as pippo from TabellaLog order by pippo;
ottengo solo una cosa del tipo
+-------+-------+
| id | pippo |
+-------+-------+
| 33095 | 0 |
| 33096 | 0 |
| 33097 | 0 |
| 33098 | 0 |
| 33100 | 0 |
...... ..
| 33094 | 1 |
| 33099 | 1 |
| 33102 | 1 |
| 33103 | 1 |
| 33104 | 1 |
..... ...
poiche REGEXP restuisce solo il valore 0 o 1 in base se non trova o trova il pattern della regexp...a me invece serve un comando che mi restituisca anche la stringa (es "user user 67550").
In particolare devo estrarre il valore numerico (che è la dimensione del file contenuto nel campo log) da usare come "order by" per ordinare la "select * from "TabellaLog" ecc ecc".
In modo da eseguire un'unica query che possa usare in una pagina php per creare una tabella html ordinata per la dimensione dei file...considerando che la dimensione di tali file non è un campo della tabella mysql ma una stringa contenta nel campo log della tabella.
Grazie a chiunque vorrà aiutarmi
__________________
Cooler Master Silencio 652S | Msi Z170A Gaming M5 | Intel skylake i5-6600K @ 4,7 Ghz + dissi liquid Arctic Freezer 240 | DDR4 16GB G.SKill 3000 CL15 KIT (2x8GB) 16GTZB Trident Z | nVidia Gigabyte GTX980TI 6GB Extreme Gaming | Samsung evo SSD 256GB | BeQuiet L8-730W Pure Power Modular | Acer XB Predator XB271HU IPS 27" 2K
Necrolord è offline   Rispondi citando il messaggio o parte di esso
Old 20-06-2011, 16:14   #2
Necrolord
Member
 
L'Avatar di Necrolord
 
Iscritto dal: Nov 2004
Città: R.E.
Messaggi: 222
Nessuno nessuno esperto di mysql ?
__________________
Cooler Master Silencio 652S | Msi Z170A Gaming M5 | Intel skylake i5-6600K @ 4,7 Ghz + dissi liquid Arctic Freezer 240 | DDR4 16GB G.SKill 3000 CL15 KIT (2x8GB) 16GTZB Trident Z | nVidia Gigabyte GTX980TI 6GB Extreme Gaming | Samsung evo SSD 256GB | BeQuiet L8-730W Pure Power Modular | Acer XB Predator XB271HU IPS 27" 2K
Necrolord è offline   Rispondi citando il messaggio o parte di esso
Old 24-06-2011, 14:16   #3
fspino
Junior Member
 
Iscritto dal: Jun 2011
Messaggi: 3
Quote:
Originariamente inviato da Necrolord Guarda i messaggi
Nessuno nessuno esperto di mysql ?
Forse non è che non esistono esperti mysql, ma che il tuo post è poco leggibile.
Ad esempio la definizione della tabella avresti potuto inserirla così:
Codice:
Field     | Type         | Null | Key | Default | Extra          
id        | int(11)      | NO   | PRI | NULL    | auto_increment 
timestamp | int(14)      | NO   | MUL | 0       |                
filename  | varchar(255) | NO   | MUL |         |                
log       | longtext     | NO   |     |         |                
exit_code | varchar(4)   | NO   |     |         |
Sarebbe stato sicuramente più leggibile e magari gli altri utenti non sarebbero scappati.

In ogni modo, perché vuoi usare un espressione regolare?
Non puoi scrivere semplicemente una query tipo:
Codice:
SELECT id,
     CAST(SUBSTRING(log,
           POSITION('user user',log) + 10, 
           POSITION('/',log)-POSITION('user user',log) - 24) 
        AS INTEGER) AS pippo
FROM TabellaLog 
WHERE log LIKE '% user user %'
ORDER BY pippo;
Tieni conto che io non ho potuto provare la query perché al momento dispongo solo di db2 e sybase, che sono entrambi non compatibili con mysql.

Ciao
fspino è offline   Rispondi citando il messaggio o parte di esso
Old 05-09-2011, 12:48   #4
Necrolord
Member
 
L'Avatar di Necrolord
 
Iscritto dal: Nov 2004
Città: R.E.
Messaggi: 222
So che sono passati quasi 3 mesi ma volevo ringraziarti, perchè alla fine ho risolto con un metodo simile a quello che mi hai proposto.

Grazie ancora e scusa del ritardo con il quale te lo dico
Ciao
__________________
Cooler Master Silencio 652S | Msi Z170A Gaming M5 | Intel skylake i5-6600K @ 4,7 Ghz + dissi liquid Arctic Freezer 240 | DDR4 16GB G.SKill 3000 CL15 KIT (2x8GB) 16GTZB Trident Z | nVidia Gigabyte GTX980TI 6GB Extreme Gaming | Samsung evo SSD 256GB | BeQuiet L8-730W Pure Power Modular | Acer XB Predator XB271HU IPS 27" 2K
Necrolord è offline   Rispondi citando il messaggio o parte di esso
Old 22-09-2011, 15:05   #5
fspino
Junior Member
 
Iscritto dal: Jun 2011
Messaggi: 3
Ringraziamenti e scuse accettate

Ciao
fspino è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


OPPO Find X9 Pro: il camera phone con teleobiettivo da 200MP e batteria da 7500 mAh OPPO Find X9 Pro: il camera phone con teleobiett...
DJI Romo, il robot aspirapolvere tutto trasparente DJI Romo, il robot aspirapolvere tutto trasparen...
DJI Osmo Nano: la piccola fotocamera alla prova sul campo DJI Osmo Nano: la piccola fotocamera alla prova ...
FUJIFILM X-T30 III, la nuova mirrorless compatta FUJIFILM X-T30 III, la nuova mirrorless compatta
Oracle AI World 2025: l'IA cambia tutto, a partire dai dati Oracle AI World 2025: l'IA cambia tutto, a parti...
Gli USA preparano il programma Apollo de...
Jensen Huang ha mostrato per la prima vo...
Addio vecchia OpenAI: ora punta al profi...
Dallo spazioporto di Jiuquan decollerann...
Il Giappone un passo più vicino a...
Gli interferometri LIGO, Virgo e KAGRA h...
Kia PV5: è record di autonomia! I...
L'aeroplano supersonico ''silenzioso'' N...
Nissan: le batterie allo stato solido co...
NVIDIA cambia strategia? La GPU Feynman ...
Signal respinge le accuse dopo il down A...
Uragano Melissa in arrivo: la tempesta d...
8K o 4K? Ecco perché il tuo occhi...
Mercato auto europeo in crescita nei pri...
Addio SSD e RAM, benvenuti funghi: dagli...
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: 06:30.


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