|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Senior Member
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
|
|
|
|
|
|
#2 |
|
Senior Member
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 |
|
|
|
|
|
#3 | |
|
Senior Member
Iscritto dal: Nov 2002
Messaggi: 536
|
Quote:
|
|
|
|
|
|
|
#4 |
|
Senior Member
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 |
|
|
|
|
|
#5 | |
|
Senior Member
Iscritto dal: Nov 2002
Messaggi: 536
|
Quote:
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. |
|
|
|
|
|
|
#6 |
|
Senior Member
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 |
|
|
|
|
|
#7 | |
|
Senior Member
Iscritto dal: Nov 2002
Messaggi: 536
|
Quote:
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
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
Spero di essermi spiegato abbastanza bene E' corretto il mio modo di strutturare il tutto?c'è qualche cosa di errato?? |
|
|
|
|
|
|
#8 |
|
Senior Member
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
|
Mi sembra un buon modello
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 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 |
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 17:02.




















