156 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			156 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2019 The Xorm Authors. All rights reserved.
 | |
| // Use of this source code is governed by a BSD-style
 | |
| // license that can be found in the LICENSE file.
 | |
| 
 | |
| package core
 | |
| 
 | |
| import (
 | |
| 	"reflect"
 | |
| 	"strings"
 | |
| )
 | |
| 
 | |
| // Table represents a database table
 | |
| type Table struct {
 | |
| 	Name          string
 | |
| 	Type          reflect.Type
 | |
| 	columnsSeq    []string
 | |
| 	columnsMap    map[string][]*Column
 | |
| 	columns       []*Column
 | |
| 	Indexes       map[string]*Index
 | |
| 	PrimaryKeys   []string
 | |
| 	AutoIncrement string
 | |
| 	Created       map[string]bool
 | |
| 	Updated       string
 | |
| 	Deleted       string
 | |
| 	Version       string
 | |
| 	Cacher        Cacher
 | |
| 	StoreEngine   string
 | |
| 	Charset       string
 | |
| 	Comment       string
 | |
| }
 | |
| 
 | |
| func (table *Table) Columns() []*Column {
 | |
| 	return table.columns
 | |
| }
 | |
| 
 | |
| func (table *Table) ColumnsSeq() []string {
 | |
| 	return table.columnsSeq
 | |
| }
 | |
| 
 | |
| func NewEmptyTable() *Table {
 | |
| 	return NewTable("", nil)
 | |
| }
 | |
| 
 | |
| // NewTable creates a new Table object
 | |
| func NewTable(name string, t reflect.Type) *Table {
 | |
| 	return &Table{Name: name, Type: t,
 | |
| 		columnsSeq:  make([]string, 0),
 | |
| 		columns:     make([]*Column, 0),
 | |
| 		columnsMap:  make(map[string][]*Column),
 | |
| 		Indexes:     make(map[string]*Index),
 | |
| 		Created:     make(map[string]bool),
 | |
| 		PrimaryKeys: make([]string, 0),
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func (table *Table) columnsByName(name string) []*Column {
 | |
| 	n := len(name)
 | |
| 
 | |
| 	for k := range table.columnsMap {
 | |
| 		if len(k) != n {
 | |
| 			continue
 | |
| 		}
 | |
| 		if strings.EqualFold(k, name) {
 | |
| 			return table.columnsMap[k]
 | |
| 		}
 | |
| 	}
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| func (table *Table) GetColumn(name string) *Column {
 | |
| 
 | |
| 	cols := table.columnsByName(name)
 | |
| 
 | |
| 	if cols != nil {
 | |
| 		return cols[0]
 | |
| 	}
 | |
| 
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| func (table *Table) GetColumnIdx(name string, idx int) *Column {
 | |
| 	cols := table.columnsByName(name)
 | |
| 
 | |
| 	if cols != nil && idx < len(cols) {
 | |
| 		return cols[idx]
 | |
| 	}
 | |
| 
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| // PKColumns reprents all primary key columns
 | |
| func (table *Table) PKColumns() []*Column {
 | |
| 	columns := make([]*Column, len(table.PrimaryKeys))
 | |
| 	for i, name := range table.PrimaryKeys {
 | |
| 		columns[i] = table.GetColumn(name)
 | |
| 	}
 | |
| 	return columns
 | |
| }
 | |
| 
 | |
| func (table *Table) ColumnType(name string) reflect.Type {
 | |
| 	t, _ := table.Type.FieldByName(name)
 | |
| 	return t.Type
 | |
| }
 | |
| 
 | |
| func (table *Table) AutoIncrColumn() *Column {
 | |
| 	return table.GetColumn(table.AutoIncrement)
 | |
| }
 | |
| 
 | |
| func (table *Table) VersionColumn() *Column {
 | |
| 	return table.GetColumn(table.Version)
 | |
| }
 | |
| 
 | |
| func (table *Table) UpdatedColumn() *Column {
 | |
| 	return table.GetColumn(table.Updated)
 | |
| }
 | |
| 
 | |
| func (table *Table) DeletedColumn() *Column {
 | |
| 	return table.GetColumn(table.Deleted)
 | |
| }
 | |
| 
 | |
| // AddColumn adds a column to table
 | |
| func (table *Table) AddColumn(col *Column) {
 | |
| 	table.columnsSeq = append(table.columnsSeq, col.Name)
 | |
| 	table.columns = append(table.columns, col)
 | |
| 	colName := strings.ToLower(col.Name)
 | |
| 	if c, ok := table.columnsMap[colName]; ok {
 | |
| 		table.columnsMap[colName] = append(c, col)
 | |
| 	} else {
 | |
| 		table.columnsMap[colName] = []*Column{col}
 | |
| 	}
 | |
| 
 | |
| 	if col.IsPrimaryKey {
 | |
| 		table.PrimaryKeys = append(table.PrimaryKeys, col.Name)
 | |
| 	}
 | |
| 	if col.IsAutoIncrement {
 | |
| 		table.AutoIncrement = col.Name
 | |
| 	}
 | |
| 	if col.IsCreated {
 | |
| 		table.Created[col.Name] = true
 | |
| 	}
 | |
| 	if col.IsUpdated {
 | |
| 		table.Updated = col.Name
 | |
| 	}
 | |
| 	if col.IsDeleted {
 | |
| 		table.Deleted = col.Name
 | |
| 	}
 | |
| 	if col.IsVersion {
 | |
| 		table.Version = col.Name
 | |
| 	}
 | |
| }
 | |
| 
 | |
| // AddIndex adds an index or an unique to table
 | |
| func (table *Table) AddIndex(index *Index) {
 | |
| 	table.Indexes[index.Name] = index
 | |
| }
 |