0
0
mirror of https://github.com/go-gitea/gitea.git synced 2025-01-15 22:51:29 +01:00
gitea/vendor/xorm.io/core
guillep2k ad1b6d439f Add support for database schema in PostgreSQL (#8819)
* Add support for database schema

* Require setting search_path for the db user

* Add schema setting to admin/config.tmpl

* Use a schema different from default for psql tests

* Update postgres scripts to use custom schema

* Update to xorm/core 0.7.3 and xorm/xorm c37aff9b3a

* Fix migration test

Co-authored-by: Antoine GIRARD <sapk@users.noreply.github.com>
Co-authored-by: Lunny Xiao <xiaolunwen@gmail.com>
2020-01-20 16:45:14 +01:00
..
.drone.yml Add support for database schema in PostgreSQL (#8819) 2020-01-20 16:45:14 +01:00
.gitignore
benchmark.sh
cache.go Retry create issue to cope with duplicate keys (#7898) 2019-08-26 22:17:23 -04:00
column.go Add support for database schema in PostgreSQL (#8819) 2020-01-20 16:45:14 +01:00
converstion.go
db.go Retry create issue to cope with duplicate keys (#7898) 2019-08-26 22:17:23 -04:00
dialect.go Retry create issue to cope with duplicate keys (#7898) 2019-08-26 22:17:23 -04:00
driver.go
error.go Retry create issue to cope with duplicate keys (#7898) 2019-08-26 22:17:23 -04:00
filter.go Upgrade xorm to latest to fix insert issue bug (#8309) 2019-09-29 20:52:39 +08:00
go.mod Upgrade xorm to latest to fix insert issue bug (#8309) 2019-09-29 20:52:39 +08:00
go.sum Upgrade xorm to latest to fix insert issue bug (#8309) 2019-09-29 20:52:39 +08:00
ilogger.go Retry create issue to cope with duplicate keys (#7898) 2019-08-26 22:17:23 -04:00
index.go Add support for database schema in PostgreSQL (#8819) 2020-01-20 16:45:14 +01:00
LICENSE
mapper.go Retry create issue to cope with duplicate keys (#7898) 2019-08-26 22:17:23 -04:00
pk.go
README.md Add support for database schema in PostgreSQL (#8819) 2020-01-20 16:45:14 +01:00
rows.go Retry create issue to cope with duplicate keys (#7898) 2019-08-26 22:17:23 -04:00
scan.go
stmt.go Retry create issue to cope with duplicate keys (#7898) 2019-08-26 22:17:23 -04:00
table.go Retry create issue to cope with duplicate keys (#7898) 2019-08-26 22:17:23 -04:00
tx.go
type.go Upgrade xorm to latest to fix insert issue bug (#8309) 2019-09-29 20:52:39 +08:00

Core is a lightweight wrapper of sql.DB.

Build Status Test Coverage Go Report Card

Open

db, _ := core.Open(db, connstr)

SetMapper

db.SetMapper(SameMapper())

Scan usage

Scan

rows, _ := db.Query()
for rows.Next() {
    rows.Scan()
}

ScanMap

rows, _ := db.Query()
for rows.Next() {
    rows.ScanMap()

ScanSlice

You can use []string, [][]byte, []interface{}, []*string, []sql.NullString to ScanSclice. Notice, slice's length should be equal or less than select columns.

rows, _ := db.Query()
cols, _ := rows.Columns()
for rows.Next() {
    var s = make([]string, len(cols))
    rows.ScanSlice(&s)
}
rows, _ := db.Query()
cols, _ := rows.Columns()
for rows.Next() {
    var s = make([]*string, len(cols))
    rows.ScanSlice(&s)
}

ScanStruct

rows, _ := db.Query()
for rows.Next() {
    rows.ScanStructByName()
    rows.ScanStructByIndex()
}

Query usage

rows, err := db.Query("select * from table where name = ?", name)

user = User{
    Name:"lunny",
}
rows, err := db.QueryStruct("select * from table where name = ?Name",
            &user)

var user = map[string]interface{}{
    "name": "lunny",
}
rows, err = db.QueryMap("select * from table where name = ?name",
            &user)

QueryRow usage

row := db.QueryRow("select * from table where name = ?", name)

user = User{
    Name:"lunny",
}
row := db.QueryRowStruct("select * from table where name = ?Name",
            &user)

var user = map[string]interface{}{
    "name": "lunny",
}
row = db.QueryRowMap("select * from table where name = ?name",
            &user)

Exec usage

db.Exec("insert into user (`name`, title, age, alias, nick_name,created) values (?,?,?,?,?,?)", name, title, age, alias...)

user = User{
    Name:"lunny",
    Title:"test",
    Age: 18,
}
result, err = db.ExecStruct("insert into user (`name`, title, age, alias, nick_name,created) values (?Name,?Title,?Age,?Alias,?NickName,?Created)",
            &user)

var user = map[string]interface{}{
    "Name": "lunny",
    "Title": "test",
    "Age": 18,
}
result, err = db.ExecMap("insert into user (`name`, title, age, alias, nick_name,created) values (?Name,?Title,?Age,?Alias,?NickName,?Created)",
            &user)