Giter Club home page Giter Club logo

go-preparedsqlx's Introduction

About

Package stores list of map queryName=>queryPreparedStatement linked to the sqlx/db object.

Usage example

import (
	"github.com/sda0/go-preparedsqlx"
)

const (
	sqlGetFilesTerms = "sqlGetFilesTerms"
	sqlDeleteFilesTerms = "sqlDeleteFilesTerms"
)
type SQLStorage struct {
	connect   *sqlx.DB
	prepQuery *preparedsqlx.Registry
}

func init() {
	// Add queries to registry
	preparedsqlx.Add(sqlGetFilesTerms, "SELECT * FROM term_file WHERE fid::text=ANY($1)")
	preparedsqlx.Add(sqlDeleteFilesTerms, "DELETE FROM term_file tf WHERE fid=$1")
}

func NewSQLStorage() (*SQLStorage, error) {
	pg := &SQLStorage{}
	_, err := pg.getConnect()
	if err != nil {
		return nil, err
	}
	err = pg.MigrateUp()
	if err != nil {
		pg.connect.Close()
		return nil, err
	}
	// Prepare all registered queries
	pg.prepQuery, err = preparedsqlx.New(pg.connect)
	if err != nil {
		pg.connect.Close()
		return nil, err
	}
	return pg, nil
}

// GetFilesTerms returns all terms associated for requested files
func (s *SQLStorage) GetFilesTerms(ctx context.Context, files []string) ([]*storage.FileTerms, error) {
	getFilesTermsQuery, err := s.prepQuery.Get(sqlGetFilesTerms)
	if err != nil {
		return nil, err
	}
	rows, err := getFilesTermsQuery.QueryxContext(ctx, pg2.Array(files))
	if err != nil {
		return nil, err
	}
	defer rows.Close()
	var result []*storage.FileTerms
	for rows.Next() {
		var r storage.FileTerms
		err = rows.StructScan(&r)
		if err != nil {
			return nil, err
		}
		result = append(result, &r)
	}
	return result, nil
}

// RemoveFilesTerms uses transactions 
func (s *SQLStorage) RemoveFilesTerms(ctx context.Context, vv []int) (error) {
	tx, err := s.connect.Beginx()
	if err != nil {
		return nil
	}
	deleteFilesTermsQuery, err := s.prepQuery.GetTx(tx, sqlDeleteFilesTerms)
	if err != nil {
		tx.Rollback()
		return nil
	}
	for _, v := range vv {
		r, err := deleteFilesTermsQuery.ExecContext(ctx, v)
		if err != nil {
			tx.Rollback()
			return nil
		}
	}
	return tx.Commit()
}

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.