티스토리 뷰
반응형
Golang에서의 경량 ORM으로서의 bun package를 다루며 경험한 내용을 정리해둔다.
Query building
링크: https://bun.uptrace.dev/guide/complex-queries.html#query-generation
Query를 만들면서 조건에 따라 더욱 이어붙이는 건에 대하여
q = q.Limit() 의 결과가 단순히 q.Limit()와 같은 것을 동료분이 이야기해 알게 되었다.
코드가 더욱 간결해진다. 그런데 위 링크를 보면 심지어 bun 패키지 설명도 그 차이를 모르는 것인가 싶다.
Example code with comment
아래 코드와 코멘트로 설명을 마무리 한다.
전체 GitHub Repo: https://github.com/nicewook/bun-orm-study
Query Building Example: https://github.com/nicewook/bun-orm-study/blob/main/query-build/main.go
func main() {
prepareDB()
// Query build 방법 1
query := db.NewSelect().Model((*User)(nil))
fmt.Printf("memory address %p, query: %v\n", query, query)
query = query.Where("name =?", "kim") // Where() 메서드의 결과를 왼쪽으로 대입한다
fmt.Printf("memory address %p, query: %v\n", query, query)
// Query build 방법 2
query = db.NewSelect().Model((*User)(nil))
fmt.Printf("memory address %p, query: %v\n", query, query)
query.Where("name =?", "kim") // 대입을 시키지 않고 단순히 Where() 만을 실행한다.
fmt.Printf("memory address %p, query: %v\n", query, query)
}
// 결과를 보면
// 1. query를 추가해주어도 두 경우 모두 메모리 주소가 바뀌지 않고, 생성된 query string 도 동일함을 알 수 있다.
// memory address 0x140002e8000, query: SELECT "u"."id", "u"."name" FROM "users" AS "u"
// memory address 0x140002e8000, query: SELECT "u"."id", "u"."name" FROM "users" AS "u" WHERE (name ='kim')
// memory address 0x140002e81e0, query: SELECT "u"."id", "u"."name" FROM "users" AS "u"
// memory address 0x140002e81e0, query: SELECT "u"."id", "u"."name" FROM "users" AS "u" WHERE (name ='kim')
반응형
'golang' 카테고리의 다른 글
Golang: go get으로 패키지를 최신으로 업데이트 하는 법 (0) | 2022.12.15 |
---|---|
Golang ORM - Bun 삽질 이야기 - Automatic timestamp (0) | 2022.12.10 |
Golang ORM - Bun 삽질 이야기 - ScanAndCount (0) | 2022.12.09 |
Golang: 양자 컴퓨터 이후의 암호기술 구현 패키지 sidh 분석 (0) | 2021.12.28 |
Golang: gorilla/websocket chatting 예제 분석 (0) | 2021.12.13 |
댓글
반응형
공지사항
최근에 달린 댓글
- Total
- 386,764
- Today
- 16
- Yesterday
- 307
링크
TAG
- golang
- docker
- bun
- gcm
- go
- 클린 애자일
- min heap
- gorilla/websocket
- 마셜
- 로젠버그
- heap
- Handshake
- Gin
- agile
- 하드씽
- websocket
- install
- solid
- branch
- timestamp
- 2022
- postgres
- powershell
- additional data
- AES
- 비폭력대화
- 명상
- ORM
- 자아
- 독서후기