Documentation
¶
Index ¶
- Constants
- func Append(fmter Formatter, b []byte, v interface{}) []byte
- func AppendBoolValue(fmter Formatter, b []byte, v reflect.Value) []byte
- func AppendFloat32Value(fmter Formatter, b []byte, v reflect.Value) []byte
- func AppendFloat64Value(fmter Formatter, b []byte, v reflect.Value) []byte
- func AppendIntValue(fmter Formatter, b []byte, v reflect.Value) []byte
- func AppendJSONValue(fmter Formatter, b []byte, v reflect.Value) []byte
- func AppendQueryAppender(fmter Formatter, b []byte, app QueryAppender) []byte
- func AppendStringValue(fmter Formatter, b []byte, v reflect.Value) []byte
- func AppendUintValue(fmter Formatter, b []byte, v reflect.Value) []byte
- func DiscoverSQLType(typ reflect.Type) string
- func SetTableNameInflector(fn func(string) string)
- type AfterScanRowHook
- type AppenderFunc
- type BaseDialect
- func (BaseDialect) AppendBool(b []byte, v bool) []byte
- func (BaseDialect) AppendBytes(b, bs []byte) []byte
- func (BaseDialect) AppendJSON(b, jsonb []byte) []byte
- func (BaseDialect) AppendString(b []byte, s string) []byte
- func (BaseDialect) AppendTime(b []byte, tm time.Time) []byte
- func (BaseDialect) AppendUint32(b []byte, n uint32) []byte
- func (BaseDialect) AppendUint64(b []byte, n uint64) []byte
- type BaseModel
- type BeforeAppendModelHook
- type BeforeScanRowHook
- type ColumnsAppender
- type CustomAppender
- type Dialect
- type Field
- func (f *Field) AppendValue(fmter Formatter, b []byte, strct reflect.Value) []byte
- func (f *Field) Clone() *Field
- func (f *Field) HasNilValue(v reflect.Value) bool
- func (f *Field) HasZeroValue(v reflect.Value) bool
- func (f *Field) ScanValue(strct reflect.Value, src interface{}) error
- func (f *Field) ScanWithCheck(fv reflect.Value, src interface{}) error
- func (f *Field) SkipUpdate() bool
- func (f *Field) String() string
- func (f *Field) Value(strct reflect.Value) reflect.Value
- func (f *Field) WithIndex(path []int) *Field
- type Formatter
- func (f Formatter) AppendIdent(b []byte, ident string) []byte
- func (f Formatter) AppendName(b []byte, name string) []byte
- func (f Formatter) AppendQuery(dst []byte, query string, args ...interface{}) []byte
- func (f Formatter) AppendValue(b []byte, v reflect.Value) []byte
- func (f Formatter) Dialect() Dialect
- func (f Formatter) FormatQuery(query string, args ...interface{}) string
- func (f Formatter) HasFeature(feature feature.Feature) bool
- func (f Formatter) IdentQuote() byte
- func (f Formatter) IsNop() bool
- func (f Formatter) WithArg(arg NamedArgAppender) Formatter
- func (f Formatter) WithNamedArg(name string, value interface{}) Formatter
- type Ident
- type IsZeroerFunc
- type Model
- type Name
- type NamedArgAppender
- type NullTime
- type Query
- type QueryAppender
- type QueryWithArgs
- type QueryWithSep
- type Relation
- type Safe
- type ScannerFunc
- type Table
- func (t *Table) AppendNamedArg(fmter Formatter, b []byte, name string, strct reflect.Value) ([]byte, bool)
- func (t *Table) CheckPKs() error
- func (t *Table) Dialect() Dialect
- func (t *Table) Field(name string) (*Field, error)
- func (t *Table) HasAfterScanHook() bool
- func (t *Table) HasAfterScanRowHook() bool
- func (t *Table) HasBeforeAppendModelHook() bool
- func (t *Table) HasBeforeScanHook() bool
- func (t *Table) HasBeforeScanRowHook() bool
- func (t *Table) HasField(name string) bool
- func (t *Table) LookupField(name string) *Field
- func (t *Table) String() string
- type Tables
Constants ¶
const ( InvalidRelation = iota HasOneRelation BelongsToRelation HasManyRelation ManyToManyRelation )
Variables ¶
This section is empty.
Functions ¶
func AppendBoolValue ¶ added in v0.1.6
func AppendFloat32Value ¶ added in v0.1.6
func AppendFloat64Value ¶ added in v0.1.6
func AppendJSONValue ¶ added in v0.3.4
func AppendQueryAppender ¶
func AppendQueryAppender(fmter Formatter, b []byte, app QueryAppender) []byte
func AppendStringValue ¶ added in v0.3.4
func DiscoverSQLType ¶ added in v0.1.17
func SetTableNameInflector ¶
SetTableNameInflector overrides the default func that pluralizes model name to get table name, e.g. my_article becomes my_articles.
Types ¶
type AfterScanRowHook ¶ added in v1.0.13
type AppenderFunc ¶
func FieldAppender ¶
func FieldAppender(dialect Dialect, field *Field) AppenderFunc
func PtrAppender ¶ added in v1.0.3
func PtrAppender(fn AppenderFunc) AppenderFunc
type BaseDialect ¶ added in v1.0.14
type BaseDialect struct{}
func (BaseDialect) AppendBool ¶ added in v1.1.9
func (BaseDialect) AppendBool(b []byte, v bool) []byte
func (BaseDialect) AppendBytes ¶ added in v1.0.14
func (BaseDialect) AppendBytes(b, bs []byte) []byte
func (BaseDialect) AppendJSON ¶ added in v1.0.14
func (BaseDialect) AppendJSON(b, jsonb []byte) []byte
func (BaseDialect) AppendString ¶ added in v1.0.17
func (BaseDialect) AppendString(b []byte, s string) []byte
func (BaseDialect) AppendTime ¶ added in v1.0.14
func (BaseDialect) AppendTime(b []byte, tm time.Time) []byte
func (BaseDialect) AppendUint32 ¶ added in v1.0.14
func (BaseDialect) AppendUint32(b []byte, n uint32) []byte
func (BaseDialect) AppendUint64 ¶ added in v1.0.14
func (BaseDialect) AppendUint64(b []byte, n uint64) []byte
type BeforeAppendModelHook ¶ added in v1.0.13
type BeforeScanRowHook ¶ added in v1.0.13
type ColumnsAppender ¶
type CustomAppender ¶ added in v0.3.4
type CustomAppender func(typ reflect.Type) AppenderFunc
type Dialect ¶
type Dialect interface { Init(db *sql.DB) Name() dialect.Name Features() feature.Feature Tables() *Tables OnTable(table *Table) IdentQuote() byte AppendUint32(b []byte, n uint32) []byte AppendUint64(b []byte, n uint64) []byte AppendTime(b []byte, tm time.Time) []byte AppendString(b []byte, s string) []byte AppendBytes(b []byte, bs []byte) []byte AppendJSON(b, jsonb []byte) []byte AppendBool(b []byte, v bool) []byte // AppendSequence adds the appropriate instruction for the driver to create a sequence // from which (autoincremented) values for the column will be generated. AppendSequence(b []byte, t *Table, f *Field) []byte // DefaultVarcharLen should be returned for dialects in which specifying VARCHAR length // is mandatory in queries that modify the schema (CREATE TABLE / ADD COLUMN, etc). // Dialects that do not have such requirement may return 0, which should be interpreted so by the caller. DefaultVarcharLen() int // DefaultSchema should returns the name of the default database schema. DefaultSchema() string }
type Field ¶
type Field struct { Table *Table // Contains this field StructField reflect.StructField IsPtr bool Tag tagparser.Tag IndirectType reflect.Type Index []int Name string // SQL name, .e.g. id SQLName Safe // escaped SQL name, e.g. "id" GoName string // struct field name, e.g. Id DiscoveredSQLType string UserSQLType string CreateTableSQLType string SQLDefault string OnDelete string OnUpdate string IsPK bool NotNull bool NullZero bool AutoIncrement bool Identity bool Append AppenderFunc Scan ScannerFunc IsZero IsZeroerFunc }
func (*Field) AppendValue ¶
func (*Field) ScanWithCheck ¶
func (*Field) SkipUpdate ¶ added in v1.1.6
type Formatter ¶
type Formatter struct {
// contains filtered or unexported fields
}
func NewFormatter ¶
func NewNopFormatter ¶
func NewNopFormatter() Formatter
func (Formatter) AppendName ¶ added in v1.1.15
func (Formatter) AppendQuery ¶
func (Formatter) FormatQuery ¶
func (Formatter) IdentQuote ¶
func (Formatter) WithArg ¶
func (f Formatter) WithArg(arg NamedArgAppender) Formatter
func (Formatter) WithNamedArg ¶ added in v0.4.3
type Ident ¶
type Ident string
Ident represents a SQL identifier, for example, a fully qualified column name such as `table_name.col_name`.
type IsZeroerFunc ¶
type Name ¶ added in v1.1.15
type Name string
Name represents a single SQL name, for example, a column name.
type NamedArgAppender ¶ added in v0.4.0
type NullTime ¶ added in v0.1.17
NullTime is a time.Time wrapper that marshals zero time as JSON null and SQL NULL.
func (NullTime) AppendQuery ¶ added in v0.1.17
func (NullTime) MarshalJSON ¶ added in v0.1.17
func (*NullTime) UnmarshalJSON ¶ added in v0.1.17
type Query ¶ added in v1.0.5
type Query interface { QueryAppender Operation() string GetModel() Model GetTableName() string }
type QueryAppender ¶
func In ¶ added in v1.1.2
func In(slice interface{}) QueryAppender
func NullZero ¶ added in v1.1.15
func NullZero(value interface{}) QueryAppender
type QueryWithArgs ¶
type QueryWithArgs struct { Query string Args []interface{} }
NOTE: It should not be modified after creation.
func SafeQuery ¶
func SafeQuery(query string, args []interface{}) QueryWithArgs
func UnsafeIdent ¶
func UnsafeIdent(ident string) QueryWithArgs
func (QueryWithArgs) AppendQuery ¶
func (q QueryWithArgs) AppendQuery(fmter Formatter, b []byte) ([]byte, error)
func (QueryWithArgs) IsZero ¶
func (q QueryWithArgs) IsZero() bool
type QueryWithSep ¶
type QueryWithSep struct { QueryWithArgs Sep string }
func SafeQueryWithSep ¶
func SafeQueryWithSep(query string, args []interface{}, sep string) QueryWithSep
type Relation ¶
type Relation struct { Type int Field *Field // Has the bun tag defining this relation. // Base and Join can be explained with this query: // // SELECT * FROM base_table JOIN join_table JoinTable *Table BasePKs []*Field JoinPKs []*Field OnUpdate string OnDelete string Condition []string PolymorphicField *Field PolymorphicValue string M2MTable *Table M2MBasePKs []*Field M2MJoinPKs []*Field }
func (*Relation) References ¶ added in v1.1.17
References returns true if the table which defines this Relation needs to declare a foreign key constraint, as is the case for 'has-one' and 'belongs-to' relations. For other relations, the constraint is created either in the referencing table (1:N, 'has-many' relations) or the junction table (N:N, 'm2m' relations).
Usage of `rel:` tag does not always imply creation of foreign keys (when WithForeignKeys() is not set) and can be used exclusively for joining tables at query time. For example:
type User struct { ID int64 `bun:",pk"` Profile *Profile `bun:",rel:has-one,join:id=user_id"` }
Creating a FK users.id -> profiles.user_id would be confusing and incorrect, so for such cases References() returns false. One notable exception to this rule is when a Relation is defined in a junction table, in which case it is perfectly fine for its primary keys to reference other tables. Consider:
// UsersToGroups maps users to groups they follow. type UsersToGroups struct { UserID string `bun:"user_id,pk"` // Needs FK to users.id GroupID string `bun:"group_id,pk"` // Needs FK to groups.id User *User `bun:"rel:belongs-to,join:user_id=id"` Group *Group `bun:"rel:belongs-to,join:group_id=id"` }
Here BooksToReaders has a composite primary key, composed of other primary keys.
type ScannerFunc ¶
func FieldScanner ¶
func FieldScanner(dialect Dialect, field *Field) ScannerFunc
func PtrScanner ¶ added in v1.0.3
func PtrScanner(fn ScannerFunc) ScannerFunc
func Scanner ¶
func Scanner(typ reflect.Type) ScannerFunc
type Table ¶
type Table struct { Type reflect.Type ZeroValue reflect.Value // reflect.Struct ZeroIface interface{} // struct pointer TypeName string ModelName string Schema string Name string SQLName Safe SQLNameForSelects Safe Alias string SQLAlias Safe Fields []*Field // PKs + DataFields PKs []*Field DataFields []*Field FieldMap map[string]*Field StructMap map[string]*structField IsM2MTable bool // If true, this table is the "junction table" of an m2m relation. Relations map[string]*Relation Unique map[string][]*Field SoftDeleteField *Field UpdateSoftDeleteField func(fv reflect.Value, tm time.Time) error // contains filtered or unexported fields }
Table represents a SQL table created from Go struct.
func (*Table) AppendNamedArg ¶ added in v0.4.3
func (*Table) HasAfterScanHook ¶
DEPRECATED. Use HasAfterScanRowHook.
func (*Table) HasAfterScanRowHook ¶ added in v1.0.13
func (*Table) HasBeforeAppendModelHook ¶ added in v1.0.13
func (*Table) HasBeforeScanHook ¶
DEPRECATED. Use HasBeforeScanRowHook.