、异步执行

var entity = new Company {Name = "Async Company #2", Id = "companies/2"};
using (var session = documentStore.OpenAsyncSession())
{
    ); // loading an entity asynchronously

    await session.StoreAsync(entity); // in-memory operations are committed asynchronously when calling SaveChangesAsync
    await session.SaveChangesAsync(); // returns a task that completes asynchronously

    var query = session.Query<Company>()
                       .Where(x => x.Name == "Async Company #1")
                       .ToListAsync(); // returns a task that will execute the query
}

、维度查询

假设我们有一个这样的文档:
 {
    DateOfListing: "2000-09-01T00:00:00.0000000+01:00"
    Manufacturer: "Jessops"
    Model: "blah"
    Cost: 717.502206059872
    Zoom:
    Megapixels: 10.4508949012733
    ImageStabiliser: false
}

)建立基于制造厂商,成本和像素的维度

var _facets = new List<Facet>
              {
                  new Facet
                      {
                          Name = "Manufacturer"
                      },
                  new Facet
                      {
                          Name = "Cost_Range",
                          Mode = FacetMode.Ranges,
                          Ranges =
                              {
                                  "[NULL TO Dx200.0]",
                                  "[Dx200.0 TO Dx400.0]",
                                  "[Dx400.0 TO Dx600.0]",
                                  "[Dx600.0 TO Dx800.0]",
                                  "[Dx800.0 TO NULL]",
                              }
                      },
                  new Facet
                      {
                          Name = "Megapixels_Range",
                          Mode = FacetMode.Ranges,
                          Ranges =
                              {
                                  "[NULL TO Dx3.0]",
                                  "[Dx3.0 TO Dx7.0]",
                                  "[Dx7.0 TO Dx10.0]",
                                  "[Dx10.0 TO NULL]",
                              }
                      }
              };

成本字段范围
Cost <= 200.0
200.0 <= Cost <= 400.0
400.0 <= Cost <= 600.0
600.0 <= Cost <= 800.0
Cost >= 800.0
像素字段范围
Megapixels <= 3.0
3.0 <= Megapixels <= 7.0
7.0 <= Megapixels <= 10.0
Megapixels >= 10.0

//保存
session.Store(new FacetSetup { Id = "facets/CameraFacets", Facets = _facets });

、创建索引

store.DatabaseCommands.PutIndex("CameraCost",
            new IndexDefinition
            {
                Map = @"from camera in docs
                                select new
                                {
                                    camera.Manufacturer,
                                    camera.Model,
                                    camera.Cost,
                                    camera.DateOfListing,
                                    camera.Megapixels
                                }"
            });

、查询
var facetResults = session.Query<Camera>("CameraCost")
    .Where(x => x.Cost >=  && x.Cost <= )
    .ToFacets("facets/CameraFacets");

通过通过这个网址查询:
http://localhost:8080/facets/CameraCost?facetDoc=facets/CameraFacets&query=Cost_Range:[Dx100 TO Dx300.0]

结果如下:
 {
   Manufacturer: [
      {
         Range: 'canon',
         Count:
      },
      {
         Range: 'jessops',
         Count:
      },
      {
         Range: 'nikon',
         Count:
      },
      {
         Range: 'phillips',
         Count:
      },
      {
         Range: 'sony',
         Count:
      }
   ],
   Cost_Range: [
      {
         Range: '[NULL TO Dx200.0]',
         Count:
      },
      {
         Range: '[Dx200.0 TO Dx400.0]',
         Count:
      }
   ],
   Megapixels_Range: [
      {
         Range: '[NULL TO Dx3.0]',
         Count:
      },
      {
         Range: '[Dx3.0 TO Dx7.0]',
         Count:
      },
      {
         Range: '[Dx7.0 TO Dx10.0]',
         Count:
      },
      {
         Range: '[Dx10.0 TO NULL]',
         Count:
      }
   ]
}

RavenDb学习(七) 异步工作以及维度查询的更多相关文章

  1. (转)MyBatis框架的学习(七)——MyBatis逆向工程自动生成代码

    http://blog.csdn.net/yerenyuan_pku/article/details/71909325 什么是逆向工程 MyBatis的一个主要的特点就是需要程序员自己编写sql,那么 ...

  2. IBatis.Net学习笔记六--再谈查询

    在IBatis.Net学习笔记五--常用的查询方式 中我提到了一些IBatis.Net中的查询,特别是配置文件的写法. 后来通过大家的讨论,特别是Anders Cui 的提醒,又发现了其他的多表查询的 ...

  3. MySQL订单分库分表多维度查询

    转自:http://blog.itpub.net/29254281/viewspace-2086198/ MySQL订单分库分表多维度查询  MySQL分库分表,一般只能按照一个维度进行查询. 以订单 ...

  4. SQL反模式学习笔记18 减少SQL查询数据,避免使用一条SQL语句解决复杂问题

    目标:减少SQL查询数据,避免使用一条SQL语句解决复杂问题 反模式:视图使用一步操作,单个SQL语句解决复杂问题 使用一个查询来获得所有结果的最常见后果就是产生了一个笛卡尔积.导致查询性能降低. 如 ...

  5. MyBatis学习七:spring和MyBatis整合

    <\mybatis\day02\16mybatis和spring整合-sqlSessionFactory配置.avi;> MyBatis学习七:spring和MyBatis整合.逆向工程 ...

  6. SVG 学习<七> SVG的路径——path(1)直线命令、弧线命令

    目录 SVG 学习<一>基础图形及线段 SVG 学习<二>进阶 SVG世界,视野,视窗 stroke属性 svg分组 SVG 学习<三>渐变 SVG 学习<四 ...

  7. day 85 Vue学习七之vue-cookie

      Vue学习七之vue-cookie   通过vue如何操作cookie呢 参考链接:https://www.jianshu.com/p/535b53989b39 第一步:安装vue-cookies ...

  8. oracle学习 第一章 简单的查询语句 ——03

    1.1最简单的查询语句 例 1-1 SQL> select * from emp; 例 1-1 结果 这里的 * 号表示全部的列.它与在select 之后列出全部的列名是一样的.查询语句以分号( ...

  9. 数据库学习笔记3 基本的查询流 2 select lastname+','+firstname as fullname order by lastname+','+firstname len() left() stuff() percent , select top(3) with ties

    数据库学习笔记3 基本的查询流 2   order by子句对查询结果集进行排序 多列和拼接 多列的方式就很简单了 select firstname,lastname from person.pers ...

随机推荐

  1. linux 查看 cpu个数 核心数 线程数

    深蓝的blog:http://blog.csdn.net/huangyanlong/article/details/43935535 (1).查看cpu信息 [root@xckydb ~]# cat ...

  2. maven pom文件简单模板和配置详解

    https://blog.csdn.net/earbao/article/details/49924943 maven pom文件简单模板和配置详解

  3. C#基础第九天-作业答案-储蓄账户(SavingAccount)和信用账户(CreditAccount)

    class Bank { //Dictionary<long,Account> dictionary=new Dictionary<long,Account>(); DataT ...

  4. Android 7.0 介绍和适配问题

    介绍:http://gank.io/post/56e0b83c67765963436fcb94 适配:http://blog.csdn.net/fengyuzhengfan/article/detai ...

  5. 关于NOIP的运行环境

    目前(2019年2月22日)仍然是 G++ , 终端运行,命令行: g++ test.cpp -o test ,而g++ 4.8.4默认标准是: -std=gnu++ . g++到了gcc6才把默认标 ...

  6. 错误状态码URL重定向

    server { listen 80; server_name www.espressos.com; location / { root /data0/www/bbs; index index.htm ...

  7. lua 创建listview

    只要是新的聊天对象就创建一个新的listview local name = tolua.cast(UIHelper:seekWidgetByName(self.nameItem, "name ...

  8. Theories of Deep Learning

    https://stats385.github.io/readings Lecture 1 – Deep Learning Challenge. Is There Theory? Readings D ...

  9. close Spark Streaming gratefully

    https://blog.csdn.net/u010454030/article/details/78679930 https://blog.csdn.net/u010454030/article/d ...

  10. Silverlight-MEF-DEMO

    “托管扩展性框架(Managed Extensibility Framework,简称MEF),是微软.NET框架下为提高应用和组件复用程度而推出的,用于使组件能够最大化的重用.使用MEF能够使静态编 ...