Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

841 lines
40 KiB

  1. <!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML//EN">
  2. <html><head><title>Indexing Service: Query Language</title>
  3. <SCRIPT LANGUAGE="JavaScript">
  4. TempString = navigator.appVersion
  5. if (navigator.appName == "Microsoft Internet Explorer"){
  6. // Check to see if browser is Microsoft
  7. if (TempString.indexOf ("4.") >= 0){
  8. // Check to see if it is IE 4
  9. document.writeln('<link rel="stylesheet" type="text/css" href="/iishelp/common/coua.css">');
  10. }
  11. else {
  12. document.writeln('<link rel="stylesheet" type="text/css" href="/iishelp/common/cocss.css">');
  13. }
  14. }
  15. else if (navigator.appName == "Netscape") {
  16. // Check to see if browser is Netscape
  17. document.writeln('<link rel="stylesheet" type="text/css" href="/iishelp/common/coua.css">');
  18. }
  19. else
  20. document.writeln('<link rel="stylesheet" type="text/css" href="/iishelp/common/cocss.css">');
  21. </script>
  22. <META NAME="DESCRIPTION" CONTENT="Tells how to refine searches by using complex queries"></head>
  23. <body bgcolor="#FFFFFF" text="#000000">
  24. <font face="Verdana,Arial,Helvetica">
  25. <h1><a name="QueryLanguage">Query Language</a></h1>
  26. <p>You can search for any word or phrase on a Web site by typing the word or phrase into a query form and clicking the button to execute the query (for example, the Execute Query button on the sample query form). This section covers the following topics:</p>
  27. <ul>
  28. <li><strong><a href="#Operators">Boolean and Proximity Operators</a>:</strong> Shows how to make more precise queries by inserting Boolean and proximity operators.</li>
  29. <li><strong><a href="#Wildcards">Wildcards</a>:</strong> Helps you find pages containing words similar to a given word.</li>
  30. <li><strong><a href="#FreeTextQueries">Free-Text Queries</a>:</strong> Describes how to formulate a query based on the meaning of a phrase rather than the exact wording.</li>
  31. <li><strong><a href="#VectorQueries">Vector Space Queries</a>:</strong> Explains how to get query results that match a list of words and phrases.</li>
  32. <li><strong><a href="#PropertyValueQueries">Property Value Queries</a>:</strong> Tells how to query for the property values of a file.</li>
  33. <li><strong><a href="#Examples">Query Examples</a>:</strong> Gives examples of various queries.</li>
  34. <li><strong><a href="#PropertyNamesList">List of Property Names</a>:</strong> Lists and describes property names always available for queries.</li>
  35. </ul>
  36. <p>Searches produce a list of files that contain the word or phrase no matter where they appear in the text. This list gives the rules for formulating queries:</p>
  37. <ul>
  38. <li>Consecutive words are treated as a phrase; they must appear in the same order within a matching document.</li>
  39. <li>Queries are case-insensitive, so you can type your query in uppercase or lowercase.</li>
  40. <li>You can search for any word except for those in the exception list (for English, this includes <em>a</em>, <em>an</em>, <em>and</em>, <em>as</em>, and other common words), which are ignored during a search.</li>
  41. <li>Words in the exception list are treated as placeholders in phrase and proximity queries. For example, if you searched for &#147;Word for Windows&#148;, the results could give you &#147;Word for Windows&#148; and &#147;Word and Windows&#148;, because <em>for </em>is a noise word and appears in the exception list.</li>
  42. <li>Punctuation marks such as the period (.), colon (:), semicolon (;), and comma (,) are ignored during a search.</li>
  43. <li>To use specially treated characters such as &amp;, |, ^, #, @, $, (, ), in a query, enclose your query in quotation marks (&#147;).</li>
  44. <li>To search for a word or phrase containing quotation marks, enclose the entire phrase in quotation marks and then double the quotation marks around the word or words you want to surround with quotes. For example, &#147;World-Wide Web or &#147;&#147;Web&#148;&#148;&#148; searches for <em>World-Wide Web or &#147;Web&#148;.</em></li>
  45. <li>You can insert <a href="#Operators">Boolean operators</a> (<strong>AND</strong>, <strong>OR</strong>, and <strong>NOT</strong>) and the <a href="#Operators">proximity operator</a> (<strong>NEAR</strong>) to specify additional search information.</li>
  46. <li>The <a href="#Wildcards">wildcard character</a> (*) can match words with a given prefix. The query esc* matches the terms &#147;ESC,&#148; &#147;escape,&#148;
  47. and so on.</li>
  48. <li><a href="#FreeTextQueries">Free-text queries</a> can be specified without regard to query syntax.</li>
  49. <li><a href="#VectorQueries">Vector space queries</a> can be specified.</li>
  50. <li>ActiveX&#153; (OLE) and file attribute <a href="#PropertyValueQueries">property value queries</a> can be issued.</li>
  51. </ul>
  52. <h1><a name="Operators">Boolean and Proximity Operators</a></h1>
  53. <p>Boolean and proximity operators can create a more precise query.</p>
  54. <table border="1" cellpadding="4" cellspacing="1" width="100%">
  55. <tr>
  56. <th align="Left" valign="bottom" bgcolor="#C0C0C0" width=33%>To Search For</th>
  57. <th align="Left" valign="bottom" bgcolor="#C0C0C0" width=33%>Example</th>
  58. <th align="Left" valign="bottom" bgcolor="#C0C0C0" width=33%>Results</th>
  59. </tr>
  60. <tr>
  61. <td valign="top">Both terms in the same page </td>
  62. <td valign="top"><font size="3" face="Courier"><code>access and basic</code></font> <br>
  63. <strong>&#151;</strong>Or<strong>&#151;</strong><br>
  64. <font size="3" face="Courier"><code>access &amp; basic</code></font></td>
  65. <td valign="top">Pages with both the words &#147;access&#148; and
  66. &#147;basic&#148; </td>
  67. </tr>
  68. <tr>
  69. <td valign="top">Either term in a page </td>
  70. <td valign="top"><font size="3" face="Courier"><code>cgi or isapi</code></font><br>
  71. <strong>&#151;</strong>Or<strong>&#151;</strong><br>
  72. <font size="3" face="Courier"><code>cgi | isapi</code></font></td>
  73. <td valign="top">Pages with the words &#147;cgi&#148; or &#147;isapi&#148; </td>
  74. </tr>
  75. <tr>
  76. <td valign="top">The first term without the second term </td>
  77. <td valign="top"><font size="3" face="Courier"><code>access and not basic</code></font><br>
  78. <strong>&#151;</strong>Or<strong>&#151;</strong><br>
  79. <font size="3" face="Courier"><code>access &amp; ! basic</code></font></td>
  80. <td valign="top">Pages with the word &#147;access&#148; but not &#147;basic&#148; </td>
  81. </tr>
  82. <tr>
  83. <td valign="top">Pages not matching a property value </td>
  84. <td valign="top"><font size="3" face="Courier"><code>not @size = 100</code></font><br>
  85. <strong>&#151;</strong>Or<strong>&#151;</strong><br>
  86. <font size="3" face="Courier"><code>! @size = 100</code></font></td>
  87. <td valign="top">Pages that are not 100 bytes </td>
  88. </tr>
  89. <tr>
  90. <td valign="top">Both terms in the same page, close together </td>
  91. <td valign="top"><font size="3" face="Courier"><code>excel near project</code></font><br>
  92. <strong>&#151;</strong>Or<strong>&#151;</strong><br>
  93. <font size="3" face="Courier"><code>excel ~ project</code></font></td>
  94. <td valign="top">Pages with the word &#147;excel&#148; near the word
  95. &#147;project&#148; </td>
  96. </tr>
  97. </table>
  98. <p>Hints:</p>
  99. <ul>
  100. <li>You can add parentheses to nest expressions within a query. The expressions in parentheses are evaluated before the
  101. rest of the query.</li>
  102. <li>Use double quotes (&#147;) to indicate that a Boolean or <strong>NEAR</strong> operator keyword should be ignored in your query. For
  103. example, &#147;Abbott and Costello&#148; will match pages with the phrase, not pages that match the Boolean expression. In
  104. addition to being an operator, the word <em>and</em> is a noise word in English.</li>
  105. <li>The<strong> NEAR</strong> operator is similar to the <strong>AND</strong> operator in that <strong>NEAR</strong> returns a match if both words being searched for are in the same page. However, the <strong>NEAR</strong> operator differs from <strong>AND</strong> because the rank assigned by <strong>NEAR</strong> depends on the proximity of words. That is, the rank of a page with the searched-for words closer together is greater than or
  106. equal to the rank of a page where the words are farther apart. If the searched-for words are more than 50 words apart, they are not considered near enough, and the page is assigned a rank of zero.</li>
  107. <li>The <strong>NOT</strong> operator can be used only after an <strong>AND</strong> operator in content queries; it can be used only to exclude pages
  108. that match a previous content restriction. For property value queries, the <strong>NOT</strong> operator can be used apart from the
  109. <strong>AND</strong> operator.</li>
  110. <li>The <strong>AND</strong> operator has a higher precedence than <strong>OR</strong>. For example, the first three queries are equal, but the fourth is
  111. not:a AND b OR c<br>
  112. c OR a AND b<br>
  113. c OR (a AND b)<br>
  114. (c OR a) AND b</li>
  115. </ul>
  116. <p><strong>Note</strong>&nbsp;&nbsp;&nbsp;The symbols (&amp;, |, !, ~) and the English keywords <strong>AND</strong>, <strong>OR</strong>, <strong>NOT</strong>, and <strong>NEAR</strong> work the same way in all languages
  117. supported by Indexing Service. Localized keywords are also available when the browser locale is set to one of the following six
  118. languages:</p>
  119. <table border="1" cellpadding="4" cellspacing="1" width="100%">
  120. <tr>
  121. <th align="Left" valign="bottom" bgcolor="#C0C0C0" width="40%">Language</th>
  122. <th align="Left" valign="bottom" bgcolor="#C0C0C0" width="60%">Keywords</th>
  123. </tr>
  124. <tr>
  125. <td valign="top">German</td>
  126. <td valign="top"><strong>UND</strong>, <strong>ODER</strong>, <strong>NICHT</strong>, <strong>NAH</strong></td>
  127. </tr>
  128. <tr>
  129. <td valign="top">French</td>
  130. <td valign="top"><strong>ET</strong>, <strong>OU</strong>, <strong>SANS</strong>, <strong>PRES</strong></td>
  131. </tr>
  132. <tr>
  133. <td valign="top">Spanish</td>
  134. <td valign="top"><strong>Y</strong>, <strong>O</strong>, <strong>NO</strong>, <strong>CERCA</strong></td>
  135. </tr>
  136. <tr>
  137. <td valign="top">Dutch</td>
  138. <td valign="top"><strong>EN</strong>, <strong>OF</strong>, <strong>NIET</strong>, <strong>NABIJ</strong></td>
  139. </tr>
  140. <tr>
  141. <td valign="top">Swedish</td>
  142. <td valign="top"><strong>OCH</strong>, <strong>ELLER</strong>, <strong>INTE</strong>, <strong>N&Auml;RA</strong></td>
  143. </tr>
  144. <tr>
  145. <td>Italian</td><td><strong>E</strong>, <strong>O</strong>, <strong>NO</strong>, <strong>VICINO</strong></td>
  146. </tr>
  147. </table>
  148. <p><strong>Note</strong>&nbsp;&nbsp;&nbsp;The NEAR operator can be applied only to words or phrases.</p>
  149. <h1><a name="Wildcards">Wildcards</a></h1>
  150. <p><a name="Wildcards">Wildcard operators help you find pages containing words similar to a given word. </a></p>
  151. <table border="1" cellpadding="4" cellspacing="1" width="100%">
  152. <tr>
  153. <th align="Left" valign="bottom" width=33% bgcolor="#C0C0C0"><a name="Wildcards">To Search For</a></th>
  154. <th align="Left" valign="bottom" width=33% bgcolor="#C0C0C0"><a name="Wildcards">Example</a></th>
  155. <th align="Left" valign="bottom" width=33% bgcolor="#C0C0C0"><a name="Wildcards">Results</a></th></tr>
  156. <tr>
  157. <td valign="top"><a name="Wildcards">Words with the same prefix</a></td>
  158. <td valign="top"><a name="Wildcards"><font size="3" face="Courier"><code>comput*</code></font></a></td>
  159. <td valign="top"><a name="Wildcards">Pages with words that have the prefix
  160. &#147;comput,&#148; such as &#147;computer,&#148; &#147;computing,&#148;
  161. and so on</a></td>
  162. </tr>
  163. <tr>
  164. <td valign="top"><a name="Wildcards">Words based on the same stem word</a></td>
  165. <td valign="top"><a name="Wildcards"><font size="3" face="Courier"><code>fly**</code></font></a></td>
  166. <td valign="top"><a name="Wildcards">Pages with words based on the same stem as
  167. &#147;fly,&#148; such as &#147;flying,&#148; &#147;flown,&#148; &#147;flew,&#148; and
  168. so on </a></td>
  169. </tr>
  170. </table>
  171. <h1><a name="FreeTextQueries">Free-Text Queries</a></h1>
  172. <p><a name="FreeTextQueries">The query engine finds pages that best match the words and phrases in a free-text query. This is done by automatically finding pages that match the meaning, not the exact wording, of the query. Boolean, proximity, and wildcard operators are ignored within a free-text query. Free-text queries are prefixed with $contents.</a></p>
  173. <table border="1" cellpadding="4" cellspacing="1" width="100%">
  174. <tr><th align="Left" valign="bottom" width=33% bgcolor="#C0C0C0"><a name="FreeTextQueries">To Search For</a></th>
  175. <th align="Left" valign="bottom" width=33% bgcolor="#C0C0C0"><a name="FreeTextQueries">Example </a></th>
  176. <th align="Left" valign="bottom" width=33% bgcolor="#C0C0C0"><a name="FreeTextQueries">Results</a></th>
  177. </tr>
  178. <tr>
  179. <td valign="top"><a name="FreeTextQueries">Files that match free-text</a></td>
  180. <td valign="top"><a name="FreeTextQueries"><font size="3" face="Courier"><code>$contents how do I print in
  181. Microsoft Excel? </code></font></a></td>
  182. <td valign="top"><a name="FreeTextQueries">Pages that mention printing and Microsoft
  183. Excel.</a></td>
  184. </tr>
  185. </table>
  186. <h1><a name="VectorQueries">Vector Space Queries</a></h1>
  187. <p>The query engine supports vector space queries. Vector queries return pages that match a list of words and phrases. The rank of each page indicates how well the page matched the query. </p>
  188. <table border="1" cellpadding="4" cellspacing="1" width="100%">
  189. <tr>
  190. <th align="Left" valign="bottom" width=33% bgcolor="#C0C0C0">To Search For</th>
  191. <th align="Left" valign="bottom" width=33% bgcolor="#C0C0C0">Example</th>
  192. <th align="Left" valign="bottom" width=33% bgcolor="#C0C0C0">Results</th></tr>
  193. <tr>
  194. <td valign="top">Pages that contain specific words</td>
  195. <td valign="top"><font size="3" face="Courier"><code>light, bulb</code></font></td>
  196. <td valign="top">Files with words that best match the words
  197. being searched for</td>
  198. </tr>
  199. <tr>
  200. <td valign="top">Pages that contain weighted prefixes, words,
  201. and phrases</td>
  202. <td valign="top"><font size="3" face="Courier"><code>invent*, light[50], bulb[10],
  203. &quot;light bulb&quot;[400]</code></font></td>
  204. <td valign="top">Files that contain words prefixed by &#147;invent,&#148;
  205. the words &#147;light,&#148; &#147;bulb,&#148; and the phrase
  206. &#147;light bulb&#148; (the terms are weighted)</td>
  207. </tr>
  208. </table>
  209. <p>&nbsp;<!-- </p> --><br>
  210. <ul>
  211. <li>Components in vector queries are separated by commas. </li>
  212. <li>Components in vector queries can be weighted by using the [weight] syntax. </li>
  213. <li>Pages returned by vector queries do not necessarily match every term in the query. </li>
  214. <li>Vector queries work best when the results are sorted by rank. </li>
  215. </ul>
  216. <h1><a name="PropertyValueQueries">Property Value Queries</a></h1>
  217. <p>With property value queries, you can find files that have property values that match a given criteria. The properties over which you can query include basic file information like file name and file size, and ActiveX properties including the document summary (information) that is stored in files created by ActiveX-aware applications.</p>
  218. <p>There are two types of property queries:</p>
  219. <ul>
  220. <li><a name="PropertyValueQueries"><em>Relational property queries</em> consist of an &#147;at&#148; character (@), a </a><a href="#PropertyNames">property name</a>, a <a href="#RelationalOperators">relational operator</a>, and a <a href="#PropertyValues">property value</a>. For example, to find all of the files larger than one million bytes, issue the query @size &gt; 1000000.</li>
  221. <li><em>Regular expression property queries</em> consist of a number sign (#), a property name, and a <a href="#RegularExpressions">regular expression</a> for the property value. For example, to find to find all of the video (.avi) files, issue the query #filename *.avi. Regular expressions will never match the special properties contents (#contents) and all (#all). Properties that are not retrievable at query time cannot be used in # queries. these include HTML META properties not stored in the property cache.</li>
  222. </ul>
  223. <p>This section covers the following topics:</p>
  224. <ul>
  225. <li><a href="#PropertyNames">Property Names</a></li>
  226. <li><a href="#RelationalOperators">Relational Operators</a></li>
  227. <li><a href="#PropertyValues">Property Values</a></li>
  228. </ul>
  229. <h2><a name="PropertyNames">Property Names</a></h2>
  230. <p>Property names are preceded by either the &#147;at&#148; (@) or number sign (#) character. Use @ for relational queries, and # for regular expression queries.</p>
  231. <p>If no property name is specified, <em>@contents</em> is assumed.</p>
  232. <p>Properties available for all files include:</p>
  233. <table border="1" cellpadding="4" cellspacing="1" width="100%">
  234. <tr>
  235. <th align="Left" valign="bottom" bgcolor="#C0C0C0" width="40%">Property Name</th>
  236. <th align="Left" valign="bottom" bgcolor="#C0C0C0" width="60%">Description</th></tr>
  237. <tr>
  238. <td valign="top">All</td>
  239. <td valign="top">Matches words, phrases, and any property</td>
  240. </tr>
  241. <tr>
  242. <td valign="top">Contents</td>
  243. <td valign="top">Words and phrases in the file</td>
  244. </tr>
  245. <tr>
  246. <td valign="top">Filename</td>
  247. <td valign="top">Name of the file</td>
  248. </tr>
  249. <tr>
  250. <td valign="top">Size</td>
  251. <td valign="top">File size</td>
  252. </tr>
  253. <tr>
  254. <td valign="top">Write</td>
  255. <td valign="top">Last time the file was modified</td>
  256. </tr>
  257. </table>
  258. <p>ActiveX property values can also be used in queries. Web sites with files created by most ActiveX-aware applications can be queried for these properties:</p>
  259. <table border="1" cellpadding="4" cellspacing="1" width="100%">
  260. <tr>
  261. <th align="Left" valign="bottom" bgcolor="#C0C0C0" width="40%">Property Name </th>
  262. <th align="Left" valign="bottom" bgcolor="#C0C0C0" width="60%">Description</th></tr>
  263. <tr>
  264. <td valign="top">DocTitle</td>
  265. <td valign="top">Title of the document</td>
  266. </tr>
  267. <tr>
  268. <td valign="top">DocSubject</td>
  269. <td valign="top">Subject of the document </td>
  270. </tr>
  271. <tr>
  272. <td valign="top">DocAuthor</td>
  273. <td valign="top">The document&#146;s author </td>
  274. </tr>
  275. <tr>
  276. <td valign="top">DocKeywords</td>
  277. <td valign="top">Keywords for the document </td>
  278. </tr>
  279. <tr>
  280. <td valign="top">DocComments</td>
  281. <td valign="top">Comments about the document </td>
  282. </tr>
  283. </table>
  284. <p>For a complete list of property names, see the <a href="#PropertyNamesList">List of Property Names</a> later on this page.</p>
  285. <h2><a name="RelationalOperators">Relational Operators</a></h2>
  286. <p>Relational operators are used in relational property queries. </p>
  287. <table border="1" cellpadding="4" cellspacing="1" width="100%">
  288. <tr>
  289. <th align="Left" valign="bottom" bgcolor="#C0C0C0" width=33%>To Search For</th>
  290. <th align="Left" valign="bottom" bgcolor="#C0C0C0" width=33%>Example</th>
  291. <th align="Left" valign="bottom" bgcolor="#C0C0C0" width=33%>Results</th></tr>
  292. <tr>
  293. <td valign="top">Property values in relation to a fixed value </td>
  294. <td valign="top"><font size="3" face="Courier"><code>@size &lt; 100 <br>
  295. @size &lt;= 100 <br>
  296. @size = 100 <br>
  297. @size != 100 <br>
  298. @size &gt;= 100 <br>
  299. @size &gt; 100 </code></font></td>
  300. <td valign="top">Files whose size matches the query</td>
  301. </tr>
  302. <tr>
  303. <td valign="top">Property values with all of a set of bits on </td>
  304. <td valign="top"><font size="3" face="Courier"><code>@attrib ^a 0x820</code></font></td>
  305. <td valign="top">Compressed files with the archive bit on </td>
  306. </tr>
  307. <tr>
  308. <td valign="top">Property values with some of a set of bits on </td>
  309. <td valign="top"><font size="3" face="Courier"><code>@attrib ^s 0x20</code></font></td>
  310. <td valign="top">Files with the archive bit on </td>
  311. </tr>
  312. </table>
  313. <h2><a name="PropertyValues">Property Values</a></h2>
  314. <table border="1" cellpadding="4" cellspacing="1" width="100%">
  315. <tr>
  316. <th align="Left" valign="bottom" bgcolor="#C0C0C0" width="130">To Search For</th>
  317. <th align="Left" valign="bottom" bgcolor="#C0C0C0" width="200">Example</th>
  318. <th align="Left" valign="bottom" bgcolor="#C0C0C0" width="170">Results</th></tr>
  319. <tr>
  320. <td valign="top">A specific value</td>
  321. <td valign="top"><font size="3" face="Courier"><code>@DocAuthor = Bill Barnes </code></font></td>
  322. <td valign="top">Files authored by &#147;Bill Barnes&#148;</td>
  323. </tr>
  324. <tr>
  325. <td valign="top">Values beginning with a prefix</td>
  326. <td valign="top"><font size="3" face="Courier"><code>#DocAuthor George* </code></font></td>
  327. <td valign="top">Files whose author property begins with
  328. &#147;George&#148; </td>
  329. </tr>
  330. <tr>
  331. <td valign="top">Files with any of a set of extensions</td>
  332. <td valign="top"><font size="3" face="Courier"><code>#filename *.|(exe|,dll|,sys|) </code></font></td>
  333. <td valign="top">Files with .exe, .dll, or .sys extensions </td>
  334. </tr>
  335. <tr>
  336. <td valign="top">Files modified after a certain date</td>
  337. <td valign="top"><font size="3" face="Courier"><code>@write &gt; 96/2/14 10:00:00</code></font></td>
  338. <td valign="top">Files modified after February 14, 1996 at 10:00
  339. GMT</td>
  340. </tr>
  341. <tr>
  342. <td valign="top">Files modified after a relative date</td>
  343. <td valign="top"><font size="3" face="Courier"><code>@write &gt; -1d2h</code></font></td>
  344. <td valign="top">Files modified in the last 26 hours</td>
  345. </tr>
  346. <tr>
  347. <td valign="top">Vectors matching a vector</td>
  348. <td valign="top"><font size="3" face="Courier"><code>@vectorprop = { 10, 15, 20 }</code></font></td>
  349. <td valign="top">ActiveX documents with a vectorprop value
  350. of { 10, 15, 20 }</td>
  351. </tr>
  352. <tr>
  353. <td valign="top">Vectors where each value matches a criteria</td>
  354. <td valign="top"><font size="3" face="Courier"><code>@vectorprop &gt;^a 15</code></font></td>
  355. <td valign="top">ActiveX documents with a vectorprop value
  356. in which all values in the vector are greater
  357. than 15</td>
  358. </tr>
  359. <tr>
  360. <td valign="top">Vectors where at least one value matches a
  361. criteria</td>
  362. <td valign="top"><font size="3" face="Courier"><code>@vectorprop =^s 15</code></font></td>
  363. <td valign="top">ActiveX documents with a vectorprop value
  364. in which at least one value is 15</td>
  365. </tr>
  366. </table>
  367. <p>&nbsp;</p>
  368. <ul>
  369. <li>Be sure to use the pound (#) character before the property name when using a regular expression in a property value,
  370. and an &#147;at&#148; (@) character otherwise. The equal (=) relational operator is assumed for regular-expression queries.</li>
  371. <li>File name (#filename) is the only property that efficiently supports regular expressions with wildcards to the <em>left</em> of text.</li>
  372. <li>Date and time values are of the form <em>yyyy/mm/dd hh:mm:ss</em> or <EM>yyyy-mm-dd hh:mm:ss</EM>. The first two characters of the year and the entire time can be omitted. If you omit the first two characters of the year, then 29 or less is interpreted as the year 2000, and 30 or greater is interpreted as the year 1900. All dates and times are in Greenwich Mean Time (GMT).</li>
  373. <li>Dates and times relative to the current time can be expressed with a minus (-) character followed by zero or by more integer unit and time unit pairs. Time units are expressed as: (y) for years, (m) for months, (w) for weeks, (d) for days, (h) for hours, (n) for minutes, and (s) for seconds. A three-digit millisecond value can be optionally specified after the seconds value in date expressions. For example, 1997/12/8 10:10:03:452</li>
  374. <li>Currency values are of the form <em>x.y</em>, where <em>x</em> is the whole value amount and <em>y</em> is the fractional amount. There is no
  375. assumption about units.</li>
  376. <li>Boolean values are (t) or (true) for <strong>TRUE</strong> and (f) or (false) for <strong>FALSE</strong>.</li>
  377. <li>Vectors (VT_VECTOR) are expressed as an opening brace ({), followed by a comma-separated list of values, then a
  378. closing brace (}).</li>
  379. <li>Single-value expressions that are compared against vectors are expressed as a <a href="#RelationalOperators">relational operator</a>, then a (^a) for <em>all of</em>
  380. or a (^s) for <em>some of</em>.
  381. <li>Numeric values can be in decimal or hexadecimal (preceded by 0x).</li>
  382. <li>The <em>contents</em> property does not support relational operators. If a relational operator is specified, no results will be
  383. found. For example, @contents Microsoft will find documents containing Microsoft, but @contents<strong>=</strong>Microsoft
  384. will find none. </li>
  385. </ul>
  386. <h3><a name="RegularExpressions">Regular Expressions</a></h3>
  387. <p>Regular expressions in property queries are defined as follows: </p>
  388. <ul>
  389. <li>Any character except asterisk (*), period (.), question mark (?), and vertical bar (|) defaults to matching just itself.</li>
  390. <li>Regular expressions can be enclosed in matching quotes (&#147;), and must be enclosed in quotes if they contain a space ( )
  391. or closing parenthesis ()).</li>
  392. <li>The characters *, ., and ? behave as they behave in Windows; they match any number of characters, match (.) or end
  393. of string, and match any one character, respectively.</li>
  394. <li>The character | is an escape character. After |, the following characters have special meaning:</li>
  395. <p>( opens a group. Must be followed by a matching ).<!--</p>--><br>
  396. <p>) closes a group. Must be preceded by a matching (. <!--</p>--><br>
  397. <p>[ opens a character class. Must be followed by a matching (un-escaped) ]. <!--</p>--><br>
  398. <p>{ opens a counted match. Must be followed by a matching }. <!--</p>--><br>
  399. <p>} closes a counted match. Must be preceded by a matching {. <!--</p>--><br>
  400. <p>, separates <strong>OR</strong> clauses. <!--</p>--><br>
  401. <p>* matches zero or more occurrences of the preceding expression.<!--</p>--><br>
  402. <p>? matches zero or one occurrences of the preceding expression.<!--</p>--><br>
  403. <p>+ matches one or more occurrences of the preceding expression. <!--</p>--><br>
  404. <p>Anything else, including |, matches itself.<!--</p>--><br>
  405. <li>Between square brackets ([]) the following characters have special meaning:</li>
  406. <p>^ matches everything but following classes. Must be the first character. <!--</p>--><br>
  407. <p>] matches ]. May only be preceded by ^, otherwise it closes the class. <!--</p>--><br>
  408. <p>- range operator. Preceded and followed by normal characters.<!--</p>--><br>
  409. <p>Anything else matches itself (or begins or ends a range at itself).<!--</p>--><br>
  410. <li>Between curly braces ({}) the following syntax applies:</li>
  411. <p>|{m|} matches exactly <em>m</em> occurrences of the preceding expression. (0 &lt; m &lt; 256). <!--</p>--><br>
  412. <p>|{m,|} matches at least <em>m</em> occurrences of the preceding expression. (1 &lt; m &lt; 256). <!--</p>--><br>
  413. <p>|{m,n|} matches between <em>m</em> and <em>n</em> occurrences of the preceding expression, inclusive. (0 &lt; m &lt; 256, 0 &lt; n &lt;
  414. 256).<!--</p>--><br>
  415. <li>To match *, ., and ?, enclose them in brackets (for example, |[*]sample will match &#147;*sample&#148;).</li>
  416. </ul>
  417. <h1><a name="Examples">Query Examples</a></h1>
  418. <table border="1" cellpadding="4" cellspacing="1" width="100%">
  419. <tr>
  420. <th align="Left" valign="bottom" bgcolor="#C0C0C0" width="40%">Example</th>
  421. <th align="Left" valign="bottom" bgcolor="#C0C0C0" width="60%">Results</th></tr>
  422. <tr>
  423. <td valign="top"><font size="3" face="Courier"><code>@size &gt; 1000000</code></font></td>
  424. <td valign="top">Pages larger than one million bytes</td>
  425. </tr>
  426. <tr>
  427. <td valign="top"><font size="3" face="Courier"><code>@write &gt; 95/12/23</code></font></td>
  428. <td valign="top">Pages modified after the date</td>
  429. </tr>
  430. <tr>
  431. <td valign="top"><font size="3" face="Courier"><code>Apple tree</code></font></td>
  432. <td valign="top">Pages with the phrase &#147;apple tree&#148;</td>
  433. </tr>
  434. <tr>
  435. <td valign="top"><font size="3" face="Courier"><code>&quot;apple tree&quot;</code></font></td>
  436. <td valign="top">Same as above</td>
  437. </tr>
  438. <tr>
  439. <td valign="top"><font size="3" face="Courier"><code>@contents apple tree</code></font></td>
  440. <td valign="top">Same as above</td>
  441. </tr>
  442. <tr>
  443. <td valign="top"><font size="3" face="Courier"><code>Microsoft and @size &gt; 1000000</code></font></td>
  444. <td valign="top">Pages with the word &#147;Microsoft&#148; that are larger than one million bytes</td>
  445. </tr>
  446. <tr>
  447. <td valign="top"><font size="3" face="Courier"><code>&quot;microsoft and @size &gt; 1000000&quot;</code></font></td>
  448. <td valign="top">Pages with the phrase specified (not the same as above)</td>
  449. </tr>
  450. <tr>
  451. <td valign="top"><font size="3" face="Courier"><code>#filename *.avi</code></font></td>
  452. <td valign="top">Video files (the # prefix is used because the query contains a regular expression)</td>
  453. </tr>
  454. <tr>
  455. <td valign="top"><font size="3" face="Courier"><code>@attrib ^s 32</code></font></td>
  456. <td valign="top">Pages with the archive attribute bit on</td>
  457. </tr>
  458. <tr>
  459. <td valign="top"><font size="3" face="Courier"><code>@docauthor = John Smith</code></font></td>
  460. <td valign="top">Pages with the given author</td>
  461. </tr>
  462. <tr>
  463. <td valign="top"><font size="3" face="Courier"><code>$contents why is the sky blue?</code></font></td>
  464. <td valign="top">Pages that match the query</td>
  465. </tr>
  466. <tr>
  467. <td valign="top"><font size="3" face="Courier"><code>@size &lt; 100 &amp; #filename *.gif</code></font></td>
  468. <td valign="top">Graphics Interchange Format (GIF) files less than 100 bytes in size</td>
  469. </tr>
  470. </table>
  471. <h1><a name="PropertyNamesList">List of Property Names</a></h1>
  472. <p>These properties are always available for queries. Additional properties may also be available depending on the configuration of the Web server.</p>
  473. <table border="1" cellpadding="4" cellspacing="1" width="100%">
  474. <tr>
  475. <th align="Left" valign="bottom" bgcolor="#C0C0C0" width="15%">Friendly Name</th>
  476. <th align="Left" valign="bottom" bgcolor="#C0C0C0" width="20%">Datatype</th>
  477. <th align="Left" valign="bottom" bgcolor="#C0C0C0" width="65%">Property</th></tr>
  478. <tr>
  479. <td valign="top">A_HRef</td>
  480. <td valign="top">DBTYPE_WSTR |
  481. DBTYPE_BYREF</td>
  482. <td valign="top" width=65%>Text of HTML HREF. This property name was created for Microsoft&#174; Site Server and corresponds with the Indexing Service property name HtmlHRef. <em>Can be queried but not retrieved.</em></td>
  483. </tr>
  484. <tr>
  485. <td valign="top">Access</td>
  486. <td valign="top">VT_FILETIME</td>
  487. <td valign="top" width=65%>Last time file was accessed.</td>
  488. </tr>
  489. <tr>
  490. <td valign="top">All</td><td valign="top">(not applicable)</td>
  491. <td valign="top" width=65%>Searches every property for a string. <em>Can be queried but not retrieved.</em></td>
  492. </tr>
  493. <tr>
  494. <td valign="top">AllocSize</td><td valign="top">DBTYPE_I8</td>
  495. <td valign="top" width=65%>Size of disk allocation for file.</td>
  496. </tr>
  497. <tr>
  498. <td valign="top">Attrib</td><td valign="top">DBTYPE_UI4</td>
  499. <td valign="top" width=65%>File attributes. Documented in Win32 SDK.</td>
  500. </tr>
  501. <tr>
  502. <td valign="top">ClassId</td><td valign="top">DBTYPE_GUID</td>
  503. <td valign="top" width=65%>Class ID of object, for example, WordPerfect, Word, and so on.</td>
  504. </tr>
  505. <tr>
  506. <td valign="top"><a name="Characterization">Characterization</a></td><td valign="top">DBTYPE_WSTR |
  507. DBTYPE_BYREF</td>
  508. <td valign="top" width=65%>Characterization, or abstract, of document. Computed by Indexing Service.</td>
  509. </tr>
  510. <tr>
  511. <td valign="top">Contents</td><td valign="top">(not applicable)</td>
  512. <td valign="top" width=65%>Main contents of file. <em>Can be queried but not retrieved.</em></td>
  513. </tr>
  514. <tr>
  515. <td valign="top">Create</td><td valign="top">VT_FILETIME</td>
  516. <td valign="top" width=65%>Time file was created.</td>
  517. </tr>
  518. <tr>
  519. <td valign="top">Directory</td><td valign="top">DBTYPE_WSTR |
  520. DBTYPE_BYREF</td>
  521. <td valign="top" width=65%>Physical path to the file, not including the file name.</td>
  522. </tr>
  523. <tr>
  524. <td valign="top">DocAppName</td><td valign="top">DBTYPE_WSTR |
  525. DBTYPE_BYREF</td>
  526. <td valign="top" width=65%>Name of application that created the file.</td>
  527. </tr>
  528. <tr>
  529. <td valign="top">DocAuthor</td><td valign="top">DBTYPE_WSTR |
  530. DBTYPE_BYREF</td>
  531. <td valign="top" width=65%>Author of document.</td>
  532. </tr>
  533. <tr>
  534. <td>DocByteCount</td><td>DBTYPE_14</td><td>Number of bytes in a document.</td>
  535. </tr>
  536. <tr>
  537. <td>DocCategory</td><td>DBTYPE_STR |
  538. DBTYPE_BYREF</td><td>Type of document such as a memo, schedule, or whitepaper.</td>
  539. </tr>
  540. <tr>
  541. <td valign="top">DocCharCount</td><td valign="top">DBTYPE_I4</td>
  542. <td valign="top" width=65%>Number of characters in document.</td>
  543. </tr>
  544. <tr>
  545. <td valign="top">DocComments</td><td valign="top">DBTYPE_WSTR |
  546. DBTYPE_BYREF</td>
  547. <td valign="top" width=65%>Comments about document.</td>
  548. </tr>
  549. <tr>
  550. <td>DocCompany</td><td>DBTYPE_STR |
  551. DBTYPE_BYREF</td><td>Name of the company for which the document was written.</td>
  552. </tr>
  553. <tr>
  554. <td valign="top">DocCreatedTm</td><td valign="top">VT_FILETIME</td>
  555. <td valign="top" width=65%>Time document was created.</td>
  556. </tr>
  557. <tr>
  558. <td valign="top">DocEditTime</td><td valign="top">VT_FILETIME</td>
  559. <td valign="top" width=65%>Total time spent editing document.</td>
  560. </tr>
  561. <tr>
  562. <td>DocHiddenCount</td><td>DBTYPE_14</td><td>Number of hidden slides in a Microsoft&#174; PowerPoint document.</td>
  563. </tr>
  564. <tr>
  565. <td valign="top">DocKeywords</td><td valign="top">DBTYPE_WSTR |
  566. DBTYPE_BYREF</td>
  567. <td valign="top" width=65%>Document keywords.</td>
  568. </tr>
  569. <tr>
  570. <td valign="top">DocLastAuthor</td><td valign="top">DBTYPE_WSTR |
  571. DBTYPE_BYREF</td>
  572. <td valign="top" width=65%>Most recent user who edited document.</td>
  573. </tr>
  574. <tr>
  575. <td valign="top">DocLastPrinted</td><td valign="top">VT_FILETIME</td>
  576. <td valign="top" width=65%>Time document was last printed.</td>
  577. </tr>
  578. <tr>
  579. <td valign="top">DocLastSavedTm</td><td valign="top">VT_FILETIME</td>
  580. <td valign="top" width=65%>Time document was last saved.</td>
  581. </tr>
  582. <tr>
  583. <td>DocLineCount</td><td>DBTYPE_14</td><td>Number of lines contained in a document.</td>
  584. </tr>
  585. <tr>
  586. <td>DocManager</td><td>DBTYPE_STR |
  587. DBTYPE_BYREF</td><td>Name of the manager of the document&#146;s author.</td>
  588. </tr>
  589. <tr>
  590. <td>DocNoteCount</td><td>DBTYPE_14</td><td>Number of pages with notes in a PowerPoint document.</td>
  591. </tr>
  592. <tr>
  593. <td valign="top">DocPageCount</td><td valign="top">DBTYPE_I4</td>
  594. <td valign="top" width=65%>Number of pages in document.</td>
  595. </tr>
  596. <tr>
  597. <td>DocParaCount</td><td>DBTYPE_14</td><td>Number of paragraphs in a document.</td>
  598. </tr>
  599. <tr>
  600. <td>DocPartTitles</td><td>DBTYPE_STR | DBTYPE_VECTOR</td><td>Names of document parts. For example, in Excel part titles are the names of spread sheets, in PowerPoint slide titles, and in Word for Windows the names of the documents in the master document.</td>
  601. </tr>
  602. <tr>
  603. <td>DocPresentationTarget</td><td>DBTYPE_STR|DBTYPE_BYREF</td><td>Target format (35mm, printer, video, and so on) for a presentation in PowerPoint.</td>
  604. </tr>
  605. <tr>
  606. <td valign="top">DocRevNumber</td><td valign="top">DBTYPE_WSTR |
  607. DBTYPE_BYREF</td>
  608. <td valign="top" width=65%>Current version number of document.</td>
  609. </tr>
  610. <tr>
  611. <td>DocSlideCount</td><td>DBTYPE_14</td><td>Number of slides in a PowerPoint document.</td>
  612. </tr>
  613. <tr>
  614. <td valign="top">DocSubject</td><td valign="top">DBTYPE_WSTR |
  615. DBTYPE_BYREF</td>
  616. <td valign="top" width=65%>Subject of document.</td>
  617. </tr>
  618. <tr>
  619. <td valign="top">DocTemplate</td><td valign="top">DBTYPE_WSTR |
  620. DBTYPE_BYREF</td>
  621. <td valign="top" width=65%>Name of template for document.</td>
  622. </tr>
  623. <tr>
  624. <td valign="top"><a name="DocTitle">DocTitle</a></td><td valign="top">DBTYPE_WSTR |
  625. DBTYPE_BYREF</td>
  626. <td valign="top" width=65%>Title of document.</td>
  627. </tr>
  628. <tr>
  629. <td valign="top">DocWordCount</td><td valign="top">DBTYPE_I4</td>
  630. <td valign="top" width=65%>Number of words in document.</td>
  631. </tr>
  632. <tr>
  633. <td valign="top">FileIndex</td><td valign="top">DBTYPE_I8</td>
  634. <td valign="top" width=65%>Unique ID of file.</td>
  635. </tr>
  636. <tr>
  637. <td valign="top"><a name="FileName">FileName</a></td><td valign="top">DBTYPE_WSTR |
  638. DBTYPE_BYREF</td>
  639. <td valign="top" width=65%>Name of file.</td>
  640. </tr>
  641. <tr>
  642. <td valign="top">HitCount</td><td valign="top">DBTYPE_I4</td>
  643. <td valign="top" width=65%>Number of hits (words matching query) in file.</td>
  644. </tr>
  645. <tr>
  646. <td valign="top">HtmlHRef</td><td valign="top">DBTYPE_WSTR |
  647. DBTYPE_BYREF</td>
  648. <td valign="top" width=65%>Text of HTML HREF. <em>Can be queried but not retrieved.</em></td>
  649. </tr>
  650. <tr>
  651. <td valign="top">HtmlHeading1</td><td valign="top">DBTYPE_WSTR |
  652. DBTYPE_BYREF</td>
  653. <td valign="top" width=65%>Text of HTML document in style H1. <em>Can be queried but not retrieved.</em></td>
  654. </tr>
  655. <tr>
  656. <td valign="top">HtmlHeading2</td><td valign="top">DBTYPE_WSTR |
  657. DBTYPE_BYREF</td>
  658. <td valign="top" width=65%>Text of HTML document in style H2. <em>Can be queried but not retrieved.</em></td>
  659. </tr>
  660. <tr>
  661. <td valign="top">HtmlHeading3</td><td valign="top">DBTYPE_WSTR |
  662. DBTYPE_BYREF</td>
  663. <td valign="top" width=65%>Text of HTML document in style H3. <em>Can be queried but not retrieved.</em></td>
  664. </tr>
  665. <tr>
  666. <td valign="top">HtmlHeading4</td><td valign="top">DBTYPE_WSTR |
  667. DBTYPE_BYREF</td>
  668. <td valign="top" width=65%>Text of HTML document in style H4. <em>Can be queried but not retrieved.</em></td>
  669. </tr>
  670. <tr>
  671. <td valign="top">HtmlHeading5</td><td valign="top">DBTYPE_WSTR |
  672. DBTYPE_BYREF</td>
  673. <td valign="top" width=65%>Text of HTML document in style H5. <em>Can be queried but not retrieved.</em></td>
  674. </tr>
  675. <tr>
  676. <td valign="top">HtmlHeading6</td><td valign="top">DBTYPE_WSTR |
  677. DBTYPE_BYREF</td>
  678. <td valign="top" width=65%>Text of HTML document in style H6. <em>Can be queried but not retrieved.</em></td>
  679. </tr>
  680. <tr>
  681. <td valign="top">Img_Alt</td>
  682. <td valign="top">DBTYPE_WSTR | DBTYPE_BYREF</td>
  683. <td valign="top" width=65%>Alternate text for &lt;IMG&gt; tags. <em>Can be queried but not retrieved.</em></td>
  684. </tr>
  685. <tr>
  686. <td valign="top"><a name="Path">Path</a></td><td valign="top">DBTYPE_WSTR |
  687. DBTYPE_BYREF</td>
  688. <td valign="top" width=65%>Full physical path to file, including file name.</td>
  689. </tr>
  690. <tr>
  691. <td valign="top">Rank</td><td valign="top">DBTYPE_I4</td>
  692. <td valign="top" width=65%>Rank of row. Ranges from 0 to 1000. Larger numbers indicate better matches.</td>
  693. </tr>
  694. <tr>
  695. <td valign="top">RankVector</td><td valign="top">DBTYPE_I4 |
  696. DBTYPE_VECTOR</td>
  697. <td valign="top" width=65%>Ranks of individual components of a <a href="#VectorQueries">vector query</a>.</td>
  698. </tr>
  699. <tr>
  700. <td valign="top">ShortFileName</td><td valign="top">DBTYPE_WSTR |
  701. DBTYPE_BYREF</td>
  702. <td valign="top" width=65%>Short (8.3) file name.</td>
  703. </tr>
  704. <tr>
  705. <td valign="top">Size</td><td valign="top">DBTYPE_I8</td>
  706. <td valign="top" width=65%>Size of file, in bytes.</td>
  707. </tr>
  708. <tr>
  709. <td valign="top">USN</td><td valign="top">DBTYPE_I8</td>
  710. <td valign="top" width=65%>Update Sequence Number. NTFS drives only.</td>
  711. </tr>
  712. <tr>
  713. <td valign="top"><a name="VPath">VPath</a></td><td valign="top">DBTYPE_WSTR |
  714. DBTYPE_BYREF</td>
  715. <td valign="top" width=65%>Full virtual path to file, including file name. If more than one possible path, then the best
  716. match for the specific query is chosen.</td>
  717. </tr>
  718. <tr>
  719. <td valign="top">WorkId</td><td valign="top">DBTYPE_I4</td>
  720. <td valign="top" width=65%>Internal ID for file. Used within Indexing Service.</td>
  721. </tr>
  722. <tr>
  723. <td valign="top">Write</td><td valign="top">VT_FILETIME</td>
  724. <td valign="top" width=65%>Last time file was written.</td>
  725. </tr>
  726. </table>
  727. <h2><a name="DefiningNewPropertyNames">Defining New Property Names</a></h2>
  728. <p>To define properties that are not in the previous list, you must list them in a [Names] section in the .idq file. To use these properties in a restriction, sort specification, or as a retrieved column, you have define them in the .idq file, using the following format:</p>
  729. <p>[Names]<br>
  730. #Properties that are not in the standard list<br>
  731. <em>Propertyname</em> ( <em>Datatype </em>) = <em>GUID</em> ["<em>Name</em>" | <em>propid</em>]<br>
  732. </p>
  733. <p>In the syntax, <em>"Name"</em> is the property name (<strong>"Sales"</strong> in the following example), and <em>propid</em> is the property ID in hexadecimal. Note that you need to surround the friendly name with quotation marks, but the property ID does not take quotation marks.</p>
  734. <p>For example, suppose you want to define an HTML meta tag as a property name that somebody can search for. The property you want to define is <strong>Sales</strong>.</p>
  735. <p><big>To define the <strong>Sales</strong> property</big><!--</p>--><br>
  736. <ol>
  737. <li>In the .idq file, under the [Names] section, add the following line.</li>
  738. <p>MetaDescription(DBTYPE_WSTR) = d1b5d3f0-c0b3-11cf-9a92-00a0c908dbf1 "Sales"<!--</p>--><br>
  739. <p>The GUID number comes from the <strong>MetaTagClsid</strong> parameter in the registry, at the following location:<!--</p>--><br>
  740. <pre><font size="3" face="Courier">HKEY_LOCAL_MACHINE
  741. \SYSTEM
  742. &nbsp;\CurrentControlSet
  743. &nbsp;&nbsp;\Control
  744. &nbsp;&nbsp;&nbsp;\HtmlFilter
  745. &nbsp;&nbsp;&nbsp;&nbsp;\MetaTagClsid</font></pre>
  746. <li>Then, in the HTML files where you want the tag to appear, define the meta description.</li>
  747. <p>For example, say you want to search for all files that give sales projections for the future:<!--</p>--><br>
  748. <p>In File1.htm:<!--</p>--><br>
  749. <p>&lt;META NAME="Sales" CONTENT="Projections for 1998"&gt;<!--</p>--><br>
  750. <p>In File2.htm:<!--</p>--><br>
  751. <p>&lt;META NAME="Sales" CONTENT="Projections for 1999"&gt;<!--</p>--><br>
  752. <p>In File3.htm:<!--</p>--><br>
  753. <p>&lt;META NAME="Sales" CONTENT="Sales in 1997"&gt;<!--</p>--><br>
  754. </ol>
  755. <p><strong>Note</strong>&nbsp;&nbsp;&nbsp;Be sure to add your META NAME tags between the &lt;head&gt; and &lt;/head&gt; HTML tags at the beginning of the file.</p>
  756. <p>You can now search for all files that show sales projections. Send the following query:</p>
  757. <p>@metadescription projections<!--</p>--><br>
  758. <p>This query returns all the files with the word <em>projections</em> in the CONTENT field of the meta tag. In this example, File1.htm and File2.htm are returned.</p>
  759. <p>But suppose you want to search for sales by year, for example a list of sales in 1997. Send the following query:</p>
  760. <p>@metadescription 1997<!--</p>--><br>
  761. <p>File3.htm is returned.</p>
  762. <hr class="iis" size="1">
  763. <p align="center"><em><a href="/iishelp/common/colegal.htm">&copy; 1997-1999 by Microsoft Corporation. All rights reserved.</a></em></p>
  764. </font>
  765. </body>
  766. </html>