私が取り組んでいるデータ アプリの基本的な ORM を設計しようとしています。私が思いついたモデルについての質問は 2 つあります。
- これは、データベース追跡の「最適」で最も「効率的な」モデルですか?
- これは慣用的な囲碁ですか?
アイデアは、アプリの開始時にデータベースの完全なモデルをメモリにロードすることです。このモデルを使用して、各オブジェクト (データベース内の行に対応) の crc32 ハッシュでマップを生成します。これは、モデルと比較して、.save() が呼び出されたときに変更が加えられた場所を特定するために使用するものです。
次の最初の部分はcrc32マップを生成し、2番目の部分はランダムな変更を導入し、最後の部分はdbの変更をディスクに書き込む.save()の一部になります
コード:
func main() {
// Read data off of disk into memory
memDB := ddb
// Create hash map of memDB
peopleMap := make(map[int]uint32)
for _, v := range memDB.people {
// make row into byte array, looks kludgy
hash := []byte(fmt.Sprintf("%#v", v))
peopleMap[v.pID] = crc32.ChecksumIEEE(hash)
fmt.Printf("%v: %v %v \t(%v %v) - crc sum: %v\n",
v.pID, v.fName, v.lName, v.job, v.location,
peopleMap[v.pID])
}
fmt.Println("\n# of people in memory:", len(memDB.people))
// Sometime later, we need to delete Danielle, so
// Delete in memory:
var tmpSlice []ddPerson
for _, v := range memDB.people {
if v.fName == "Danielle" {
continue
}
tmpSlice = append(tmpSlice, v)
}
memDB.people = tmpSlice
fmt.Println("# of people in memory:", len(memDB.people))
// Okay, we save in-memory representation mem.DB back
// to disk with some kind of .save() assertion
// a len(peopleMap) comparison to len(memDB.people) will
// tell us there has been a change for INSERTS and
// DELETES, but it won't tell us about updates or which
// record was inserted or deleted
// First, check for additions
if len(peopleMap) < len(memDB.people) {
// Code to find and add person to disk db ddb here
fmt.Println("Adding someone to disk database...")
} else if len(peopleMap) > len(memDB.people) {
// Check for deletions
fmt.Println("Purging someone from disk database...")
}
// in any case, recheck hashes
tMap := make(map[int]uint32)
for _, v := range memDB.people {
hash := []byte(fmt.Sprintf("%#v", v))
t := crc32.ChecksumIEEE(hash)
// Add to temporary map
tMap[v.pID] = t
// And check for changes
if t != peopleMap[v.pID] {
fmt.Println("Change detected in in-memory model...")
fmt.Println("Writing changes to disk db now")
// Writing any changes to DB here
ddb.people = memDB.people
}
}
// 'Fix' our hashmap checker deal
peopleMap = tMap
// Carry on
}
動作中のバージョンがあります: http://play.golang.org/p/XMTmynNy7t