質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

88.77%

PowershellでAzureTableStorageのEntityを削除したい

解決済

回答 2

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 2,347

Takayukky

score 10

log4netでAzureログをAzureStorageのWADLogsTableに吐き出しております。
私は古いログ(Entity)を削除したく、以下のスクリプトを作成し実行しました。
ところがエラーが発生しエンティティを削除できませんでした。

# 指定したAzureサブスクリプションを選択
Select-AzureSubscription -SubscriptionName $SubscriptionName

Get-AzureSubscription

# ストレージアカウントへの接続コンテキスト生成
$context = New-AzureStorageContext -StorageAccountName $storageAccountName -StorageAccountKey $storageAccessKey
# テーブル名
$tableName = "WADLogsTable"

$table = Get-AzureStorageTable –Name $tableName -Context $context

# TimeStampを使用してフィルターする
$query = New-Object Microsoft.WindowsAzure.Storage.Table.TableQuery

# フィルター設定
$query.FilterString = "Timestamp le datetime'2016-07-17T15:00:00'"

# フィルター結果
$entities = $table.CloudTable.ExecuteQuery($query)
if ($entities -ne $null){

    Write-Output "START DELETE..."
    # フィルターして取得したエンティティを削除
    $table.CloudTable.Execute([Microsoft.WindowsAzure.Storage.Table.TableOperation]::Delete($entities))
    Write-Output "COMPLETED DELETE"
}else{
    Write-Output "Retrieved Entity is empty"
}

どうやらエラーの原因は、

$table.CloudTable.Execute([Microsoft.WindowsAzure.Storage.Table.TableOperation]::Delete($entities))


Delete()の引数の型がDynamicTableEntityになっていることでした。
Delete()の引数の型はITableEntityでなくてはいけないのですが、
今回のようにクエリでエンティティを絞り込み、その結果を削除したい場合は
どのようにすればいいのでしょうか?

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 2

check解決した方法

0

自己解決しました。

初期の意向とは異なってしまいますが、
不慣れなPowershellよりは慣れているC#でプログラムを作成することにしました。
(目的はテーブル内のエンティティを削除することでしたので...)

下記コードは、AzureのTableStorage内のエンティティをTimestampで絞り込み
その結果得られたエンティティを削除するものです。
10万を超すエンティティを全て削除するには多くの時間が掛かってしまいますが、
Azure Storage Explorerで地道に削除するよりは効率がいいです。

※ほとんどMicrosoftのDocumentationに載っているコードを参考にしました。
https://azure.microsoft.com/ja-jp/documentation/articles/storage-dotnet-how-to-use-tables/

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

using Microsoft.Azure; // Namespace for CloudConfigurationManager 
using Microsoft.WindowsAzure.Storage; // Namespace for CloudStorageAccount
using Microsoft.WindowsAzure.Storage.Table; // Namespace for Table storage types

namespace ConsoleApplication2
{
    class Program
    {
        static void Main(string[] args)
        {

            // Parse the connection string and return a reference to the storage account.
            CloudStorageAccount storageAccount = CloudStorageAccount.Parse(
                CloudConfigurationManager.GetSetting("StorageConnectionString"));

            // Create the table client.
            CloudTableClient tableClient = storageAccount.CreateCloudTableClient();

            // Create the CloudTable object that represents the target table.
            CloudTable table = tableClient.GetTableReference("TargetTable"); //引数:テーブル名

            // TableQuery オブジェクトを使用しクエリを生成
            TableQuery<TableEntity> query = new TableQuery<TableEntity>()
                                            .Where(TableQuery.GenerateFilterConditionForDate
                                            (
                                                "Timestamp", //絞り込み対象のカラム名
                                                QueryComparisons.LessThan,
                                                DateTime.Parse("yyyy-MM-dd")
                                            ));

            // Print the fields for each customer.
            foreach (TableEntity entity in table.ExecuteQuery(query))
            {
                Console.WriteLine("{0}, {1}\t{2}", entity.PartitionKey, entity.RowKey, entity.Timestamp);

                TableOperation deleteOperation = TableOperation.Delete(entity);

                // Execute the operation.
                table.Execute(deleteOperation);

                Console.WriteLine("Entity deleted.");
            }

        }
    }
}

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

0

4年前の質問であり、既にC++での代替をされてるとのことでしたが、Powershellで実装したサンプルをQiitaの記事に投稿しました。
Table Storageに溜まり続けるWindowsイベントログのクリーニング

実装にあたり、こちらの質問に記載されているコードがとても参考になったので、この場で御礼をさせていただきます。ありがとうございました。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 88.77%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る