mirror of
https://github.com/samuelncui/yatm.git
synced 2025-12-23 06:15:22 +00:00
73 lines
1.3 KiB
Go
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)
|
|
}
|