當前位置: 首頁>>代碼示例>>C#>>正文


C# CloudTable.ExecuteQuery方法代碼示例

本文整理匯總了C#中Microsoft.WindowsAzure.Storage.Table.CloudTable.ExecuteQuery方法的典型用法代碼示例。如果您正苦於以下問題:C# CloudTable.ExecuteQuery方法的具體用法?C# CloudTable.ExecuteQuery怎麽用?C# CloudTable.ExecuteQuery使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Microsoft.WindowsAzure.Storage.Table.CloudTable的用法示例。


在下文中一共展示了CloudTable.ExecuteQuery方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: Search

        private static void Search(CloudTable table)
        {
            TableQuery<TableChat> query =
                new TableQuery<TableChat>().Where(TableQuery.GenerateFilterCondition("user",
                    QueryComparisons.Equal, "Tzkwizard"));

            // Print the fields for each customer.
            foreach (TableChat entity in table.ExecuteQuery(query))
            {
                Console.WriteLine("{0}, {1} {2} {3} {4}", entity.PartitionKey, entity.RowKey,
                    entity.roomName, entity.uid, entity.message);
            }
        }
開發者ID:tzkwizard,項目名稱:ELS,代碼行數:13,代碼來源:ChatBackup.cs

示例2: RetrieveSessions

        private static void RetrieveSessions(CloudTable table)
        {
            var startsAt = new DateTime(2016, 10, 4, 12, 0, 0);
            // Construct the query operation for all sessions for the first day of the TechDays event.
            TableQuery<Session> query = new TableQuery<Session>()
                .Where(TableQuery.GenerateFilterCondition("PartitionKey", QueryComparisons.Equal, startsAt.Date.ToString("s")));

            // Print the fields for each session.
            foreach (Session entity in table.ExecuteQuery(query))
            {
                Console.WriteLine($"Day: {entity.PartitionKey}, ID:{entity.RowKey}\tName:{entity.Name}\tDescription{entity.Description}");
            }
        }
開發者ID:XpiritBV,項目名稱:mini-hacks,代碼行數:13,代碼來源:Program.cs

示例3: DashboardUpdate

        public DashboardUpdate(CloudTable generalInfoTable, CloudTable pageTable, CloudTable errorTable, CloudTable mappingTable, CloudQueue urlQ)
        {
            this.dashboardTable = generalInfoTable;
            this.pageTable = pageTable;
            this.errorTable = errorTable;
            this.mappingTable = mappingTable;
            this.urlQ = urlQ;

            IEnumerator<Dashboard> results = generalInfoTable.ExecuteQuery(new TableQuery<Dashboard>()).GetEnumerator();
            if (!results.MoveNext())
            {
                generalInfoTable.Execute(TableOperation.InsertOrReplace(new Dashboard(0, 0, 0, new List<string>(), new List<string>())));
            }
        }
開發者ID:kxchiu,項目名稱:INFO344,代碼行數:14,代碼來源:[PA+4]+DashboardUpdate.cs

示例4: GetLogs

        private static string GetLogs(CloudTable table)
        {
            var query = new TableQuery<LogEntity>()
                .Where(TableQuery.GenerateFilterConditionForDate("Timestamp", QueryComparisons.GreaterThan, _lastQuery));

            var sb = new StringBuilder();
            foreach (LogEntity entry in table.ExecuteQuery(query))
            {
                sb.Append(entry.Message)
                    .Append(", ")
                    .Append(entry.Timestamp)
                    .AppendLine();
                _lastQuery = entry.Timestamp;
            }

            return sb.ToString();
        }
開發者ID:kunzimariano,項目名稱:SumoLogic.Sample,代碼行數:17,代碼來源:Program.cs

示例5: searchMainTableOCR

        public void searchMainTableOCR(CloudTable mainbl, ref List<TableKeys> results, string keyword)
        {

            int rank = 1;

            var sortedList = from p in results
                             orderby p.Counter descending
                             select p;
            //sortedList.ToList().ForEach(p => Console.WriteLine(p.Counter));

            Console.WriteLine("");

            foreach (var v in sortedList)
            {
                

                string finalPK = TableQuery.GenerateFilterCondition("PartitionKey", QueryComparisons.Equal, v.PartitionKey);
                string finalRK = TableQuery.GenerateFilterCondition("RowKey", QueryComparisons.Equal, v.RowKey);

                TableQuery<BookEntity> finalquery = new TableQuery<BookEntity>().Where(TableQuery.CombineFilters(finalPK, TableOperators.And, finalRK));

                var finallist = mainbl.ExecuteQuery(finalquery).ToList();

                foreach (var vv in finallist)
                {
                    Console.WriteLine("{0} {1}", rank, vv.title);
                    Console.WriteLine("by {0} ", vv.publisher);
                    Console.WriteLine(vv.place);
                    Console.WriteLine("The Keyword '{0}' was found {1} times", keyword, v.Counter);
                    Console.WriteLine();
                    rank += 1;
                }

            }

        }
開發者ID:BL-publicdomain,項目名稱:blpublicdomain,代碼行數:36,代碼來源:AzureStorageController.cs

示例6: queryForPlaceSimple

        public void queryForPlaceSimple(CloudTable placebl, ref List<TableKeys> results, string keyword)
        {

            //split user-query into array
            string[] words = keyword.Split();
            int counterOfKeyword = words.Count();



            TableQuery<PlaceEntity> queryPlaces =
       new TableQuery<PlaceEntity>()
          .Where(TableQuery.GenerateFilterCondition("PartitionKey",
              QueryComparisons.GreaterThanOrEqual, " "));

            var listOfPlaces = placebl.ExecuteQuery(queryPlaces).ToList();


            //Console.WriteLine("Lista {0}", listOfPlaces.Count());



            foreach (var v in listOfPlaces)
            {
                //Console.WriteLine("the partition key is {0}", v.newPartitionKey);


                foreach (string word in words)
                {

                    int wordAdded = 0;
                    int itemExist = 0;

                    string tem = (v.PartitionKey.ToString()).ToLower();




                    if (tem.Equals(keyword))
                    {
                        itemExist = 0;
                        // Console.WriteLine("The list contains {0} ",results.Count());

                        for (int i = 0; i < results.Count(); i++)
                        {
                            if (results[i].RowKey.Equals(v.RowKey))
                            {
                                //Console.WriteLine("The item already exists");
                                itemExist = 1;
                            }
                        }

                        if (itemExist == 0)
                        {
                            results.Add(new TableKeys() { PartitionKey = v.newPartitionKey, RowKey = v.RowKey, Counter = counterOfKeyword });
                            //Console.WriteLine("Insert of item");
                        }

                    }

                }

            }

        }
開發者ID:BL-publicdomain,項目名稱:blpublicdomain,代碼行數:64,代碼來源:AzureStorageController.cs

示例7: queryForOCR1

        public void queryForOCR1(CloudTable placebl, ref List<TableKeys> results, string keyword)
        {
            char[] delimiters = new char[] { '\r', '\n', ' ', ',', '.', '<', '>', '?', '.', '!', '[', ']', '{', '}', '"' };


            //frequency of word in OCR
            int counterOCR = 0;




            TableQuery<BookEntity> queryPlaces =
       new TableQuery<BookEntity>()
          .Where(TableQuery.GenerateFilterCondition("PartitionKey",
              QueryComparisons.GreaterThanOrEqual, " ")).Take(10);

            var listOfPlaces = placebl.ExecuteQuery(queryPlaces).ToList();

            //Console.WriteLine("{0}",listOfPlaces.Count());


            string ocr = "";
            int itemExist = 0;

            foreach (var v in listOfPlaces)
            {


                ocr = v.ocrtext;
                //Console.WriteLine("{0}", ocr);
                itemExist = 0;


                if (ocr != "")
                {


                    //Console.WriteLine("Found");






                    frequentWordInOCR(ocr, keyword, out counterOCR);
                    if (counterOCR != 0)
                    {

                        for (int i = 0; i < results.Count(); i++)
                        {
                            //Console.Write("{0} ", results[i].RowKey);
                            //Console.WriteLine("{0} ", v.RowKey);

                            string finalPK = TableQuery.GenerateFilterCondition("PartitionKey", QueryComparisons.Equal, results[i].PartitionKey);
                            string finalRK = TableQuery.GenerateFilterCondition("RowKey", QueryComparisons.Equal, results[i].RowKey);

                            TableQuery<BookEntity> finalquery = new TableQuery<BookEntity>().Where(TableQuery.CombineFilters(finalPK, TableOperators.And, finalRK));

                            var finallist = placebl.ExecuteQuery(finalquery).ToList();

                            foreach (var vv in finallist)
                            {

                                bool resultEqual = vv.ocrtext.Equals(v.ocrtext);

                                if (resultEqual)
                                {

                                    //Console.WriteLine("The item already exists");
                                    itemExist = 1;
                                }

                            }

                        }

                    }


                    if (itemExist == 0 && counterOCR != 0)
                    {
                        results.Add(new TableKeys() { PartitionKey = v.PartitionKey, RowKey = v.RowKey, Counter = counterOCR });
                        //Console.WriteLine("Insert of item");
                    }

                }

            }

        }
開發者ID:BL-publicdomain,項目名稱:blpublicdomain,代碼行數:90,代碼來源:AzureStorageController.cs

示例8: searchMainTable

        public void searchMainTable(CloudTable mainbl, ref List<TableKeys> results, string keyword)
        {


            int rank = 1;

            // string[] words = keyword.Split();


            char[] delimiters = new char[] { '\r', '\n', ' ', ',', '.', '<', '>', '?', '.', '!', '[', ']', '{', '}' };
            string[] words = keyword.Split(delimiters, StringSplitOptions.RemoveEmptyEntries);



            int counterOfKeyword = words.Count();

            Console.WriteLine();

            for (int i = counterOfKeyword; i > 0; i--)
            {
                string finalPK = "";
                string finalRK = "";
                foreach (TableKeys entry in results)
                {


                    if (entry.Counter == i)
                    {


                        finalPK = TableQuery.GenerateFilterCondition("PartitionKey", QueryComparisons.Equal, entry.PartitionKey);
                        finalRK = TableQuery.GenerateFilterCondition("RowKey", QueryComparisons.Equal, entry.RowKey);

                        TableQuery<BookEntity> finalquery = new TableQuery<BookEntity>().Where(TableQuery.CombineFilters(finalPK, TableOperators.And, finalRK));

                        var finallist = mainbl.ExecuteQuery(finalquery).ToList();

                        //Console.WriteLine("The result in the main {0}", finallist.Count());

                        foreach (var vv in finallist)
                        {
                            Console.WriteLine("{0} {1}", rank, vv.title);
                            Console.WriteLine("by {0} ", vv.publisher);
                            Console.WriteLine(vv.place);
                            Console.WriteLine();
                            rank += 1;


                            //Console.WriteLine("The publisher is {0}", vv.publisher);
                        }

                    }

                }

            }


            Console.WriteLine("Total Results Found {0}", rank - 1);

        }
開發者ID:BL-publicdomain,項目名稱:blpublicdomain,代碼行數:61,代碼來源:AzureStorageController.cs

示例9: __fetchScheduledItems

        private ScheduledTask[] __fetchScheduledItems(CloudTable scheduleTable, string channel, int retryCount)
        {
            /* ------------------------------------
            * Make Range Query to fetch tasks with scheduled time elapsed.
             * The reason we retrieve 50 items is that each row will be followed by two table operations each, which makes a total of 100 operations (Maximum handled by a BatchTableOperation)
            *-------------------------------------
            */

            const int count = 50;

            TableQuery<DynamicTableEntity> rangeQuery = new TableQuery<DynamicTableEntity>().Where(
                TableQuery.CombineFilters(
                    TableQuery.GenerateFilterCondition("PartitionKey", QueryComparisons.Equal, channel),
                    TableOperators.And,
                    TableQuery.GenerateFilterCondition("RowKey", QueryComparisons.LessThan, DateTime.Now.ToUniversalTime().ToString("yyyyMMddHHmmssffff"))))
                   .Take(count);

            var results = scheduleTable.ExecuteQuery(rangeQuery).Take(count).ToArray();

            if (results.Length == 0)
                return new ScheduledTask[0];

            /* ------------------------------------
             * For every ScheduleEntry retrieved, they must be deleted right away for concurency reason.
             * They are also 'postponed' at the specifyed time span in order to be fired again in case the task never completes.
             *-------------------------------------
             */

            TableBatchOperation tb = new TableBatchOperation();

            List<ScheduledTask> _items = new List<ScheduledTask>();

            foreach (var x in results)
            {
                int delimiter = x.RowKey.IndexOf('-');
                string[] rowSpl = new string[] { x.RowKey.Substring(0, delimiter), x.RowKey.Substring(delimiter + 1) };

                string tempPostponed = DateTime.Now.ToUniversalTime().AddSeconds(POSTPONE_DELAY_FOR_UNCOMMITED_SECONDS).ToString("yyyyMMddHHmmssffff") + "-" + rowSpl[1];

                DynamicTableEntity ghost = new DynamicTableEntity(x.PartitionKey, tempPostponed);
                ghost.Properties = x.Properties;

                int tryCount = 0;
                if (ghost.Properties.ContainsKey("RetryCount"))
                {
                    tryCount = ghost.Properties["RetryCount"].Int32Value.Value;
                }

                ghost.Properties["RetryCount"] = new EntityProperty(tryCount + 1);

                //delete an postpone
                tb.Add(TableOperation.Delete(x));
                tb.Add(TableOperation.Insert(ghost));

                _items.Add(new ScheduledTask
                {
                    ScheduledTime = DateTime.ParseExact(rowSpl[0], "yyyyMMddHHmmssffff", System.Globalization.CultureInfo.InvariantCulture),
                    Channel = channel,
                    FailedTimes = tryCount,
                    Data = x["Data"].StringValue,
                    Id = rowSpl[1]
                });

            }

            /* ----------------------------------------------------------------------------------------------------------------------------------------
            * Now that the batch operation containing deletes and 'postpones' is built, we execute it.
             *
             * This BatchOperation is the 'trick' that handles concurency, as the Azure Table Storage is centralized somewhere as one authority,
             * if two batches are made at the same time on the same rows, one of them will fail, hence it should'nt be possible to dequeue twice
            *------------------------------------------------------------------------------------------------------------------------------------------
            */
            TableResult[] tableResults = null;
            try
            {
                tableResults = scheduleTable.ExecuteBatch(tb).Where(x => x.HttpStatusCode == 201).ToArray(); //select only 201 response to get only inserted items results
                for (int i = 0; i < _items.Count; i++)
                {
                    _items[i].temporaryTask = (DynamicTableEntity)tableResults[i].Result;
                }
            }
            catch (Exception ex)
            {

             /* ----------------------------------------------------------------------------------------------------------------------------------------
             * If an exception occurs while executing, it's most likely because another Fetch operation where made at the same time (which should have succeed),
             * so we try to execute the FetchScheduledItems operation again to get the next items.
             *
             * If the exception keeps occuring after several retry times, it's most likely a problem with the Azure Storage Account.
            *------------------------------------------------------------------------------------------------------------------------------------------
                */
                if (retryCount >= 5)
                    throw ex;

                return __fetchScheduledItems(scheduleTable, channel, ++retryCount);
            }

            return _items.ToArray();
        }
開發者ID:raizam,項目名稱:SimpleAzureScheduler,代碼行數:99,代碼來源:Scheduler.cs

示例10: queryForTitle1

        public void queryForTitle1(CloudTable placebl, ref List<TableKeys> results, string keyword)
        {
            char[] delimiters = new char[] { '\r', '\n', ' ', ',', '.', '<', '>', '?', '.', '!', '[', ']', '{', '}', '"' };


            ////split user-query into array
            //string[] words = keyword.Split();
            //int counterOfKeyword = words.Count();



            int counterOfKeyword = 0;
            //string[] words = keyword.Split();

            string[] words = keyword.Split(delimiters, StringSplitOptions.RemoveEmptyEntries);


            TableQuery<PlaceEntity> queryPlaces =
       new TableQuery<PlaceEntity>()
          .Where(TableQuery.GenerateFilterCondition("PartitionKey",
              QueryComparisons.GreaterThanOrEqual, " "));

            var listOfPlaces = placebl.ExecuteQuery(queryPlaces).ToList();


            //Console.WriteLine("{0}",listOfPlaces.Count());


            //Console.WriteLine("Lista {0}", listOfPlaces.Count());


            int counter = 0;



            foreach (var v in listOfPlaces)
            {
                //counter++;
                //Console.Write("{0}  ", counter);

                int itemExist = 0;
                counterOfKeyword = 0;


                foreach (string word in words)
                {

                    //Console.WriteLine("We examine the word {0}", word);


                    int wordAdded = 0;


                    //Console.WriteLine(text);
                    //char[] delimiters = new char[] { '\r', '\n', ' ', ',', '.', '<', '>', '?', '.', '!', '[', ']', '{', '}' , '"'};
                    //string[] words = line.Split(delimiters, StringSplitOptions.RemoveEmptyEntries);



                    string temp = (v.PartitionKey.ToString()).ToLower();
                    string[] temporarylist = temp.Split(delimiters, StringSplitOptions.RemoveEmptyEntries);

                    foreach (string tem in temporarylist)
                    {
                        //Console.Write("the partition key is {0}",tem);

                        if (tem.Equals(word))
                        {



                            counterOfKeyword++;
                            // itemExist = 0;
                            // Console.WriteLine("The list contains {0} ",results.Count());

                            for (int i = 0; i < results.Count(); i++)
                            {
                                if (results[i].RowKey.Equals(v.RowKey))
                                {
                                    //Console.WriteLine("The item already exists");
                                    itemExist = 1;
                                }
                            }
                        }

                    }

                }



                if (itemExist == 0)
                {
                    results.Add(new TableKeys() { PartitionKey = v.newPartitionKey, RowKey = v.RowKey, Counter = counterOfKeyword });
                    //Console.WriteLine("Insert of item");
                }

            }

        }
開發者ID:BL-publicdomain,項目名稱:blpublicdomain,代碼行數:100,代碼來源:AzureStorageController.cs

示例11: Data

    public ActionResult Data(string ModuleName, int takenum, string DateStart, string DateEnd) {

      table = common.AzureAccess();
      Malldata AllData = new Malldata();

      var loginuser = RDB.db.Users.Where(p => p.idName.Equals(User.Identity.Name)).Single();
      var module = loginuser.Modules.Where(p => p.Name.Equals(ModuleName)).Single();
      int id = module.id;
      var units = module.Units;

      // 削除中ならmoduleテーブルのTypeプロパティは"1"である(DataDeleteController參照)
      if (module.Type.Equals("1")) {
        AllData.ModuleName = ModuleName;
        AllData.Deleting = true;
        return View(AllData);
      } else {
        AllData.Deleting = false;
      }

      // データ數が0なら
      if (module.NumData == 0) {
        AllData.ModuleName = ModuleName;
        AllData.NumData = 0;
        return View(AllData);
      }

      // AllDataの中には、takenum件から20件のValueデータが入る
      TableQuery<DataEntity> query = GetQueryTakeNum(id, takenum, DateStart, DateEnd);
      AllData = GetData(query, units);

      //takenum件から20件のTakeデータを取得して、DataValプロパティが"BlobData"ならば、そのデータはBlobデータである。
      TableQuery<DataEntity> query1 = new TableQuery<DataEntity>().Where(
          TableQuery.CombineFilters(
          TableQuery.GenerateFilterCondition("PartitionKey", QueryComparisons.Equal, "Take," + id),
          TableOperators.And,
          TableQuery.CombineFilters(
          TableQuery.GenerateFilterCondition("RowKey", QueryComparisons.GreaterThanOrEqual, common.GetTimeIndex(DateStart)),
          TableOperators.And,
          TableQuery.GenerateFilterCondition("RowKey", QueryComparisons.LessThanOrEqual, common.GetTimeIndex(DateEnd))
          )
        )).Take(takenum);
      TableQuery<DataEntity> query2 = new TableQuery<DataEntity>().Where(
        TableQuery.CombineFilters(
        TableQuery.GenerateFilterCondition("PartitionKey", QueryComparisons.Equal, "Take," + id),
        TableOperators.And,
        TableQuery.GenerateFilterCondition("RowKey", QueryComparisons.GreaterThanOrEqual, table.ExecuteQuery(query1).LastOrDefault().RowKey)
      )).Take(20);
      AllData.FlagBlob = new List<bool>();
      foreach (var entity in table.ExecuteQuery(query2)) {
        if (entity.DataVal == null) {
          AllData.FlagBlob.Add(false);
        } else {
          if (entity.DataVal.Equals("BlobData")) {
            AllData.FlagBlob.Add(true);
          } else {
            AllData.FlagBlob.Add(false);
          }
        }
      }

      AllData.ModuleName = ModuleName;
      AllData.NumData = GetDataCount(id, DateStart, DateEnd);
      AllData.TakeNum = takenum;
      AllData.Id = id;
      AllData.DateStart = DateStart;
      AllData.DateEnd = DateEnd;



      return View(AllData);
    }
開發者ID:kazuki-mo,項目名稱:SmartHome-Cats,代碼行數:71,代碼來源:HomeController.cs

示例12: ExecuteQueryAndAssertResults

 private static void ExecuteQueryAndAssertResults(CloudTable table, string filter, int expectedResults)
 {
     Assert.AreEqual(expectedResults, table.ExecuteQuery(new TableQuery<ComplexEntity>().Where(filter)).Count());
 }
開發者ID:Gajendra-Bahakar,項目名稱:azure-storage-net,代碼行數:4,代碼來源:TableQueryGenericTests.cs

示例13: Post

    // Azure Tableのデータを取得
    // POST api/data/{UserID名}/{Module名}
    public alldata Post(string fir, string sec, [FromBody]DataQuery dataquery) {

      alldata AllData = new alldata();  // 取得したデータをここに格納

      // RDBの中から、ターゲットモジュールなどを検索
      try {
          var usertest = RDB.db.Users.Where(p => p.idName.Equals(fir)).Single();
      } catch {
          AllData.Type = new List<string>();
          AllData.Type.Add("User does not exist.");
          return AllData;
      }
      var user = RDB.db.Users.Where(p => p.idName.Equals(fir)).Single();
      try {
          var moduletest = user.Modules.Where(p => p.Name.Equals(sec)).Single();
      } catch {
          AllData.Type = new List<string>();
          AllData.Type.Add("Module does not exist.");
          return AllData;
      }
      var module = user.Modules.Where(p => p.Name.Equals(sec)).Single();
      var units = module.Units;

      // パスワードチェック
      if (common.PasswordError(dataquery.pw, module.rPassWord)) {
        AllData.Type = new List<string>();
        AllData.Type.Add("Password Error");
        return AllData;
      }

      table = common.AzureAccess(); // Azure Tableへアクセス

      TableQuery<DataEntity> query = new TableQuery<DataEntity>();

      if ((dataquery.since == null) && (dataquery.until == null)) { //範囲指定なし
        query = new TableQuery<DataEntity>().Where(
        TableQuery.CombineFilters(
        TableQuery.GenerateFilterCondition("PartitionKey", QueryComparisons.Equal, "Value," + module.id),
        TableOperators.And,
        TableQuery.GenerateFilterCondition("RowKey", QueryComparisons.GreaterThanOrEqual, common.GetTimeIndex(module.Latest))
        ));
      } else if (dataquery.since == null) { //~untilのデータ取得
        query = new TableQuery<DataEntity>().Where(
        TableQuery.CombineFilters(
        TableQuery.GenerateFilterCondition("PartitionKey", QueryComparisons.Equal, "Value," + module.id),
        TableOperators.And,
        TableQuery.GenerateFilterCondition("RowKey", QueryComparisons.GreaterThanOrEqual, common.GetTimeIndex(dataquery.until))
      ));
      } else if (dataquery.until == null) { //since~のデータ取得
        query = new TableQuery<DataEntity>().Where(
        TableQuery.CombineFilters(
        TableQuery.GenerateFilterCondition("PartitionKey", QueryComparisons.Equal, "Value," + module.id),
        TableOperators.And,
        TableQuery.GenerateFilterCondition("RowKey", QueryComparisons.LessThanOrEqual, common.GetTimeIndex(dataquery.since) + 1)
      ));
      } else { //since~untilのデータ取得
        query = new TableQuery<DataEntity>().Where(
        TableQuery.CombineFilters(
        TableQuery.GenerateFilterCondition("PartitionKey", QueryComparisons.Equal, "Value," + module.id),
        TableOperators.And,
        TableQuery.CombineFilters(
          TableQuery.GenerateFilterCondition("RowKey", QueryComparisons.LessThanOrEqual, common.GetTimeIndex(dataquery.since) + 1),
          TableOperators.And,
          TableQuery.GenerateFilterCondition("RowKey", QueryComparisons.GreaterThanOrEqual, common.GetTimeIndex(dataquery.until))
          )
      ));
      }

      List<DataEntity> BeforeDataList = new List<DataEntity>();
      List<DataEntity> AfterDataList = new List<DataEntity>();

      BeforeDataList = table.ExecuteQuery(query).ToList<DataEntity>();
      AfterDataList = table.ExecuteQuery(query).ToList<DataEntity>();

      //"asc"なら逆順にする
      if (dataquery.orderby.Equals("asc")) {
        int count = BeforeDataList.Count();
        int i = 1;
        foreach (var BeforeData in BeforeDataList) {
          AfterDataList[count - i] = BeforeData;
          i++;
        }
      }

      string[] Type;
      int[] TypeId;

      int num = 0;

      //unitlistの中には、ユーザが取得したいデータの列インデックスが格納されている
      if (dataquery.unitlist == null) {
        Type = new string[units.Count];
        TypeId = new int[units.Count];
        foreach (var unit in units) {
          Type[num] = unit.Unit1;
          TypeId[num] = unit.id;
          num++;
        }
//.........這裏部分代碼省略.........
開發者ID:kazuki-mo,項目名稱:SmartHome-Cats,代碼行數:101,代碼來源:dataController.cs

示例14: AssignOwner

 // Private methods
 private People AssignOwner(Question q, CloudTable table)
 {
     // Grab a random person from the list of people who match that category.
     TableQuery<People> query = new TableQuery<People>();
     var results = table
         .ExecuteQuery(query);
     if (results.Count() <= 0)
     {
         return null;
     }
     return results.ElementAt((new Random()).Next(0, results.Count()));
 }
開發者ID:christopheranderson,項目名稱:feedbackengine,代碼行數:13,代碼來源:Questions.cs

示例15: ExecuteSimpleQuery

        /// <summary>
        /// Demonstrate a partition range query that searches within a partition for a set of entities that are within a 
        /// specific range. This query returns all entities in the range. Note that if your table contains a large amount of data,
        /// the query may be slow or may time out. In that case, use a segmented query, as shown in the PartitionRangeQueryAsync() 
        /// sample method.
        /// Note that the ExecuteSimpleQuery method is called synchronously, for the purposes of the sample. However, in a real-world
        /// application using the async/await pattern, best practices recommend using asynchronous methods consistently.
        /// </summary>
        /// <param name="table">Sample table name</param>
        /// <param name="partitionKey">The partition within which to search</param>
        /// <param name="startRowKey">The lowest bound of the row key range within which to search</param>
        /// <param name="endRowKey">The highest bound of the row key range within which to search</param>
        private static void ExecuteSimpleQuery(CloudTable table, string partitionKey, string startRowKey, string endRowKey)
        {
            try
            {
                // Create the range query using the fluid API 
                TableQuery<CustomerEntity> rangeQuery = new TableQuery<CustomerEntity>().Where(
                    TableQuery.CombineFilters(
                            TableQuery.GenerateFilterCondition("PartitionKey", QueryComparisons.Equal, partitionKey),
                            TableOperators.And,
                            TableQuery.CombineFilters(
                                TableQuery.GenerateFilterCondition("RowKey", QueryComparisons.GreaterThanOrEqual, startRowKey),
                                TableOperators.And,
                                TableQuery.GenerateFilterCondition("RowKey", QueryComparisons.LessThanOrEqual, endRowKey))));

                foreach (CustomerEntity entity in table.ExecuteQuery(rangeQuery))
                {
                    Console.WriteLine("Customer: {0},{1}\t{2}\t{3}", entity.PartitionKey, entity.RowKey, entity.Email, entity.PhoneNumber);
                }
            }
            catch (StorageException e)
            {
                Console.WriteLine(e.Message);
                Console.ReadLine();
                throw;
            }
        }
開發者ID:Azure-Samples,項目名稱:storage-table-dotnet-getting-started,代碼行數:38,代碼來源:AdvancedSamples.cs


注:本文中的Microsoft.WindowsAzure.Storage.Table.CloudTable.ExecuteQuery方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。