목표
이 튜토리얼에서는 Spanner ADO.NET 드라이버를 사용하여 다음 단계를 안내합니다.
- Spanner 인스턴스와 데이터베이스 만들기
- 데이터베이스에서 데이터 읽기, 쓰기 및 데이터에서 SQL 쿼리 실행
- 데이터베이스 스키마 업데이트
- 읽기-쓰기 트랜잭션을 사용하여 데이터 업데이트
- 데이터베이스에 보조 색인 추가
- 색인을 사용하여 데이터 읽기 및 데이터에서 SQL 쿼리 실행
- 읽기 전용 트랜잭션을 사용하여 데이터 검색
비용
이 튜토리얼에서는 청구 가능한Google Cloud구성요소인 Spanner를 사용합니다. Spanner 사용 비용에 대한 자세한 내용은 가격 책정을 참조하세요.
시작하기 전에
설정에 설명된 단계를 완료합니다. 기본 Google Cloud 프로젝트 만들기 및 설정, 결제 사용 설정, Cloud Spanner API 사용 설정, Cloud Spanner API 사용에 필요한 사용자 인증 정보를 가져오도록 OAuth 2.0 설정을 다룹니다.
특히 gcloud auth
application-default login을 실행하여 사용자 인증 정보로 로컬 개발 환경을 설정해야 합니다.
로컬 ADO.NET 환경 준비
개발 머신에 아직 .NET이 설치되어 있지 않다면 .NET을 다운로드하여 설치합니다.
샘플 저장소를 로컬 머신에 클론합니다.
git clone https://github.com/googleapis/dotnet-spanner-entity-framework.gitSpanner ADO.NET 드라이버 샘플 코드가 있는 디렉터리로 변경합니다.
cd dotnet-spanner-entity-framework/spanner-ado-net/spanner-ado-net-getting-started-guide
인스턴스 만들기
Spanner를 처음 사용할 때는 인스턴스를 만들어야 합니다. 이 인스턴스는 Spanner 데이터베이스에서 사용하는 리소스를 할당한 것입니다. 인스턴스를 만들 때는 인스턴스 구성을 선택합니다. 이 구성에 따라 데이터 저장 위치와 사용할 노드 수가 결정되고, 또한 노드 수에 따라 인스턴스의 제공 리소스 및 스토리지 리소스 양이 결정됩니다.
다음 방법 중 하나를 사용하여 Spanner 인스턴스를 만드는 방법은 인스턴스 만들기를 참조하세요. 인스턴스 이름을 test-instance로 지정하여 test-instance 인스턴스를 참조하는 이 문서의 다른 주제에서 사용할 수 있습니다.
- Google Cloud CLI
- Google Cloud 콘솔
- 클라이언트 라이브러리(C++, C#, Go, Java, Node.js, PHP, Python 또는 Ruby)
샘플 파일 살펴보기
샘플 저장소에는 ADO.NET과 함께 Spanner를 사용하는 방법을 보여주는 샘플이 있습니다.
Spanner 사용 방법을 보여주는SampleRunner.cs 파일을 살펴보세요. 코드는 새 데이터베이스를 만들고 사용하는 방법을 보여줍니다. 데이터는 스키마 및 데이터 모델 페이지에 나와 있는 스키마 예시를 사용합니다.
데이터베이스 만들기
GoogleSQL
gcloud spanner databases create example-db --instance=test-instance
PostgreSQL
gcloud spanner databases create example-db --instance=test-instance \
--database-dialect=POSTGRESQL
다음과 같이 표시됩니다.
Creating database...done.
테이블 만들기
다음 코드에서는 데이터베이스에 테이블 2개를 만듭니다.
GoogleSQL
PostgreSQL
다음 명령어로 샘플을 실행합니다.
GoogleSQL
dotnet run createtables projects/PROJECT_ID/instances/test-instance/databases/example-db
PostgreSQL
dotnet run createtablespg projects/PROJECT_ID/instances/test-instance/databases/example-db
다음 단계는 데이터베이스에 데이터 쓰기입니다.
연결 만들기
읽기 또는 쓰기를 수행하려면 먼저 Spanner와 상호작용할 연결을 만들어야 합니다. 데이터베이스 이름 및 기타 연결 속성은 ADO.NET 연결 문자열에 지정됩니다.GoogleSQL
PostgreSQL
DML을 사용하여 데이터 쓰기
읽기-쓰기 트랜잭션에서 DML(Data Manipulation Language)을 사용하여 데이터를 삽입할 수 있습니다.
DbCommand#ExecuteNonQuery 메서드를 사용하여 DML 문을 실행합니다.
GoogleSQL
PostgreSQL
다음 명령어로 샘플을 실행합니다.
GoogleSQL
dotnet run dmlwrite projects/PROJECT_ID/instances/test-instance/databases/example-db
PostgreSQL
dotnet run dmlwritepg projects/PROJECT_ID/instances/test-instance/databases/example-db
결과는 다음과 같이 표시됩니다.
4 records inserted.
변형을 사용하여 데이터 쓰기
변형을 사용하여 데이터를 삽입할 수도 있습니다.
batch.CreateInsertCommand() 메서드를 사용하여 데이터를 삽입할 수 있습니다. 이 메서드는 테이블에 행을 삽입하는 새 SpannerBatchCommand를 만듭니다.
SpannerBatchCommand.ExecuteNonQueryAsync() 메서드는 테이블에 새 행을 추가합니다.
다음 코드는 변형을 사용하여 데이터를 쓰는 방법을 보여줍니다.
GoogleSQL
PostgreSQL
write 인수를 사용하여 다음 예시를 실행합니다.
GoogleSQL
dotnet run write projects/PROJECT_ID/instances/test-instance/databases/example-db
PostgreSQL
dotnet run writepg projects/PROJECT_ID/instances/test-instance/databases/example-db
SQL을 사용하여 데이터 쿼리
Spanner는 데이터 읽기용 SQL 인터페이스를 지원하며, 개발자는 Google Cloud CLI를 사용하여 명령줄에서 액세스하거나 Spanner ADO.NET 드라이버를 사용하여 프로그래매틱 방식으로 액세스할 수 있습니다.
명령줄에서
다음 SQL 문을 실행하여 Albums 테이블에서 모든 열의 값을 읽습니다.
GoogleSQL
gcloud spanner databases execute-sql example-db --instance=test-instance \
--sql='SELECT SingerId, AlbumId, AlbumTitle FROM Albums'
PostgreSQL
gcloud spanner databases execute-sql example-db --instance=test-instance \
--sql='SELECT singer_id, album_id, album_title FROM albums'
결과는 다음과 같습니다.
SingerId AlbumId AlbumTitle
1 1 Total Junk
1 2 Go, Go, Go
2 1 Green
2 2 Forever Hold Your Peace
2 3 Terrified
Spanner ADO.NET 드라이버 사용
명령줄에서 SQL 문을 실행하는 것 외에도 Spanner ADO.NET 드라이버를 사용하여 동일한 SQL 문을 프로그래매틱 방식으로 실행할 수 있습니다.
다음 메서드는 SQL 쿼리를 실행하는 데 사용됩니다.DbCommand클래스의ExecuteReader메서드: 쿼리 또는THEN RETURN절이 있는 DML 문과 같이 행을 반환하는 SQL 문을 실행하는 데 사용합니다.DbDataReader클래스: SQL 문으로 반환된 데이터에 액세스하려면 사용합니다.
다음 예시에서는 ExecuteReaderAsync 메서드를 사용합니다.
GoogleSQL
PostgreSQL
다음 명령어를 사용하여 예시를 실행합니다.
GoogleSQL
dotnet run query projects/PROJECT_ID/instances/test-instance/databases/example-db
PostgreSQL
dotnet run querypg projects/PROJECT_ID/instances/test-instance/databases/example-db
결과는 다음과 같이 표시됩니다.
1 1 Total Junk
1 2 Go, Go, Go
2 1 Green
2 2 Forever Hold Your Peace
2 3 Terrified
SQL 매개변수를 사용하여 쿼리
애플리케이션에 자주 실행되는 쿼리가 있는 경우 이를 매개변수화하여 성능을 개선할 수 있습니다. 매개변수화된 결과 쿼리를 캐시하고 다시 사용할 수 있으므로 컴파일 비용이 절감됩니다. 자세한 내용은 쿼리 매개변수를 사용하여 자주 실행되는 쿼리 속도 향상을 참조하세요.
다음은 WHERE 절에서 매개변수를 사용하여 LastName의 특정 값을 포함하는 레코드를 쿼리하는 예입니다.
Spanner ADO.NET 드라이버는 위치 쿼리 파라미터와 이름 지정 쿼리 파라미터를 모두 지원합니다. SQL 문의 ?는 위치 쿼리 파라미터를 나타냅니다. DbCommand의 Parameters에 쿼리 매개변수 값을 추가합니다. 예를 들면 다음과 같습니다.
GoogleSQL
PostgreSQL
다음 명령어를 사용하여 예시를 실행합니다.
GoogleSQL
dotnet run querywithparameter projects/PROJECT_ID/instances/test-instance/databases/example-db
PostgreSQL
dotnet run querywithparameterpg projects/PROJECT_ID/instances/test-instance/databases/example-db
결과는 다음과 같습니다.
12 Melissa Garcia
데이터베이스 스키마 업데이트
Albums 테이블에 MarketingBudget이라는 새 열을 추가해야 한다고 가정합니다. 기존 테이블에 새 열을 추가하려면 데이터베이스 스키마를 업데이트해야 합니다. Spanner는 데이터베이스에서 트래픽이 계속 처리되는 동안 데이터베이스의 스키마 업데이트를 지원합니다. 스키마 업데이트 시 데이터베이스를 오프라인으로 전환할 필요가 없고 전체 테이블 또는 열을 잠그지 않습니다. 스키마 업데이트 중에도 데이터베이스에 계속 데이터를 쓸 수 있습니다. 스키마 업데이트에서 지원되는 스키마 업데이트와 스키마 변경 성능에 대해 자세히 알아보세요.
열 추가
Google Cloud CLI를 사용하여 명령줄에서 열을 추가하거나 Spanner ADO.NET 드라이버를 사용해서 프로그래매틱 방식으로 열을 추가할 수 있습니다.
명령줄에서
다음과 같은 ALTER TABLE 명령어를 사용하여 테이블에 새 열을 추가합니다.
GoogleSQL
gcloud spanner databases ddl update example-db --instance=test-instance \
--ddl='ALTER TABLE Albums ADD COLUMN MarketingBudget INT64'
PostgreSQL
gcloud spanner databases ddl update example-db --instance=test-instance \
--ddl='alter table albums add column marketing_budget bigint'
다음과 같이 표시됩니다.
Schema updating...done.
Spanner ADO.NET 드라이버 사용
ExecuteNonQueryAsync 메서드를 사용하여 스키마를 수정합니다.
GoogleSQL
PostgreSQL
다음 명령어를 사용하여 예시를 실행합니다.
GoogleSQL
dotnet run addcolumn projects/PROJECT_ID/instances/test-instance/databases/example-db
PostgreSQL
dotnet run addcolumnpg projects/PROJECT_ID/instances/test-instance/databases/example-db
결과는 다음과 같습니다.
Added MarketingBudget column.
DDL 일괄 실행
여러 스키마 수정을 일괄 실행하는 것이 좋습니다. ADO.NET CreateBatch 메서드를 사용하여 일괄 처리를 만듭니다. 다음 예시에서는 한 번에 두 개의 테이블을 만듭니다.
GoogleSQL
PostgreSQL
다음 명령어를 사용하여 예시를 실행합니다.
GoogleSQL
dotnet run ddlbatch projects/PROJECT_ID/instances/test-instance/databases/example-db
PostgreSQL
dotnet run ddlbatchpg projects/PROJECT_ID/instances/test-instance/databases/example-db
결과는 다음과 같습니다.
Added Venues and Concerts tables.
새 열에 데이터 쓰기
다음 코드는 새 열에 데이터를 씁니다. 이 코드는 MarketingBudget을 Albums(1, 1)로 키가 지정된 행에서는 100000으로, Albums(2, 2)로 키가 지정된 행에서는 500000으로 설정합니다.
GoogleSQL
PostgreSQL
다음 명령어를 사용하여 예시를 실행합니다.
GoogleSQL
dotnet run update projects/PROJECT_ID/instances/test-instance/databases/example-db
PostgreSQL
dotnet run updatepg projects/PROJECT_ID/instances/test-instance/databases/example-db
결과는 다음과 같습니다.
Updated 2 albums
방금 쓴 값을 가져오기 위해 SQL 쿼리를 실행할 수도 있습니다.
다음 예시에서는 ExecuteReaderAsync 메서드를 사용하여 쿼리를 실행합니다.
GoogleSQL
PostgreSQL
이 쿼리를 실행하려면 다음 명령어를 실행합니다.
GoogleSQL
dotnet run querymarketingbudget projects/PROJECT_ID/instances/test-instance/databases/example-db
PostgreSQL
dotnet run querymarketingbudgetpg projects/PROJECT_ID/instances/test-instance/databases/example-db
다음과 같이 표시됩니다.
1 1 100000
1 2 null
2 1 null
2 2 500000
2 3 null
데이터 업데이트
읽기-쓰기 트랜잭션에서 DML을 사용하여 데이터를 업데이트할 수 있습니다.
ADO.NET에서 읽기-쓰기 트랜잭션을 실행하려면 connection.BeginTransactionAsync()를 호출합니다.
GoogleSQL
PostgreSQL
다음 명령어를 사용하여 예시를 실행합니다.
GoogleSQL
dotnet run writewithtransactionusingdml projects/PROJECT_ID/instances/test-instance/databases/example-db
PostgreSQL
dotnet run writewithtransactionusingdmlpg projects/PROJECT_ID/instances/test-instance/databases/example-db
트랜잭션 태그 및 요청 태그
트랜잭션 태그 및 요청 태그를 사용하여 Spanner에서 트랜잭션 및 쿼리를 문제 해결할 수 있습니다. 트랜잭션 태그를 전송하려면 트랜잭션 객체에 태그를 설정하고 요청 태그를 Spanner에 전송하려면 DbCommand 객체에 태그를 설정하면 됩니다. 예를 들면 다음과 같습니다.
GoogleSQL
PostgreSQL
다음 명령어를 사용하여 예시를 실행합니다.
GoogleSQL
dotnet run tags projects/PROJECT_ID/instances/test-instance/databases/example-db
PostgreSQL
dotnet run tagspg projects/PROJECT_ID/instances/test-instance/databases/example-db
읽기 전용 트랜잭션을 사용하여 데이터 검색
같은 타임스탬프에서 읽기를 하나 이상 실행한다고 가정해 봅시다. 읽기 전용 트랜잭션은 트랜잭션 커밋 기록의 일관된 프리픽스를 관찰하므로 애플리케이션이 항상 일관된 데이터를 가져옵니다.
connection.BeginReadOnlyTransactionAsync()을 호출하여 읽기 전용 트랜잭션을 실행합니다.
다음은 같은 읽기 전용 트랜잭션에서 쿼리를 실행하고 읽기를 수행하는 방법을 보여줍니다.
GoogleSQL
PostgreSQL
다음 명령어를 사용하여 예시를 실행합니다.
GoogleSQL
dotnet run readonlytransaction projects/PROJECT_ID/instances/test-instance/databases/example-db
PostgreSQL
dotnet run readonlytransactionpg projects/PROJECT_ID/instances/test-instance/databases/example-db
결과는 다음과 같습니다.
1 1 Total Junk
1 2 Go, Go, Go
2 1 Green
2 2 Forever Hold Your Peace
2 3 Terrified
2 2 Forever Hold Your Peace
1 2 Go, Go, Go
2 1 Green
2 3 Terrified
1 1 Total Junk
Partitioned DML
Partitioned DML은 다음과 같은 유형의 일괄 업데이트와 삭제를 위해 설계되었습니다.
- 정기적 클린업 및 가비지 컬렉션:
- 새 열을 기본값으로 백필:
GoogleSQL
PostgreSQL
다음 명령어를 사용하여 예시를 실행합니다.
GoogleSQL
dotnet run pdml projects/PROJECT_ID/instances/test-instance/databases/example-db
PostgreSQL
dotnet run pdmlpg projects/PROJECT_ID/instances/test-instance/databases/example-db
삭제
이 튜토리얼에서 사용한 리소스에 대한 추가 비용이 Cloud Billing 계정에 청구되지 않도록 하려면 데이터베이스와 새로 만든 인스턴스를 삭제합니다.
데이터베이스 삭제
인스턴스를 삭제하면 인스턴스 내의 모든 데이터베이스가 자동으로 삭제됩니다. 다음 단계는 인스턴스를 삭제하지 않고 데이터베이스를 삭제하는 방법을 보여줍니다. 인스턴스에 대한 비용은 여전히 발생합니다.
명령줄에서
gcloud spanner databases delete example-db --instance=test-instance
Google Cloud 콘솔 사용
Google Cloud 콘솔에서 Spanner 인스턴스 페이지로 이동합니다.
인스턴스를 클릭합니다.
삭제할 데이터베이스를 클릭합니다.
데이터베이스 세부정보 페이지에서 삭제를 클릭합니다.
데이터베이스 삭제 여부를 확인하고 삭제를 클릭합니다.
인스턴스 삭제
인스턴스를 삭제하면 해당 인스턴스에서 만든 모든 데이터베이스가 자동으로 삭제됩니다.
명령줄에서
gcloud spanner instances delete test-instance
Google Cloud 콘솔 사용
Google Cloud 콘솔에서 Spanner 인스턴스 페이지로 이동합니다.
인스턴스를 클릭합니다.
삭제를 클릭합니다.
인스턴스 삭제 여부를 확인하고 삭제를 클릭합니다.
다음 단계
가상 머신 인스턴스에서 Spanner에 액세스하는 방법을 알아봅니다.
클라이언트 라이브러리를 사용하여 Cloud 서비스에 인증에서 사용자 인증 정보의 승인 및 인증에 대해 알아봅니다.
Spanner 스키마 설계 권장사항에 대해 자세히 알아봅니다.