1 Star 0 Fork 0

xingyp/cn-infra

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
doc.go 2.81 KB
一键复制 编辑 原始数据 按行查看 历史
// Copyright (c) 2017 Cisco and/or its affiliates.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at:
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
// Package cassandra is the implementation of the SQL Data Broker client
// API for the Cassandra data store. See cn-infra/db/sql for the definition
// of the key-value Data Broker client API.
//
// The entity that provides access to the data store is called gocql.Session (wrapped by Broker for convenience).
//
// +--------+ +----------+ crud +-----------+
// | Broker | ----> | Session | ----> | Cassandra |
// +--------+ +----------+ +-----------+
//
// To create a Session use the following function
//
// import "github.com/gocql/gocql"
//
// cluster := gocql.NewCluster("172.17.0.1")
// cluster.Keyspace = "demo"
// session, err := cluster.CreateSession()
//
// Then create broker instance:
//
// import (
// "github.com/ligato/cn-infra/db/sql/cassandra"
// "github.com/willfaught/gockle"
// )
// db := cassandra.NewBrokerUsingSession(gockle.NewSession(session)))
//
// To insert single key-value pair into Cassandra run (both values are pointers, JamesBond is instance of User struct.):
// db.Put(sql.PK(&JamesBond.ID), JamesBond)
// To remove a value identified by key:
// datasync.Delete(sql.FROM(JamesBond, sql.WHERE(sql.PK(&JamesBond.ID)))
//
// To retrieve a value identified by key (both values are pointers):
// data, found, rev, err := db.GetValue(sql.FROM(UserTable, sql.WHERE(sql.Field(&UserTable.ID, sql.EQ("James Bond"))))
// if err == nil && found {
// ...
// }
//
// To retrieve all values matching a key prefix:
// itr, err := db.ListValues(sql.FROM(UserTable, sql.WHERE(sql.Field(&UserTable.LastName, sql.EQ("Bond"))))
// if err != nil {
// for {
// data, allReceived, rev, err := itr.GetNext()
// if allReceived {
// break
// }
// if err != nil {
// return err
// }
// process data...
// }
// }
//
// To retrieve values more conveniently directrly in slice (without using iterator):
// users := &[]User{}
// err := sql.SliceIt(users, db.ListValues(sql.FROM(UserTable,
// sql.WHERE(sql.Field(&UserTable.LastName, sql.EQ("Bond"))))
//
//
package cassandra
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/xingyp/cn-infra.git
git@gitee.com:xingyp/cn-infra.git
xingyp
cn-infra
cn-infra
v1.0.3

搜索帮助

0d507c66 1850385 C8b1a773 1850385