Files
yatm/resource/db.go
2023-10-03 16:12:44 +08:00

61 lines
1.0 KiB
Go

package resource
import (
"gorm.io/driver/mysql"
"gorm.io/driver/sqlite"
"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 = sqlite.Open(dsn)
}
return gorm.Open(dialector)
}
func SQLEscape(sql string) string {
dest := make([]byte, 0, 2*len(sql))
var escape byte
for i := 0; i < len(sql); i++ {
c := sql[i]
escape = 0
switch c {
case 0: /* Must be escaped for 'mysql' */
escape = '0'
break
case '\n': /* Must be escaped for logs */
escape = 'n'
break
case '\r':
escape = 'r'
break
case '\\':
escape = '\\'
break
case '\'':
escape = '\''
break
case '"': /* Better safe than sorry */
escape = '"'
break
case '\032': //十进制26,八进制32,十六进制1a, /* This gives problems on Win32 */
escape = 'Z'
}
if escape != 0 {
dest = append(dest, '\\', escape)
} else {
dest = append(dest, c)
}
}
return string(dest)
}