2020-07-14 14:07:44 +08:00
|
|
|
|
package system
|
2020-07-13 20:33:20 +08:00
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"ferry/global/orm"
|
|
|
|
|
"fmt"
|
|
|
|
|
"io/ioutil"
|
|
|
|
|
"strings"
|
|
|
|
|
)
|
|
|
|
|
|
2020-07-17 15:51:05 +08:00
|
|
|
|
/*
|
|
|
|
|
@Author : lanyulei
|
|
|
|
|
*/
|
|
|
|
|
|
2020-07-13 20:33:20 +08:00
|
|
|
|
func InitDb() error {
|
|
|
|
|
filePath := "config/db.sql"
|
|
|
|
|
sql, err := Ioutil(filePath)
|
|
|
|
|
if err != nil {
|
|
|
|
|
fmt.Println("数据库基础数据初始化脚本读取失败!原因:", err.Error())
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
sqlList := strings.Split(sql, ";")
|
2020-08-21 17:09:46 +08:00
|
|
|
|
for _, sql := range sqlList {
|
|
|
|
|
if strings.Contains(sql, "--") {
|
|
|
|
|
fmt.Println(sql)
|
2020-07-13 20:33:20 +08:00
|
|
|
|
continue
|
|
|
|
|
}
|
2020-08-21 17:09:46 +08:00
|
|
|
|
sqlValue := strings.Replace(sql+";", "\n", "", 1)
|
|
|
|
|
if err = orm.Eloquent.Exec(sqlValue).Error; err != nil {
|
2020-07-13 20:33:20 +08:00
|
|
|
|
if !strings.Contains(err.Error(), "Query was empty") {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func Ioutil(name string) (string, error) {
|
|
|
|
|
if contents, err := ioutil.ReadFile(name); err == nil {
|
|
|
|
|
//因为contents是[]byte类型,直接转换成string类型后会多一行空格,需要使用strings.Replace替换换行符
|
|
|
|
|
result := strings.Replace(string(contents), "\n", "", 1)
|
|
|
|
|
return result, nil
|
|
|
|
|
} else {
|
|
|
|
|
return "", err
|
|
|
|
|
}
|
|
|
|
|
}
|