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