지난 게시물에서는 페이지 매김을 다루면서 대규모 API 응답을 관리 가능한 덩어리로 나누었습니다. 하지만 사용자가 데이터 정렬 방법을 제어하거나 특정 결과를 필터링할 수 있도록 하고 싶다면 다음 단계인 정렬을 수행할 준비가 된 것입니다. 필터링.
이러한 기능을 추가하여 API를 더욱 강력하게 만들어 보겠습니다.
이전 튜토리얼을 진행하지 않으셨다면 여기 링크를 확인하세요.
정렬 및 필터링이 중요한 이유
페이지 매김만으로는 항상 충분하지 않습니다. 사용자가 최신 항목을 검색하거나 특정 기간에 생성된 항목만 검색한다고 상상해 보세요. 정렬 및 필터링을 통해 사용자는 다음을 수행할 수 있습니다.
- 정렬: 결과 순서 선택(예: 최신 항목에서 오래된 항목 순)
- 필터: 필요한 항목으로 결과 범위를 좁힙니다(예: 오늘 생성된 항목)
페이지 매김과 정렬 및 필터링을 결합하여 보다 사용자 친화적인 API를 만듭니다.
데이터베이스 쿼리 확장
이전 블로그의 항목 테이블을 기반으로 작성하겠습니다. 요약하면 다음과 같습니다.
CREATE TABLE items ( id SERIAL PRIMARY KEY, name TEXT NOT NULL, created_at TIMESTAMP DEFAULT NOW() );
정렬 추가
정렬은 결과를 정렬하는 것입니다. 사용자는 이름 또는 Create_at 열을 기준으로 오름차순 또는 내림차순으로 정렬할 수 있습니다.
1단계: 정렬 매개변수 수락
사용자는 다음 두 가지 쿼리 매개변수를 전달합니다.
- sort : 정렬 기준이 되는 열( name 또는 Created_at ).
- order : 정렬 방향(asc 또는 desc).
예제 URL:
/items?page=1&limit=10&sort=created_at&order=desc
2단계: SQL 쿼리 조정
정렬을 포함하도록 SQL 쿼리를 동적으로 수정합니다.
// Extract sort and order query parameters sort := r.URL.Query().Get("sort") order := r.URL.Query().Get("order") // Validate the sort column validSortColumns := map[string]bool{"name": true, "created_at": true} if !validSortColumns[sort] { sort = "created_at" // Default sort column } // Validate the sort order if order != "asc" && order != "desc" { order = "asc" // Default sort order } // Modify the SQL query query := fmt.Sprintf("SELECT id, name, created_at FROM items ORDER BY %s %s LIMIT OFFSET ", sort, order) rows, err := db.Query(query, limit, offset) if err != nil { http.Error(w, "Failed to fetch items", http.StatusInternalServerError) return }
필터링 추가
필터링을 통해 사용자는 검색 범위를 좁힐 수 있습니다. 예를 들어 날짜 범위를 기준으로 항목을 필터링하거나 이름에 특정 키워드가 포함된 항목을 필터링할 수 있습니다.
1단계: 필터 매개변수 수락
두 가지 필터를 지원합니다:
- name : 특정 하위 문자열이 포함된 항목을 검색합니다.
- created_after : 특정 날짜 이후에 생성된 항목을 가져옵니다.
예제 URL :
/items?page=1&limit=10&name=Item&created_after=2025-01-10 20:38:57.832777
2단계: SQL 쿼리 조정
이러한 필터를 처리하기 위해 WHERE 조건을 추가합니다.
CREATE TABLE items ( id SERIAL PRIMARY KEY, name TEXT NOT NULL, created_at TIMESTAMP DEFAULT NOW() );
향상된 API 테스트
- 이름을 기준으로 오름차순 정렬:
/items?page=1&limit=10&sort=created_at&order=desc
- 특정 날짜 이후에 생성된 항목 필터링:
// Extract sort and order query parameters sort := r.URL.Query().Get("sort") order := r.URL.Query().Get("order") // Validate the sort column validSortColumns := map[string]bool{"name": true, "created_at": true} if !validSortColumns[sort] { sort = "created_at" // Default sort column } // Validate the sort order if order != "asc" && order != "desc" { order = "asc" // Default sort order } // Modify the SQL query query := fmt.Sprintf("SELECT id, name, created_at FROM items ORDER BY %s %s LIMIT OFFSET ", sort, order) rows, err := db.Query(query, limit, offset) if err != nil { http.Error(w, "Failed to fetch items", http.StatusInternalServerError) return }
- 필터 결합 및 정렬:
/items?page=1&limit=10&name=Item&created_after=2025-01-10 20:38:57.832777
피해야 할 일반적인 실수
사용자 입력의 유효성을 검사하지 않음: 임의의 열이나 잘못된 정렬 순서를 허용하면 데이터베이스가 SQL 주입에 노출될 수 있습니다. 항상 입력을 검증하세요.
결론 / 다음 단계
여기에서 이 튜토리얼의 전체 코드 저장소를 찾을 수 있습니다
페이지 매김, 정렬, 필터링 기능이 탑재되어 이제 API가 더욱 사용자 친화적이고 유연해졌습니다. 더욱 고급 기능을 사용하려면 다음을 추가해 보세요.
- 대규모 데이터세트를 위한 커서 기반 페이지 매김
- 복잡한 검색을 위한 패싯 필터링
이러한 고급 기술을 살펴볼 다음 게시물을 계속 지켜봐 주시기 바랍니다!
Golang 개념, 프로젝트 등에 대한 자세한 정보를 얻고 튜토리얼에 대한 최신 정보를 얻으려면 Twitter 및 GitHub에서 Siddhesh를 팔로우하세요.
그때까지 계속 학습, 계속 구축 ??
위 내용은 페이지 매김을 한 단계 더 발전시키다: Go API의 정렬 및 필터링의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

goisidealforbuildingscalablesystemsduetoitssimplicity, 효율성 및 빌드-내부 컨 컨 오렌 스upport.1) go'scleansyntaxandminimalisticdesignenenhance-reductivityandreduceerrors.2) itsgoroutinesandChannelsableefficedsoncurrentProgramming, DistributingLoa

initTectionsIntOnaUtomaticallyBeforemain () andAreSefulforsettingupenvirondentAnitializingVariables.usethemforsimpletasks, propoysideeffects 및 withtestingntestingandloggingtomaincodeclarityAndestability.

goinitializespackages는 theyareimported, theexecutesinitfunctions, theneiredefinitionorder, andfilenamesDeterMineDeTerMineTeRacrossMultipleFiles.ThemayLeadTocomplexInitializations의 의존성 의존성의 의존성을 확인합니다

CustomInterfacesingoAreCrucialForwritingFlectible, 관리 가능 및 TestAblEcode.theyenabledeveloperstofocusonBehaviorimplementation, 향상 ModularityAndRobustness

시뮬레이션 및 테스트에 인터페이스를 사용하는 이유는 인터페이스가 구현을 지정하지 않고 계약의 정의를 허용하여 테스트를보다 고립되고 유지 관리하기 쉽기 때문입니다. 1) 인터페이스를 암시 적으로 구현하면 테스트에서 실제 구현을 대체 할 수있는 모의 개체를 간단하게 만들 수 있습니다. 2) 인터페이스를 사용하면 단위 테스트에서 서비스의 실제 구현을 쉽게 대체하여 테스트 복잡성과 시간을 줄일 수 있습니다. 3) 인터페이스가 제공하는 유연성은 다른 테스트 사례에 대한 시뮬레이션 동작의 변화를 허용합니다. 4) 인터페이스는 처음부터 테스트 가능한 코드를 설계하여 코드의 모듈성과 유지 관리를 향상시키는 데 도움이됩니다.

GO에서는 INT 기능이 패키지 초기화에 사용됩니다. 1) INT 기능은 패키지 초기화시 자동으로 호출되며 글로벌 변수 초기화, 연결 설정 및 구성 파일로드에 적합합니다. 2) 파일 순서로 실행할 수있는 여러 개의 초기 함수가있을 수 있습니다. 3)이를 사용할 때 실행 순서, 테스트 난이도 및 성능 영향을 고려해야합니다. 4) 부작용을 줄이고, 종속성 주입을 사용하고, 초기화를 지연하여 초기 기능의 사용을 최적화하는 것이 좋습니다.

go'selectStatementsTreamLinesconcurramprogrammingBymultiplexingOperations.1) ItallowSwaitingOnMultipLechannelOperations, executingThefirStreadYone.2) thedefaultCasePreventsDeadLocksHavingThepRamToproCeedifNooperationSready.3) Itcanusedfored

Contextandwaitgroupsarecrucialingformaninggoroutineeseforoutineeseferfectial


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경

SublimeText3 영어 버전
권장 사항: Win 버전, 코드 프롬프트 지원!

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

Eclipse용 SAP NetWeaver 서버 어댑터
Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

WebStorm Mac 버전
유용한 JavaScript 개발 도구
