WinFS(全名为Windows Future Storage[1]是以关联式资料库为基础之资料储存与管理系统的代号名称,它由微软开发,在2003年首次用于Windows中的进阶储存子系统,它针对结构化半结构化英语Semi-structured model未结构化资料保存英语Persistence (computer science)与管理用途而设计。WinFS包含可用于储存资讯的关联式资料库,而且可储存任何类型的资料,前提是资料类型已有完整定义的结构描述。接著,便可透过关系来建立个别资料项目之间的关联,这样系统便可根据特定属性作参照,使用者也可明确地描述属性作参照。此外,因资料具完整定义的结构描述,任何应用程式均可重复使用资料;而且透过使用关系,可有效率地组织与撷取相关资料。因系统知道资讯的结构与用途,故可作复杂的查询,以达成资料的进阶搜寻,并透过探索资料项目之间的关系来汇整各种不同的资料项目。

WinFS与其共用类型结构描述可让应用程式识别不同的资料类型,但仍需撰写应用程式以转译不同的资料类型。因此,WinFS并不适合用来开发可检视或编辑所有资料类型的单一应用程式;其目的是让应用程式能了解所有资料的结构并撷取资讯以作进一步处理。在2003专业开发人员大会,微软首度介绍WinFS,并发布了视讯简报,名为IWish[2],此视讯简报提供的原型介面显示应用程式如何公开介面以得益于统一类型系统。视讯中展示的概念包含应用程式如何使用资料项目之间的关系来动态筛选选项,及应用程式如何将多个相关资料组成群组并以统一方式呈现资料。

WinFS是众多“Longhorn”技术的基础,而且将包含在下一版本的Windows中。原本WinFS应在Windows Vista发行后提供,但相关计画在2006年6月搁置,然而其某些元件技术已整合到即将发行的ADO.NETMicrosoft SQL Server[3]。某些评论家指WinFS专案已完成,但史蒂夫·鲍尔默在2006年11月曾公开称WinFS仍在开发,至于此技术将以何种方式提供仍未知[4]

动机

许多常见作业系统中的档案系统(包括近年众多Windows 版本中使用的NTFS)都将档案与其他物件储存为位元流,且这些档案系统对档案中所存资料内容通常并不知道。此类档案系统也只有一种组织档案的方式(具体而言是透过目录与档案名称)[5][6]

因档案系统完全不知其所存资料[5],应用程式常使用本身的档案格式(通常为专属格式)。这阻碍在多个应用程式之间共用的资料。建立可处理来自多种档案类型之资讯的应用程式变得很困难,因程式设计师须了解所有档案的结构语意英语Semantics#Computer science[7]。使用常见档案格式是解决此问题的暂时方案,但非治本;因无法确保所有应用程式都会使用预期的格式。具有标准化结构描述的资料(例如,XML文件与关联式资料)无此问题,因为它们具有标准化的结构与执行阶段需求[8]

此外,传统档案系统只能根据档案名称来撷取与搜寻资料,因为它对资料所知的范围仅限于用储存资料之档案名称[7]。较好的解决方案是使用属性为档案加上标记(tag),此处所谓的属性可描述档案内容。属性是有关档案的中继资料,如档案类型(例如:文件、图片、音乐、建立者等)[5]。这样可让系统依属性(而非使用资料夹阶层)来搜寻档案(例如:寻找“包含人员X的图片”)。档案系统本身即可识别属性,或透过某些延伸模组来识别属性[5]。桌面搜寻应用程式进一步采用此概念。它们会从档案撷取资料(包含属性)并为档案编制索引。为了撷取资料,它们为每种档案格式使用一个筛选器。这样就可依档案属性与档案中所包含的资料来搜寻档案[5]

但是,这仍不足以协助管理相关资料,因为不同的项目之间并未定义任何关系(例如:无法搜寻“住在墨西哥阿卡波可市、在我的相片集中出现超过一百次、且我最近一个月曾经与其有过电子邮件往来的所有人员的电话号码”)。若要完成这种搜寻,必须要一种同时定义语意与资料关系的资料模型[5][6]。WinFS的目的是提供这样的资料模型与执行阶段基础结构,以便储存资料与资料项目之间的关系(根据资料模型),同时以尽量不影响效能的方式完成此动作。

概观

WinFS可识别各种类型的资料,例如:图片电子邮件文件音讯视讯行事历连络人等;不像档案系统只能识别位元流。由系统储存与管理的资料是WinFS执行阶段所识别之资料类型的执行个体。资料结构的基础是属性。例如,履历类型的执行个体将透过公开特定属性(例如姓名教育程度工作经验等)来描述资料。属性的类型可能是字串整数日期等简单类型,或连络人之类的复杂类型[7][9]。不同的资料类型会公开不同的属性。此外,WinFS也允许不同的资料执行个体与彼此关联,例如您可以利用作者关系来建立文件与连络人之间的关联[6][9]。关系也会公开为属性,例如若文件是透过建立者关系与连络人关联,则文件将具有建立者属性。当文件被存取时,系统会侦测到该关系并传回相关资料[9]。借由依循该关系即可撷取所有相关资料[6]

 
电子邮件应用程式可以使用关系来建立动态筛选器,以建立不同的电子邮件检视,如同在原型行事历截图一样

WinFS透过让所有应用程式存取资料类型与其结构描述的方式来达成应用程式之间的资料共用[7]。因此当任何应用程式想要使用WinFS类型时,可以使用结构描述来了解资料的结构,并有效利用资讯。因此,即使开发人员并未撰写剖析器来识别不同的资料格式,应用程式也可以存取系统上的所有资料。它也可以使用关系与相关资料来建立动态筛选器,以不同的方式呈现应用程式所处理的资讯。WinFS API进一步将资料的存取工作抽象化。所有WinFS类型都公开为.NET 物件,而物件的属性则直接对应到资料类型的属性[5]。此外,透过让处理相同资料的不同应用程式共用相同的WinFS资料执行个体,而非将相同的资料储存为不同的档案格式,系统管理员便不需要在资料发生变更时同步不同的存放区[10]。因此WinFS可协助避免资料重复储存的情形[5][8]

透过存取系统中所有资料的能力,您可以建立复杂的搜寻来寻找由WinFS所管理之所有资料项目中的资料。在上述范例(“住在墨西哥阿卡波可市、在我的相片集中出现超过一百次、且我最近一个月曾经与其有过电子邮件往来的所有人员的电话号码”)中,WinFS可以周游所有相片的主体关系以寻找连络人项目。同样地,它也可以筛选最近一个月的电子邮件并存取通讯对象关系以与连络人联系。接著,系统便可以从上述两个搜寻结果中找出适当的连络人,并透过存取连络人项目的适当属性来撷取其电话号码。

除了完全语意化的资料(如同XML关联式资料)之外,WinFS也支援半结构化资料(例如影像,影像具有未结构化的位元资料流与结构化的中继资料)以及未结构化资料(例如档案)。它可将未结构化的元件直接储存为档案,同时将结构化的中继资料储存在结构化的存放区中[9]。WinFS在内部使用关联式资料库来管理资料。但是,它不会将资料限制为属于任何特定资料模型,例如关联式阶层式,而且它可以是任何已完整定义的结构描述。WinFS执行阶段会将结构描述对应到关联式特征(modality)[5],方式是定义将储存类型的资料表,以及重新呈现关系时所需的主索引键外部索引键。WinFS预设包含物件与XML结构描述的对应;至于其他结构描述的对应,则必须另行指定。物件结构描述是使用XML来指定;WinFS会产生指令码以将结构描述公开为.NET 类别。您可以使用ADO.NET直接指定关联式结构描述,虽然您必须提供物件结构描述的对应以将它以类别方式公开[9]。所有关系周游动作都是在这些资料表上以Joins方式执行。WinFS也会自动在这些资料表上建立索引,以便应用程式可以更快速地存取资讯[9]。索引可大幅加快Joins的速度,因此周游关系以撷取相关资料的动作非常快。搜寻资讯时也会使用索引;搜寻与查询会使用索引,因此操作可以快速完成,这跟桌面搜寻软件很类似。

发展

结构化存放区时间表
1990 —
1991 —
1992 —
1993 —
1994 —
1995 —
1996 —
1997 —
1998 —
1999 —
2000 —
2001 —
2002 —
2003 —
2004 —
2005 —
2006 —
2007 —
Cairo中的OFS[11]
Storage+,使用SQL 7.0[11]
RFS,使用SQL 2000[11]
WinFS[11]
开发中[4]
已取消
已取消
已取消
功能缩减
功能缩减
已取消
没有已知资讯
各种结构化储存专案的时间表
,由Microsoft提供。上述技术并没有任何一项已发展为全功能
执行阶段并提供相关API。此外,年度仅为预估。

WinFS的开发是1990年代早期计画之功能的延续,此功能称为物件档案系统(Object File System,简称OFS),它原本应该包含在Cairo专案中。OFS被认为应该具有强大的资料汇整功能[11]。但Cairo专案当时遭搁置,因此OFS也被延宕。但是,稍后在开发COM时,规划了一个称为Storage+(以后来发行的SQL Server 8.0为基础)的储存系统,Storage+预期应提供类似的汇整功能[11]。但是,这项计画也没有实现,而类似的技术关联式档案系统(Relational File System,RFS)据信将在SQL Server 2000中提供[11]。但是,SQL Server 2000最后只是对于SQL Server 7.0进行些许更新,但并未实作RFS。

但此概念从未被忘却[11]。因此才有WinFS的出现。WinFS原本预计包含在Windows Vista[13],以及后来代号名称为“Longhorn”的Windows Vista 组建4051(此版本在2003年的微软专业开发者大会公开发布),但当时WinFS有严重的效能问题[11]。在2004年8月,微软宣布WinFS将不会内建于Windows Vista;而是会在Vista正式发行后以可下载的更新方式提供[11]

在2005年8月29日,微软悄悄地将WinFS Beta 1提供给MSDN订户。该版本可以在Windows XP运行,而且需要.NET Framework才能执行。WinFS API包含在“System.Storage”命名空间中[11][14]。该Beta版本在2005年12月1日更新,以与.NET Framework 2.0相容[15]。WinFS Beta 2预计在2006年末推出[16],而且预期会与Windows桌面搜寻整合,因此搜寻结果会包含来自一般档案与WinFS存放区的结果;此外,您可以使用ADO.NET来存取WinFS资料[17]

但是,在2006年6月23日,微软的WinFS团队宣布将不再以独立产品方式提供WinFS[3],而且某些元件将以其他技术提供 - 例如对象关系映射元件至ADO.NET Entity Framework;支援未结构化资料、操作的无管理模式、透过FILESTREAM资料类型支援档案系统物件,以及SQL Server 2008(代号名称为“Katmai”)中的阶层式资料[18][19],以及与Win32API及Windows Shell整合,以及在未来的Microsoft SQL Server版本中透过周游关系以支援阶层的周游[18];以及将元件同步到Microsoft Sync Framework英语Microsoft Sync Framework[18]。但是尚未排除在Windows的未来版本中内置WinFS的情况[18]

微软宣布此消息之后,大部分评论分析家均认为WinFS专案已遭放弃。但在2006年11月,鲍尔默在一场会议中说明WinFS仍在开发中,但要等到技术成熟时才会整合到Windows程式码基础。2006年12月,比尔盖兹的会议证实此消息,而且微软计画移植Windows Media PlayerWindows Photo GalleryMicrosoft Outlook等应用程式以使用WinFS做为资料储存后端[20]

2013年,比尔盖兹称WinFS项目的搁置是他对微软最大的失望,并且认为WinFS已经超越了时代[21]

资料存放区

架构

 
Architecture of the WinFS Stack

WinFS不是实体档案系统;相反,它在NTFS档案系统之上提供系统化的资料模型建构能力。它仍使用NTFS在实体档案中储存其资料[11]。WinFS使用从SQL Server 2005[22]衍生的关联式引擎来提供资料关系机制。WinFS存放区仅是已设定FILESTREAM属性的SQL Server资料库(.MDF)档案[23]。这些档案是储存在磁碟区根目录下名为“System Volume Information”的资料夹(此资料夹具有限制的存取权)下的"WinFS"子资料夹中,其名称为这些存放区的GUID[23]

WinFS 堆叠的底层是WinFS Core,它会与档案系统互动并提供档案存取与定址能力[7]。关联式引擎使用WinFS核心服务来提供结构化的存放区与其他服务(例如:锁定将使用哪个WinFS执行阶段来实作该功能。WinFS执行阶段会公开服务(例如:同步处理与规则),其可用于同步处理WinFS存放区或在发生特定事件时执行特定动作[7]

WinFS是以服务的方式执行,此服务会执行三个处理程序[24] - 装载关联式资料存放区的WinFS.exe、装载索引编制与查询引擎的WinFSSearch.exe以及与底层档案系统互动的WinFPM.exe (WinFS File Promotion Manager)。您可以利用一组.NET Framework API来撰写程式以存取其功能,这些.NET Framework API可让应用程式定义自订资料型别、定义资料之间的关系、储存与撷取资讯,以及实作进阶搜寻[5][7]。接著应用程式可以汇整资料,并将资料呈现给使用者。

资料存放区

WinFS将资料储存在关联式存放区中,这些存放区会公开为虚拟位置,称为“存放区”[11]。WinFS存放区是通用存放库,任何应用程式都可以在其中储存资料,以及中继资料、资料关系与结构描述。WinFS执行阶段本身可以套用特定的资料关系;例如,若图片的“subject”属性与连络人的“name”属性相同,则WinFS可以在该连络人与该图片之间建立关联[25]。资料之间的关系也可以由其他应用程式或使用者指定[26]

WinFS提供一致性的存放区,但无法定义将储存于存放区之资料的格式。但是,它支援以应用程式支援的特定格式写入资料。前提是应用程式必须提供结构描述英语logical schema,以定义解译档案格式的方式[5]。例如,您可以新增结构描述以让WinFS知道如何读取(甚至是进一步搜寻或分析)特定档案格式,例如PDF档案。透过使用结构描述,任何应用程式都可以读取由其他应用程式所建立的资料,而且不同的应用程式也可以透过共用结构描述以其他应用程式支援的格式来写入资料[26]

您可以在一部电脑上建立多个WinFS存放区[26]。这样可以独立储存不同类别的资料,例如,您可以将公司文件与私人文件储存在不同的存放区中。根据预设,WinFS只提供一个存放区,其名称为“DefaultStore”[11]。WinFS存放区是公开为壳层(shell)物件(类似虚拟资料夹),此物件会动态产生存放区中的项目清单,并以资料夹检视方式呈现这些项目。利用壳层物件也可以搜寻资料存放区中的资讯[11]

资料单位是以WinFS项目的方式储存在WinFS存放区中[5][26]。WinFS项目与核心资料项目亦包含资料项目与其他资料之关联的资讯。此“关联”是以逻辑连结的方式储存。连结指的是目前的项目与哪些资料项目关联。换句话说,连结是用以指定资料与其他资料项目的关系。连结实体上是以连结识别码来储存,此识别码指定资料关联的名称与用途,例如,“所属型别”或“组成要素”[5]。连结识别码是储存为资料项目的属性(attribute)。具有相同连结识别码的所有物件将被视为相关物件[5]。您必须事先将XML结构描述(定义将储存在WinFS中之资料项目的结构)提供给WinFS执行阶段[5]。在WinFS的Beta 1版本中,您必须先将结构描述组件新增到GAC,才能开始使用结构描述。

资料模型

WinFS模型资料会使用资料项目、其关联、延伸(extension)与规则来规范其使用方式[7]。WinFS必须知道资料项目的类型与结构,才能将资料项目中储存的资讯提供给要求该资讯的应用程式。这是透过使用结构描述来完成。对于即将储存在WinFS中的每种资料项目类型,您必须提供对应的结构描述,以定义资料的类型、结构与关联。这些结构描述是使用XML来定义[5]

预先定义的WinFS结构描述不仅包含文件、电子邮件、约会、工作、媒体、音讯、视讯等的结构描述;也包含系统结构描述,其中包括组态、程式与其他系统相关资料[7]。如果要让应用程式在WinFS中储存资料,但不想与其他应用程式共用该资料的结构,或这些资料可跨系统提供,则可以针对个别应用程式定义自订结构描述[7]

型别系统

 
WinFS Type Hierarchy

档案系统与WinFS之间最大的差异在于WinFS知道其所储存之每个资料项目的型别。型别会指定资料项目的属性(property)。WinFS型别系统与.NET Framework的类别与继承概念紧密关联。透过延伸与巢状化任何预先定义的型别,即可建立新型别[5]

WinFS提供四种预先定义的基础型别– ItemsRelationshipsScalarTypesNestedTypes[5]。Item是可储存的基础资料物件,而Relationship则是两个资料项目之间的关系或连结。因为所有WinFS项目都必须具有型别,储存之项目的型别会定义其属性(property)。Item的属性可以是ScalarType(定义属性可包含之资讯的最小单位)或NestedType(多个ScalarTypes和/或NestedTypes的集合)。所有WinFS型别都以.NET CLR 类别的方式提供[26]

任何以资料单位(例如:连络人、影像、视讯或文件等)所代表的物件都可以储存在WinFS存放区中做为Item型别的特殊项[26]。根据预设,WinFS为档案、连络人、文件、图片、音讯、视讯、连络人与邮件提供Item型别。档案Item可以储存任何一般资料,这在档案系统中是储存为档案。但除非为档案提供进阶结构描述(透过将它定义为特殊化的Item),WinFS将无法存取其资料。此类档案Item仅能支援与其他Item相关联[5]

 
Defining a new Type

开发人员可以扩充这些型别或基础型别Item,以为其自订资料提供型别。Item中包含的资料是以属性或实际储存资料的栏位来定义。例如,连络人Item可能包含型别为ScalarType的Name栏位,以及型别为NestedType(进一步由两个ScalarType组成)的Address栏位。为定义此型别,会扩充基础类别Item,而且会新增必要栏位至该类别[5]。NestedType栏位可定义为包含两个ScalarType栏位的另一个类别。一旦定义型别,就必须定义结构描述以表示每个栏位的原始型别,例如Name栏位的型别是String、Address栏位是自订的Address类别,每个栏位的型别都是String。WinFS支援的其他原始型别包括IntegerByteDecimalFloatDoubleBoolean与DateTime等[5]。结构描述也会定义哪些栏位为必要栏位,哪些栏位为选用栏位[27]。系统会使用以此方式定义的连络人Item来储存有关连络人的资讯,方式是填入属性栏位并予以储存。首次储存时只需要填入标示为必要的栏位。[26]其他栏位可在稍后由使用者填入,或完全不填入。若需要新增多个栏位(例如:“上次交谈日期”),只要视需要简单地扩充此型别即可。您可以使用相同的方式定义其他资料的Item型别。

 
Relationships

WinFS会为所有已定义的Item建立资料表[27]。为Item定义的所有栏位会构成资料表的资料栏,而每个对应Item的Item实体则会储存为资料表的资料列。当资料表中的某些栏位参照某些其他资料表中的资料时,即表示这些资料表之间有特定的关系存在。关系的结构描述会指定相关的资料表有哪些,以及关系的种类与名称。WinFS执行阶段负责管理关系结构描述[26]。所有Item都会公开为.NET CLR 物件,此物件具有统一的介面,可让应用程式轻松存取栏位中储存的资料。因此,任何应用程式都可以撷取具有任何Item型别的物件,而且可以使用该物件中的资料,而不需要了解栏位中储存之资料的实际结构[5]

WinFS型别是公开为.NET类别,它可以具现化为.NET物件。透过设定属性即可在这些型别中储存资料。完成之后,它们变会永久储存至WinFS存放区。使用ItemContext类别即可存取WinFS存放区。ItemContext允许以交易式方式存取WinFS存放区,例如,从将ItemContext物件系结到存放区到因为全部成功而关闭或所有变更都已复原。当资料发生变更时,它们不会写入到磁碟;而是会写入到记忆体内的记录。只有当连线关闭时,变更才会以批次方式写入磁碟。这样可协助最佳化磁碟I/O[9]。下列程式码片段会建立连络人并储存在WinFS存放区中。

 //Connect to the default WinFS store
 using(ItemContext ic = ItemContext.Open())
 {
     //Create the contact and set the data in appropriate properties
     ContactEAddress contact = new ContactEAddress();

     //Name is a ComplexType
     contact.Name = new PersonName();                  
         contact.Name.Displayname = "Doe, John";
         contact.Name.FirstName = "John";
         contact.Name.LastName = "Doe";

     //Telephone number is a ComplexType
     contact.TelephoneNumber = new TelephoneNumber();  //ComplexType
         contact.TelephoneNumber.Country = CountryCode.Antarctica;
         contact.TelephoneNumber.Areacode = 4567;
         contact.TelephoneNumber.Number = 9876543210;

     //Age is a SimpleType
     contact.Age = 111;

    //Add the object to the user's personal folder.
    //This relates the item with the Folder pseudo-type, for backward
    //compatibility, as this lets the item to be accessed in a folder 
    //hierarchy for apps which are not WinFS native.
    Folder containingFolder = UserDataFolder.FindMyPersonalFolder();
    containingFolder.OutFolderMemberRelationship.AddItem(ic, contact);

    //Find a document and relate with the document. Searching begins by creating an
    //ItemSearcher object. Each WinFS type object contains a GetSearcher() method
    //that generates an ItemSearcher object which searches documents of that type.
    using(ItemSearcher searcher = Document.GetSearcher(ic))
    {
         Document d = searcher.Find(@"Title = 'Some Particular Document'");
         d.OutAuthoringRelationship.AddItem(ic, contact);
    }
    //Since only one document is to be found, the ItemContext.FindOne() method
    //could be used as well.

    //Find a picture and relate with it
    using(ItemSearcher searcher = Picture.GetSearcher(ic))
    {
         Picture p = searcher.Find(@"Occasion = 'Graduation' and Sequence = '3'");
         p.OutSubjectRelationship.AddItem(ic, contact);
    }

    //Persist to the store and close the reference to the store
    ic.Update();
    ic.Close();
 }

参考文献

  1. ^ Leaked Windows hints at changes to come. [2007-05-04]. (原始内容存档于2007-09-30). 
  2. ^ IWish Concept Video. Microsoft. [2007-07-03]. (原始内容存档于2006-06-02). 
  3. ^ 3.0 3.1 Quentin Clark. WinFS Update. What's in Store. MSDN Blogs. June 23, 2006 [2006-06-23]. (原始内容存档于2010-03-05). 
  4. ^ 4.0 4.1 WinFS Still In The Works Despite Missing Vista. [2007-06-30]. (原始内容存档于2012-11-10). 
  5. ^ 5.00 5.01 5.02 5.03 5.04 5.05 5.06 5.07 5.08 5.09 5.10 5.11 5.12 5.13 5.14 5.15 5.16 5.17 5.18 5.19 5.20 5.21 Shawn Wildermuth. A Developer's Perspective on WinFS: Part 1. MSDN. [2007-06-30]. (原始内容存档于2008-04-20). 
  6. ^ 6.0 6.1 6.2 6.3 Vijay Bangaru. Unify, Organize, Explore, and Innovate. Oh my!(Part 2). WinFS Team Blog. [2007-06-30]. (原始内容存档于2007-06-09). 
  7. ^ 7.00 7.01 7.02 7.03 7.04 7.05 7.06 7.07 7.08 7.09 Sean Grimaldi. The WinFS Files: Divide et Impera. MSDN. [2007-06-30]. (原始内容存档于2007-09-13). 
  8. ^ 8.0 8.1 Thomas Rizzo. WinFS 101: Introducing the New Windows File System. MSDN. [2007-06-30]. (原始内容存档于2007-09-16). 
  9. ^ 9.0 9.1 9.2 9.3 9.4 9.5 9.6 WinFS on The .NET Show. [2007-07-04]. [永久失效链接]
  10. ^ Vijay Bangaru. Unify, Organize, Explore, and Innovate. Oh my!(Part 1). WinFS Team Blog. [2007-06-30]. (原始内容存档于2007-07-08). 
  11. ^ 11.00 11.01 11.02 11.03 11.04 11.05 11.06 11.07 11.08 11.09 11.10 11.11 11.12 11.13 11.14 Paul Thurrott. Windows Storage Foundation (WinFS) Preview. [2007-06-30]. (原始内容存档于2007-07-02). 
  12. ^ 12.0 12.1 My tryst with Destiny, err…Integrated Storage. [2008-01-25]. (原始内容存档于2007-10-31). 
  13. ^ Cath Everett. Will Longhorn be worth the pain?. ZDNet. [2007-06-30]. (原始内容存档于2010-03-12). 
  14. ^ WinFS for Developers. NTFS.com. [2007-07-04]. (原始内容存档于2007-07-03). 
  15. ^ Vijay Bangaru. WinFS Beta 1 Refresh now available. WinFS Team Blog. [2007-06-30]. (原始内容存档于2007-05-20). 
  16. ^ Shan Sinha. Showing off the next release of WinFS at Tech Ed 2006, in Boston! Join us!. WinFS Team Blog. [2007-06-30]. (原始内容存档于2007-03-08). 
  17. ^ Sanjay Anand. My tryst with Destiny, err…Integrated Storage. WinFS Team Blog. [2007-06-30]. (原始内容存档于2007-07-09). 
  18. ^ 18.0 18.1 18.2 18.3 Quentin Clark. Where is WinFS now?. [2008-05-17]. (原始内容存档于2008-05-17). 
  19. ^ Quentin Clark. Update to the Update. WinFS Team Blog. [2007-06-30]. (原始内容存档于2007-07-03). 
  20. ^ Daniel Kornev. A few words about WinFS: The project is back on track. Channel 9. 2006-12-19. 
  21. ^ Billionaire baron Bill Gates still mourns Vista's stillborn WinFS. www.theregister.com. 2013-02-12 [2020-09-23]. (原始内容存档于2021-12-09) (英语). 
  22. ^ Nate Mook. MS Explains WinFS, Releases Beta 1. BetaNews. [2007-07-02]. (原始内容存档于2008-07-06). 
  23. ^ 23.0 23.1 Shishir Mehrotra. "WinFS" Future Directions: An Overview. Professional Developers Conference 2005 presentations. Microsoft. September 2005 [2006-05-22]. (原始内容存档于2006-01-06). (Currently offline, mirror页面存档备份,存于互联网档案馆)).
  24. ^ Erwyn van der Meer. First Look on WinFS Beta 1. [2007-07-03]. (原始内容存档于2007-06-09). 
  25. ^ Vijay Bangaru. WinFS Mailbox. WinFS Team Blog. [2007-06-30]. (原始内容存档于2007-05-22). 
  26. ^ 26.0 26.1 26.2 26.3 26.4 26.5 26.6 26.7 Richard Grimes. Revolutionary File Storage System Lets Users Search and Manage Files Based on Content. MSDN Magazine. [2007-06-30]. (原始内容存档于2007-06-27). 
  27. ^ 27.0 27.1 Shawn Wildermuth. A Developer's Perspective on WinFS: Part 2. MSDN. Microsoft. July 2004 [2007-06-30]. (原始内容存档于2008-04-04). 

参见

外部链接