70 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			70 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
package tools
 | 
						||
 | 
						||
import (
 | 
						||
	"errors"
 | 
						||
 | 
						||
	"github.com/go-admin-team/go-admin-core/sdk/config"
 | 
						||
	"github.com/go-admin-team/go-admin-core/sdk/pkg"
 | 
						||
	"gorm.io/gorm"
 | 
						||
)
 | 
						||
 | 
						||
type DBColumns struct {
 | 
						||
	TableSchema            string `gorm:"column:TABLE_SCHEMA" json:"tableSchema"`
 | 
						||
	TableName              string `gorm:"column:TABLE_NAME" json:"tableName"`
 | 
						||
	ColumnName             string `gorm:"column:COLUMN_NAME" json:"columnName"`
 | 
						||
	ColumnDefault          string `gorm:"column:COLUMN_DEFAULT" json:"columnDefault"`
 | 
						||
	IsNullable             string `gorm:"column:IS_NULLABLE" json:"isNullable"`
 | 
						||
	DataType               string `gorm:"column:DATA_TYPE" json:"dataType"`
 | 
						||
	CharacterMaximumLength string `gorm:"column:CHARACTER_MAXIMUM_LENGTH" json:"characterMaximumLength"`
 | 
						||
	CharacterSetName       string `gorm:"column:CHARACTER_SET_NAME" json:"characterSetName"`
 | 
						||
	ColumnType             string `gorm:"column:COLUMN_TYPE" json:"columnType"`
 | 
						||
	ColumnKey              string `gorm:"column:COLUMN_KEY" json:"columnKey"`
 | 
						||
	Extra                  string `gorm:"column:EXTRA" json:"extra"`
 | 
						||
	ColumnComment          string `gorm:"column:COLUMN_COMMENT" json:"columnComment"`
 | 
						||
}
 | 
						||
 | 
						||
func (e *DBColumns) GetPage(tx *gorm.DB, pageSize int, pageIndex int) ([]DBColumns, int, error) {
 | 
						||
	var doc []DBColumns
 | 
						||
	var count int64
 | 
						||
	table := new(gorm.DB)
 | 
						||
 | 
						||
	if config.DatabaseConfig.Driver == "mysql" {
 | 
						||
		table = tx.Table("information_schema.`COLUMNS`")
 | 
						||
		table = table.Where("table_schema= ? ", config.GenConfig.DBName)
 | 
						||
 | 
						||
		if e.TableName != "" {
 | 
						||
			return nil, 0, errors.New("table name cannot be empty!")
 | 
						||
		}
 | 
						||
 | 
						||
		table = table.Where("TABLE_NAME = ?", e.TableName)
 | 
						||
	}
 | 
						||
 | 
						||
	if err := table.Offset((pageIndex - 1) * pageSize).Limit(pageSize).Find(&doc).Offset(-1).Limit(-1).Count(&count).Error; err != nil {
 | 
						||
		return nil, 0, err
 | 
						||
	}
 | 
						||
	//table.Count(&count)
 | 
						||
	return doc, int(count), nil
 | 
						||
 | 
						||
}
 | 
						||
 | 
						||
func (e *DBColumns) GetList(tx *gorm.DB) ([]DBColumns, error) {
 | 
						||
	var doc []DBColumns
 | 
						||
	table := new(gorm.DB)
 | 
						||
 | 
						||
	if e.TableName == "" {
 | 
						||
		return nil, errors.New("table name cannot be empty!")
 | 
						||
	}
 | 
						||
 | 
						||
	if config.DatabaseConfig.Driver == "mysql" {
 | 
						||
		table = tx.Table("information_schema.columns")
 | 
						||
		table = table.Where("table_schema= ? ", config.GenConfig.DBName)
 | 
						||
 | 
						||
		table = table.Where("TABLE_NAME = ?", e.TableName).Order("ORDINAL_POSITION asc")
 | 
						||
	} else {
 | 
						||
		pkg.Assert(true, "目前只支持mysql数据库", 500)
 | 
						||
	}
 | 
						||
	if err := table.Find(&doc).Error; err != nil {
 | 
						||
		return doc, err
 | 
						||
	}
 | 
						||
	return doc, nil
 | 
						||
} |