티스토리 뷰
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
- Today
- Yesterday
TAG
- strange
- Bug
- golang
- notion
- OpenAI
- 엉클 밥
- 클린 애자일
- Gin
- intellij
- 독서
- 제이펍
- API
- websocket
- 노션
- agile
- 잡학툰
- bun
- 2023
- 독서후기
- solid
- go
- 오블완
- folklore
- 영화
- github
- 인텔리제이
- ChatGPT
- 체호프
- clean agile
- 티스토리챌린지
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
글 보관함