2023-01-30 12:27:34 +01:00
|
|
|
package sortby
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/jinzhu/gorm"
|
|
|
|
_ "github.com/jinzhu/gorm/dialects/mysql"
|
|
|
|
_ "github.com/jinzhu/gorm/dialects/sqlite"
|
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
|
|
|
MySQL = "mysql"
|
|
|
|
SQLite3 = "sqlite3"
|
|
|
|
)
|
|
|
|
|
|
|
|
// RandomExpr returns the name of the random function depending on the SQL dialect.
|
|
|
|
func RandomExpr(dialect gorm.Dialect) *gorm.SqlExpr {
|
|
|
|
switch dialect.GetName() {
|
|
|
|
case MySQL:
|
2024-01-01 16:22:09 +01:00
|
|
|
// A seed integer can be passed as an argument, e.g. "RAND(2342)", to generate
|
|
|
|
// reproducible pseudo-random values, see https://mariadb.com/kb/en/rand/.
|
2023-01-30 12:27:34 +01:00
|
|
|
return gorm.Expr("RAND()")
|
|
|
|
case SQLite3:
|
2024-01-01 16:22:09 +01:00
|
|
|
// SQLite does not support specifying a seed to generate a deterministic sequence
|
|
|
|
// of pseudo-random values, see https://www.sqlite.org/lang_corefunc.html#random.
|
2023-01-30 12:27:34 +01:00
|
|
|
return gorm.Expr("RANDOM()")
|
|
|
|
default:
|
|
|
|
return gorm.Expr("RAND()")
|
|
|
|
}
|
|
|
|
}
|