Torna indietro   Hardware Upgrade Forum > Software > Programmazione

PC Specialist Lafité 14 AI AMD: assemblato come vuoi tu
PC Specialist Lafité 14 AI AMD: assemblato come vuoi tu
Il modello "build to order" di PCSpecialist permette di selezionare una struttura base per un sistema, personalizzandolo in base alle specifiche esigenze con una notevole flessibilità di scelta tra i componenti. Il modello Lafité 14 AI AMD è un classico notebook clamshell compatto e potente, capace di assicurare una elevata autonomia di funzionamento anche lontano dalla presa di corrente
Recensione Nothing Phone 4(a): sempre iconico ma ora più concreto
Recensione Nothing Phone 4(a): sempre iconico ma ora più concreto
Nothing con il suo nuovo Phone 4(a) conferma la sua identità visiva puntando su una costruzione che nobilita il policarbonato. La trasparenza resta l'elemento cardine, arricchita da una simmetria interna curata nei minimi dettagli. Il sistema Glyph si evolve, riducendosi nelle dimensioni ma aumentando l'utilità quotidiana grazie a nuove funzioni software integrate e notifiche visive. Ecco tutti i dettagli nella recensione completa
Corsair Vanguard Air 99 Wireless: non si era mai vista una tastiera gaming così professionale
Corsair Vanguard Air 99 Wireless: non si era mai vista una tastiera gaming così professionale
Nelle ultime settimane abbiamo provato la Corsair Vanguard Air 99 Wireless, una tastiera tecnicamente da gaming, ma che in realtà offre un ampio ventaglio di possibilità anche al di fuori delle sessioni di gioco. Flessibilità e funzionalità sono le parole d'ordine di una periferica che si rivolge a chi cerca un prodotto capace di adattarsi a ogni esigenza e ogni piattaforma
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 21-04-2009, 15:30   #1
vegetassj2
Senior Member
 
L'Avatar di vegetassj2
 
Iscritto dal: Nov 2002
Messaggi: 536
[Python] Gestione DB sqlite

Ciao a tutti,
avrei bisogno di qualche input
Sto scrivendo una classe per potermi rendere più comodo l'interfacciamente con sqlite; nello specifico vorrei realizzare una specie di ORM, in modo da legare dei modelli definiti con delle classi a delle tabelle sul db per poi poterci fare delle operazioni. Per chi conosce Django, l'idea è creare qualcosa di simile al loro ORM, anche se molto più semplice.
Il problema è che ho delle GROSSE carenze sul design, quindi vorrei qualche suggerimento da voi su come strutturare il tutto.
Ecco qua quello che fin'ora ho realizzato:

Codice:
#!/usr/bin/env python

import sqlite3
import sys
import os
from __future__ import with_statement

class Db():
    
    def __init__(self, dbname = ':memory:'):
        
        tables = []
        
        try:
            db = sqlite3.connect(dbname)
        except sqlite3.Error, e:
            print 'An error occurred:', e.args[0]
            
    def addTable(self, schema):
        table = self.Table(db,schema)
        tables.append(table)
        return
        
    def dropTable(self,schema):
        table = self.Table(db,schema)
        table.delete()
        return
    
    class Table():
        def __init__(self, db, schema = None):
            tableName = str(schema)
            try:
                conn = db.cursor()
                with conn:
                    conn.execute('SELECT tbl_name FROM sqlite_master')
                    tables = conn.fetch()
                    if table == tableName:
                        conn.execute("pragma table_info(%s)" %tableName)
                        return conn.fetchall()
                    return self.createTable(conn, schema)
                    
            except sqlite3.Error:
                print 'Sqlite error:',e.args[0]
                return None
                
        
        def createTable(self,conn, object = None):
            fields = [field for field in dir(object) if callable(getattr(object, field))]
            
            '''
            dalla lista dei field, che sono gli elementi della mia classe modello,
            devo creare lo statement sql per creare la tabella e restituire poi il pragma
            '''
            
        def delete(self, filter):
            pass
nello specifico non so come vadano creati i vari statement a partire dall'elenco dei metodi che ottengo con la funzione getattr.
vegetassj2 è offline   Rispondi citando il messaggio o parte di esso
Old 21-04-2009, 18:30   #2
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
Non ti conviene partire dall'ORM di Django e "ridurlo" per portarlo a quello che vorresti?
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
Old 21-04-2009, 19:43   #3
vegetassj2
Senior Member
 
L'Avatar di vegetassj2
 
Iscritto dal: Nov 2002
Messaggi: 536
Quote:
Originariamente inviato da cdimauro Guarda i messaggi
Non ti conviene partire dall'ORM di Django e "ridurlo" per portarlo a quello che vorresti?
in teoria si....in pratica vedevo questa cosa in ottica di didattica: in poche parole voglio imparare non avendo tempistiche, e volendo approfondire le mie conoscenze, mi chiedevo se qualcuno potesse darmi una mano, anche solo linkandomi della documentazione
vegetassj2 è offline   Rispondi citando il messaggio o parte di esso
Old 21-04-2009, 21:16   #4
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
Capito. Per "statement" cosa intendi, alla fine del tuo primo post?
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
Old 21-04-2009, 21:47   #5
vegetassj2
Senior Member
 
L'Avatar di vegetassj2
 
Iscritto dal: Nov 2002
Messaggi: 536
Quote:
Originariamente inviato da cdimauro Guarda i messaggi
Capito. Per "statement" cosa intendi, alla fine del tuo primo post?
rileggendo la mia risposta di poco fa, mi sono reso conto di essermi espresso in maniera abbastanza dura!sorry...troppo lavoro in ufficio fa male

tornando al codice, volevo trovare il modo di comporre la stringa della query(questo intendevo con statement) di creazione della tabella usando la funzione getattr per ricavare tutti i metodi implementati in una classe "modello".
In pratica vorrei definire una classe che modellizza un oggetto, che poi passerei al db per poter creare una tabella che lo rispecchi, in modo da mappare l'oggetto sulla tabella.
vegetassj2 è offline   Rispondi citando il messaggio o parte di esso
Old 21-04-2009, 22:20   #6
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
Il tono non mi sembra affatto duro.

Comunque dal codice mi sfugge il modo in cui recuperi le informazioni sui campi della tabella. Per essere più preciso, creato l'oggetto Table, da dove li prendi i campi a essa associati? E in che modo vengono rappresentati?
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
Old 22-04-2009, 09:14   #7
vegetassj2
Senior Member
 
L'Avatar di vegetassj2
 
Iscritto dal: Nov 2002
Messaggi: 536
Quote:
Originariamente inviato da cdimauro Guarda i messaggi
Il tono non mi sembra affatto duro.

Comunque dal codice mi sfugge il modo in cui recuperi le informazioni sui campi della tabella. Per essere più preciso, creato l'oggetto Table, da dove li prendi i campi a essa associati? E in che modo vengono rappresentati?
Ti spiego brevemente la struttura che avevo in mente.

Creo una classe Field generica, da cui per eredità creerò i vari tipi di Field: IntegerField, DateField, etc.....

Codice:
class Field:
    
    def __init__(self, value):
        value = value
        
    def f1:
        pass
    
    class IntegerField(Field):
    
        def __init__(self, value):
            super.__init__(self,value)
        
        def f1:
            pass
A questo punto creo una classe generica modello che fa da contenitore generico, e da cui creo una sub-classe specifica per ogni tipo di oggetto che voglio mappare sul DB:

Codice:
class Model:
    
    def __init__(self, name):
        name = name
        primary_key = None
        
    def f2:
        pass
    
class SpecificModel(Model):
    
    def __init__(self,name):
        self.__init__(self, name)
        
    int = Field.IntegerField()
    date = Field.DateField()
    
    def f2:
        pass
A questo punto, passerei un'istanza o una lista di istanze di SpecificModel all'oggetto DB, che provvederebbe a creare una tabella se non ancora esistente e a salvare i dati degli oggetti sul db.
Spero di essermi spiegato abbastanza bene
E' corretto il mio modo di strutturare il tutto?c'è qualche cosa di errato??
vegetassj2 è offline   Rispondi citando il messaggio o parte di esso
Old 22-04-2009, 10:28   #8
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
Mi sembra un buon modello , ma personalmente terrei tutti i "field" in una lista, anziché utilizzare dir() per ricavarli e poi lavorarci.

Questo perché anche l'ordine di creazione dei campi può essere importante, e con la dir() non hai la possibilità di ottenere l'esatto ordine di creazione.

Per quanto riguarda attribuiti specifici, come PRIMARY KEY o INDEX, realizzerei entità specifiche, diverse dai Field ma che ne facciano ovviamente uso.

Queste entità, alla creazione della tabella, verrebbero poi prelevate e comporterebbero o l'aggiunta di apposite righe nella CREATE TABLE, oppure la creazione di specifiche istruzioni ALTER TABLE che modifichino lo schema relazionale in accordo al tuo modello ORM.

Anche qui per gli indici starei attento all'ordine. Ad esempio, se creo una chiave primaria su tre Field, e successivamente c'è un'entità di tipo Field su uno di essi (magari proprio il primo ), creando prima la chiave primaria e poi l'indice, se l'engine SQL è intelligente comporterebbe la creazione del solo indice sulla chiave primaria, perché il secondo indice è già "incluso".

Se invece crei prima l'indice e poi la chiave primaria, probabilmente otterrai due indici diversi e ridondanti.

Non so se sono stato chiaro. Eventualmente parliamone ancora un po' finché non ti sarai fatto un'idea precisa.
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


PC Specialist Lafité 14 AI AMD: assemblato come vuoi tu PC Specialist Lafité 14 AI AMD: assemblat...
Recensione Nothing Phone 4(a): sempre iconico ma ora più concreto Recensione Nothing Phone 4(a): sempre iconico ma...
Corsair Vanguard Air 99 Wireless: non si era mai vista una tastiera gaming così professionale Corsair Vanguard Air 99 Wireless: non si era mai...
Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lavaggio è ampio Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lav...
Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo Recensione Samsung Galaxy S26 Ultra: finalmente ...
La crisi delle memorie potrebbe durare a...
Epic non ha alcuna intenzione di smetter...
MacBook Neo: la scommessa economica di A...
Addio elio-3? La scoperta cinese che pot...
OpenAI punta a 8.000 dipendenti entro il...
Democratici all'attacco di NVIDIA: l'acc...
Elon Musk ha annunciato Terafab: fabbric...
Tutte le migliori offerte Amazon del wee...
Assassin's Creed: iniziate le riprese de...
TV 4K in super offerta: 75'' Mini-LED Hi...
iPad Air in offerta: 11'' con chip M3 a ...
Garmin Instinct 2X Solar Tactical a 259€...
Crimson Desert: Intel ha cercato di coll...
MacBook Air M4 da 899€ su Amazon, ma non...
POCO X8 Pro e Pro Max 12/512GB -23% su A...
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: 22:04.


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