本文整理匯總了Golang中github.com/FactomProject/factomd/common/interfaces.DatabaseBatchable.DatabasePrimaryIndex方法的典型用法代碼示例。如果您正苦於以下問題:Golang DatabaseBatchable.DatabasePrimaryIndex方法的具體用法?Golang DatabaseBatchable.DatabasePrimaryIndex怎麽用?Golang DatabaseBatchable.DatabasePrimaryIndex使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類github.com/FactomProject/factomd/common/interfaces.DatabaseBatchable
的用法示例。
在下文中一共展示了DatabaseBatchable.DatabasePrimaryIndex方法的5個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: SaveEntryJSON
func SaveEntryJSON(entry interfaces.DatabaseBatchable, blockHeight uint32) error {
data, err := entry.(interfaces.Printable).JSONByte()
if err != nil {
return err
}
var out bytes.Buffer
json.Indent(&out, data, "", "\t")
data = out.Bytes()
strChainID := fmt.Sprintf("%x", entry.GetChainID())
dir := DataStorePath + strChainID + "/entries"
if FileNotExists(dir) {
err := os.MkdirAll(dir, 0777)
if err == nil {
fmt.Println("Created directory " + dir)
} else {
return err
}
}
err = ioutil.WriteFile(fmt.Sprintf(dir+"/storeJSON.%09d.%v.entry", blockHeight, entry.DatabasePrimaryIndex().String()), data, 0777)
if err != nil {
return err
}
return nil
}
示例2: ProcessBlockBatchWithoutHead
func (db *Overlay) ProcessBlockBatchWithoutHead(blockBucket, numberBucket, secondaryIndexBucket []byte, block interfaces.DatabaseBatchable) error {
if block == nil {
return nil
}
batch := []interfaces.Record{}
batch = append(batch, interfaces.Record{blockBucket, block.DatabasePrimaryIndex().Bytes(), block})
if numberBucket != nil {
bytes := make([]byte, 4)
binary.BigEndian.PutUint32(bytes, block.GetDatabaseHeight())
batch = append(batch, interfaces.Record{numberBucket, bytes, block.DatabasePrimaryIndex()})
}
if secondaryIndexBucket != nil {
batch = append(batch, interfaces.Record{secondaryIndexBucket, block.DatabaseSecondaryIndex().Bytes(), block.DatabasePrimaryIndex()})
}
err := db.DB.PutInBatch(batch)
if err != nil {
return err
}
return nil
}
示例3: Insert
func (db *Overlay) Insert(bucket []byte, entry interfaces.DatabaseBatchable) error {
err := db.DB.Put(bucket, entry.DatabasePrimaryIndex().Bytes(), entry)
if err != nil {
return err
}
return nil
}
示例4: ProcessBlockBatch
func (db *Overlay) ProcessBlockBatch(blockBucket, numberBucket, secondaryIndexBucket []byte, block interfaces.DatabaseBatchable) error {
if block == nil {
return nil
}
batch := []interfaces.Record{}
batch = append(batch, interfaces.Record{blockBucket, block.DatabasePrimaryIndex().Bytes(), block})
if numberBucket != nil {
bytes := make([]byte, 4)
binary.BigEndian.PutUint32(bytes, block.GetDatabaseHeight())
batch = append(batch, interfaces.Record{numberBucket, bytes, block.DatabasePrimaryIndex()})
}
if secondaryIndexBucket != nil {
batch = append(batch, interfaces.Record{secondaryIndexBucket, block.DatabaseSecondaryIndex().Bytes(), block.DatabasePrimaryIndex()})
}
batch = append(batch, interfaces.Record{[]byte{CHAIN_HEAD}, block.GetChainID(), block.DatabasePrimaryIndex()})
err := db.DB.PutInBatch(batch)
if err != nil {
return err
}
if db.ExportData {
err = blockExtractor.ExportBlock(block)
if err != nil {
return err
}
}
return nil
}
示例5: SaveEntryBinary
func SaveEntryBinary(entry interfaces.DatabaseBatchable, blockHeight uint32) error {
data, err := entry.MarshalBinary()
if err != nil {
return err
}
strChainID := fmt.Sprintf("%x", entry.GetChainID())
dir := DataStorePath + strChainID + "/entries"
if FileNotExists(dir) {
err := os.MkdirAll(dir, 0777)
if err == nil {
fmt.Println("Created directory " + dir)
} else {
return err
}
}
err = ioutil.WriteFile(fmt.Sprintf(dir+"/store.%09d.%v.entry", blockHeight, entry.DatabasePrimaryIndex().String()), data, 0777)
if err != nil {
return err
}
return nil
}