71 lines
2.4 KiB
Go
71 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
|
|||
|
}
|