Skip to content

Instantly share code, notes, and snippets.

@syossan27
Created September 11, 2020 12:23
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save syossan27/4c09f5d188531dbea0f1c7d2b6d09215 to your computer and use it in GitHub Desktop.
Save syossan27/4c09f5d188531dbea0f1c7d2b6d09215 to your computer and use it in GitHub Desktop.
Spannerのテーブルから全レコード削除する君
func deleteAllRows(ctx context.Context, db *spanner.Client, tableName string, primaryKeyName string) {
var primaryKeys []string
stmt := spanner.Statement{SQL: `SELECT ` + primaryKeyName + ` FROM ` + tableName}
iter := db.Single().Query(ctx, stmt)
defer iter.Stop()
for {
row, err := iter.Next()
if err == iterator.Done {
break
}
if err != nil {
panic(err)
}
var primaryKey string
if err := row.Columns(&primaryKey); err != nil {
panic(err)
}
primaryKeys = append(primaryKeys, primaryKey)
}
var deleteKeys []string
for i, key := range primaryKeys {
deleteKeys = append(deleteKeys, key)
if i%1000 == 0 {
if _, err := db.ReadWriteTransaction(
ctx,
func(ctx context.Context, txn *spanner.ReadWriteTransaction) error {
stmt := spanner.Statement{SQL: `DELETE FROM ` + tableName + ` WHERE ` + primaryKeyName + ` IN UNNEST (@param)`,
Params: map[string]interface{}{"param": deleteKeys},
}
_, err := txn.Update(ctx, stmt)
return err
},
); err != nil {
panic(err)
}
deleteKeys = []string{}
}
}
if len(deleteKeys) != 0 {
if _, err := db.ReadWriteTransaction(
ctx,
func(ctx context.Context, txn *spanner.ReadWriteTransaction) error {
stmt := spanner.Statement{SQL: `DELETE ` + tableName + ` WHERE ` + primaryKeyName + ` IN UNNEST (@param)`,
Params: map[string]interface{}{"param": deleteKeys},
}
_, err := txn.Update(ctx, stmt)
return err
},
); err != nil {
panic(err)
}
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment