123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263 |
- package migrate
- import (
- "fmt"
- "log"
- "os"
- "strings"
- "gorm.io/gorm"
- )
- func InitDb(db *gorm.DB) (err error) {
- filePath := "conf/db.sql"
- if err = ExecSql(db, filePath); err != nil {
- return err
- }
- return err
- }
- func ExecSql(db *gorm.DB, filePath string) error {
- sql, err := IoUtil(filePath)
- if err != nil {
- fmt.Println("数据库基础数据初始化脚本读取失败!原因:", err.Error())
- return err
- }
- tx := db.Begin()
- defer func() {
- if err != nil {
- tx.Rollback()
- } else {
- tx.Commit()
- }
- }()
- sqlList := strings.Split(sql, ";")
- for i := 0; i < len(sqlList)-1; i++ {
- if strings.Contains(sqlList[i], "--") {
- fmt.Println(sqlList[i])
- continue
- }
- sql := strings.Replace(sqlList[i]+";", "\n", "", -1)
- sql = strings.TrimSpace(sql)
- if err = tx.Exec(sql).Error; err != nil {
- log.Printf("error sql: %s", sql)
- if !strings.Contains(err.Error(), "Query was empty") {
- return err
- }
- }
- }
- return nil
- }
- func IoUtil(filePath string) (string, error) {
- if contents, err := os.ReadFile(filePath); err == nil {
- //因为contents是[]byte类型,直接转换成string类型后会多一行空格,需要使用strings.Replace替换换行符
- result := strings.Replace(string(contents), "\n", "", 1)
- fmt.Println("Use ioUtil.ReadFile to read a file:", result)
- return result, nil
- } else {
- return "", err
- }
- }
|