Files
yatm/resource/db.go
2023-10-05 02:11:37 +08:00

73 lines
1.3 KiB
Go

package resource
import (
"fmt"
"gorm.io/driver/mysql"
"gorm.io/gorm"
)
func NewDBConn(dialect, dsn string) (*gorm.DB, error) {
var dialector gorm.Dialector
switch dialect {
case "mysql":
dialector = mysql.Open(dsn)
case "sqlite":
dialector = openSQLite(dsn)
}
db, err := gorm.Open(dialector)
if err != nil {
return nil, fmt.Errorf("new db conn fail, dialect= '%s' dsn= '%s', %w", dialect, dsn, err)
}
switch dialect {
case "sqlite":
sqlDB, err := db.DB()
if err != nil {
return nil, fmt.Errorf("sqlite set config fail, dialect= '%s' dsn= '%s', %w", dialect, dsn, err)
}
// Prevent "database locked" errors
sqlDB.SetMaxOpenConns(1)
}
return db, nil
}
func SQLEscape(str string) string {
runes := []rune(str)
result := make([]rune, 0, len(runes))
var escape rune
for i := 0; i < len(runes); i++ {
r := runes[i]
escape = 0
switch r {
case 0: /* Must be escaped for 'mysql' */
escape = '0'
case '\n': /* Must be escaped for logs */
escape = 'n'
case '\r':
escape = 'r'
case '\\':
escape = '\\'
case '\'':
escape = '\''
case '"': /* Better safe than sorry */
escape = '"'
case '\032': // This gives problems on Win32
escape = 'Z'
}
if escape != 0 {
result = append(result, '\\', escape)
} else {
result = append(result, r)
}
}
return string(result)
}