...

Package cassandra

import "github.com/golang-migrate/migrate/v4/database/cassandra"
Overview
Index

Overview ▾

Variables

var (
    ErrNilConfig     = errors.New("no config")
    ErrNoKeyspace    = errors.New("no keyspace provided")
    ErrDatabaseDirty = errors.New("database is dirty")
    ErrClosedSession = errors.New("session is closed")
)
var DefaultMigrationsTable = "schema_migrations"
var (
    DefaultMultiStatementMaxSize = 10 * 1 << 20 // 10 MB
)

func WithInstance

func WithInstance(session *gocql.Session, config *Config) (database.Driver, error)

type Cassandra

type Cassandra struct {
    // contains filtered or unexported fields
}

func (*Cassandra) Close

func (c *Cassandra) Close() error

func (*Cassandra) Drop

func (c *Cassandra) Drop() error

func (*Cassandra) Lock

func (c *Cassandra) Lock() error

func (*Cassandra) Open

func (c *Cassandra) Open(url string) (database.Driver, error)

func (*Cassandra) Run

func (c *Cassandra) Run(migration io.Reader) error

func (*Cassandra) SetVersion

func (c *Cassandra) SetVersion(version int, dirty bool) error

func (*Cassandra) Unlock

func (c *Cassandra) Unlock() error

func (*Cassandra) Version

func (c *Cassandra) Version() (version int, dirty bool, err error)

Return current keyspace version

type Config

type Config struct {
    MigrationsTable       string
    KeyspaceName          string
    MultiStatementEnabled bool
    MultiStatementMaxSize int
}