Sophie

Sophie

distrib > Fedora > 14 > x86_64 > media > updates > by-pkgid > 71d40963b505df4524269198e237b3e3 > files > 1079

virtuoso-opensource-doc-6.1.4-2.fc14.noarch.rpm

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html>
 <head profile="http://internetalchemy.org/2003/02/profile">
  <link rel="foaf" type="application/rdf+xml" title="FOAF" href="http://www.openlinksw.com/dataspace/uda/about.rdf" />
  <link rel="schema.dc" href="http://purl.org/dc/elements/1.1/" />
  <meta name="dc.title" content="Function: substring - Virtuoso Functions Guide" />
  <meta name="dc.subject" content="Function: substring - Virtuoso Functions Guide" />
  <meta name="dc.creator" content="OpenLink Software Documentation Team ;&#10;" />
  <meta name="dc.copyright" content="OpenLink Software, 1999 - 2009" />
  <link rel="top" href="index.html" title="OpenLink Virtuoso Universal Server: Documentation" />
  <link rel="search" href="/doc/adv_search.vspx" title="Search OpenLink Virtuoso Universal Server: Documentation" />
  <link rel="parent" href="functions.html" title="Chapter Contents" />
  <link rel="prev" href="appendixa.html" title="Appendix" />
  <link rel="next" href="functions.html#.html" title="" />
  <link rel="shortcut icon" href="../images/misc/favicon.ico" type="image/x-icon" />
  <link rel="stylesheet" type="text/css" href="doc.css" />
  <link rel="stylesheet" type="text/css" href="/doc/translation.css" />
  <title>Function: substring - Virtuoso Functions Guide</title>
  <meta http-equiv="Content-Type" content="text/xhtml; charset=UTF-8" />
  <meta name="author" content="OpenLink Software Documentation Team ;&#10;" />
  <meta name="copyright" content="OpenLink Software, 1999 - 2009" />
  <meta name="keywords" content="" />
  <meta name="GENERATOR" content="OpenLink XSLT Team" />
 </head>
 <body>
  <div id="header">
    <a name="xpf_substring" />
    <img src="../images/misc/logo.jpg" alt="" />
    <h1>22. Virtuoso Functions Guide - substring</h1>
  </div>
  <div id="navbartop">
   <div>
      <a class="link" href="functions.html">Chapter Contents</a> | <a class="link" href="xpf_string_length.html" title="string-length">Prev</a> | <a class="link" href="xpf_substring_after.html" title="substring-after">Next</a>
   </div>
  </div>
  <div id="currenttoc">
   <form method="post" action="/doc/adv_search.vspx">
    <div class="search">Keyword Search: <br />
        <input type="text" name="q" /> <input type="submit" name="go" value="Go" />
    </div>
   </form>
   <div>
      <a href="http://www.openlinksw.com/">www.openlinksw.com</a>
   </div>
   <div>
      <a href="http://docs.openlinksw.com/">docs.openlinksw.com</a>
   </div>
    <br />
   <div>
      <a href="index.html">Book Home</a>
   </div>
    <br />
   <div>
      <a href="contents.html">Contents</a>
   </div>
   <div>
      <a href="preface.html">Preface</a>
   </div>
    <br />
   <div>
      <a class="selected" href="functions.html">Virtuoso Functions Guide</a>
   </div>
    <br />
   <div>
      <a href="functions.html#admin">Administration</a>
   </div>
   <div>
      <a href="functions.html#aggr">Aggregate Functions</a>
   </div>
   <div>
      <a href="functions.html#array">Array Manipulation</a>
   </div>
   <div>
      <a href="functions.html#bpel">BPEL APIs</a>
   </div>
   <div>
      <a href="functions.html#backup">Backup</a>
   </div>
   <div>
      <a href="functions.html#compression">Compression</a>
   </div>
   <div>
      <a href="functions.html#cursors">Cursor</a>
   </div>
   <div>
      <a href="functions.html#time">Date &amp; Time Manipulation</a>
   </div>
   <div>
      <a href="functions.html#debug">Debug</a>
   </div>
   <div>
      <a href="functions.html#dict">Dictionary Manipulation</a>
   </div>
   <div>
      <a href="functions.html#encoding">Encoding &amp; Decoding</a>
   </div>
   <div>
      <a href="functions.html#file">File Manipulation</a>
   </div>
   <div>
      <a href="functions.html#ft">Free Text</a>
   </div>
   <div>
      <a href="functions.html#hash">Hashing / Cryptographic</a>
   </div>
   <div>
      <a href="functions.html#ldap">LDAP</a>
   </div>
   <div>
      <a href="functions.html#localization">Locale</a>
   </div>
   <div>
      <a href="functions.html#mail">Mail</a>
   </div>
   <div>
      <a href="functions.html#misc">Miscellaneous</a>
   </div>
   <div>
      <a href="functions.html#number">Number</a>
   </div>
   <div>
      <a href="functions.html#phrz">Phrases</a>
   </div>
   <div>
      <a href="functions.html#rdf">RDF data</a>
   </div>
   <div>
      <a href="functions.html#rmt">Remote SQL Data Source</a>
   </div>
   <div>
      <a href="functions.html#repl">Replication</a>
   </div>
   <div>
      <a href="functions.html#soap">SOAP</a>
   </div>
   <div>
      <a href="functions.html#sql">SQL</a>
   </div>
   <div>
      <a href="functions.html#string">String</a>
   </div>
   <div>
      <a href="functions.html#txn">Transaction</a>
   </div>
   <div>
      <a href="functions.html#type">Type Mapping</a>
   </div>
   <div>
      <a href="functions.html#uddi">UDDI</a>
   </div>
   <div>
      <a href="functions.html#udt">User Defined Types &amp; The CLR</a>
   </div>
   <div>
      <a href="functions.html#vad">VAD</a>
   </div>
   <div>
      <a href="functions.html#jvmpl">Virtuoso Java PL API</a>
   </div>
   <div>
      <a href="functions.html#bif">Virtuoso Server Extension Interface (VSEI)</a>
   </div>
   <div>
      <a href="functions.html#ws">Web &amp; Internet</a>
   </div>
   <div>
      <a href="functions.html#xml">XML</a>
   </div>
   <div>
      <a class="selected" href="functions.html#XPATH">XPATH &amp; XQUERY</a>
   </div>
   <div class="selected">
    <div>
        <a href="xpf_and.html">and</a>
    </div>
    <div>
        <a href="xpf_append.html">append</a>
    </div>
    <div>
        <a href="xpf_assign.html">assign</a>
    </div>
    <div>
        <a href="xpf_avg.html">avg</a>
    </div>
    <div>
        <a href="xpf_boolean.html">boolean</a>
    </div>
    <div>
        <a href="xpf_ceiling.html">ceiling</a>
    </div>
    <div>
        <a href="xpf_concat.html">concat</a>
    </div>
    <div>
        <a href="xpf_contains.html">contains</a>
    </div>
    <div>
        <a href="xpf_count.html">count</a>
    </div>
    <div>
        <a href="xpf_create_attribute.html">create-attribute</a>
    </div>
    <div>
        <a href="xpf_create_comment.html">create-comment</a>
    </div>
    <div>
        <a href="xpf_create_element.html">create-element</a>
    </div>
    <div>
        <a href="xpf_create_pi.html">create-pi</a>
    </div>
    <div>
        <a href="xpf_current.html">current</a>
    </div>
    <div>
        <a href="xpf_distinct.html">distinct</a>
    </div>
    <div>
        <a href="xpf_doc.html">doc</a>
    </div>
    <div>
        <a href="xpf_document.html">document</a>
    </div>
    <div>
        <a href="xpf_document_literal.html">document-literal</a>
    </div>
    <div>
        <a href="xpf_empty.html">empty</a>
    </div>
    <div>
        <a href="xpf_ends_with.html">ends-with</a>
    </div>
    <div>
        <a href="xpf_every.html">every</a>
    </div>
    <div>
        <a href="xpf_except.html">except</a>
    </div>
    <div>
        <a href="xpf_false.html">false</a>
    </div>
    <div>
        <a href="xpf_filter.html">filter</a>
    </div>
    <div>
        <a href="xpf_floor.html">floor</a>
    </div>
    <div>
        <a href="xpf_collection.html">fn:collection</a>
    </div>
    <div>
        <a href="xpf_for.html">for</a>
    </div>
    <div>
        <a href="xpf_format_number.html">format-number</a>
    </div>
    <div>
        <a href="xpf_function_available.html">function-available</a>
    </div>
    <div>
        <a href="xpf_generate_id.html">generate-id</a>
    </div>
    <div>
        <a href="xpf_id.html">id</a>
    </div>
    <div>
        <a href="xpf_if.html">if</a>
    </div>
    <div>
        <a href="xpf_intersect.html">intersect</a>
    </div>
    <div>
        <a href="xpf_is_after.html">is_after()</a>
    </div>
    <div>
        <a href="xpf_is_before.html">is_before()</a>
    </div>
    <div>
        <a href="xpf_key.html">key</a>
    </div>
    <div>
        <a href="xpf_lang.html">lang</a>
    </div>
    <div>
        <a href="xpf_last.html">last</a>
    </div>
    <div>
        <a href="xpf_let.html">let</a>
    </div>
    <div>
        <a href="xpf_list.html">list()</a>
    </div>
    <div>
        <a href="xpf_local_name.html">local-name</a>
    </div>
    <div>
        <a href="xpf_max.html">max</a>
    </div>
    <div>
        <a href="xpf_min.html">min</a>
    </div>
    <div>
        <a href="xpf_name.html">name</a>
    </div>
    <div>
        <a href="xpf_namespace_uri.html">namespace-uri</a>
    </div>
    <div>
        <a href="xpf_normalize_space.html">normalize-space</a>
    </div>
    <div>
        <a href="xpf_not.html">not</a>
    </div>
    <div>
        <a href="xpf_number.html">number</a>
    </div>
    <div>
        <a href="xpf_or.html">or</a>
    </div>
    <div>
        <a href="xpf_position.html">position</a>
    </div>
    <div>
        <a href="xpf_processXQuery.html">processxquery</a>
    </div>
    <div>
        <a href="xpf_processXSLT.html">processxslt</a>
    </div>
    <div>
        <a href="xpf_processXSQL.html">processxsql</a>
    </div>
    <div>
        <a href="xpf_progn.html">progn()</a>
    </div>
    <div>
        <a href="xpf_replace.html">replace()</a>
    </div>
    <div>
        <a href="xpf_round.html">round</a>
    </div>
    <div>
        <a href="xpf_serialize.html">serialize</a>
    </div>
    <div>
        <a href="xpf_shallow.html">shallow</a>
    </div>
    <div>
        <a href="xpf_some.html">some</a>
    </div>
    <div>
        <a href="xpf_starts_with.html">starts-with</a>
    </div>
    <div>
        <a href="xpf_string.html">string</a>
    </div>
    <div>
        <a href="xpf_string_length.html">string-length</a>
    </div>
    <div>
        <a class="selected" href="xpf_substring.html">substring</a>
    </div>
    <div>
        <a href="xpf_substring_after.html">substring-after</a>
    </div>
    <div>
        <a href="xpf_substring_before.html">substring-before</a>
    </div>
    <div>
        <a href="xpf_sum.html">sum</a>
    </div>
    <div>
        <a href="xpf_system_property.html">system-property</a>
    </div>
    <div>
        <a href="xpf_text_contains.html">text_contains()</a>
    </div>
    <div>
        <a href="xpf_translate.html">translate</a>
    </div>
    <div>
        <a href="xpf_true.html">true</a>
    </div>
    <div>
        <a href="xpf_tuple.html">tuple()</a>
    </div>
    <div>
        <a href="xpf_union.html">union</a>
    </div>
    <div>
        <a href="xpf_unordered.html">unordered</a>
    </div>
    <div>
        <a href="xpf_unparsed_entity_uri.html">unparsed-entity-uri</a>
    </div>
    <div>
        <a href="xpf_urlify.html">urlify</a>
    </div>
    <div>
        <a href="xpf_xmlview.html">xmlview</a>
    </div>
   </div>
    <br />
   <div>
      <a href="functionidx.html">Functions Index</a>
   </div>
    <br />
  </div>
  <div id="text">
    <h2>substring</h2>
    <div class="refpurpose">Returns the substring of the first argument starting at the position specified in the second argument with length specified in the third argument.</div>
    <div class="funcsynopsis">
        <span class="funcdef">string <span class="function">substring</span>
      </span>
	(<span class="paramdef">
        <span class="parameter">strg</span> string</span>, 
	<span class="paramdef">
        <span class="parameter">start</span> integer</span>, 
	<span class="paramdefoptional">[<span class="optional">length</span> integer]</span>);
      </div>
   
  
  
  <div class="refsect1">
      <div class="refsect1title">Description</div>
<p>
The substring() XPATH function returns the substring of the <span class="computeroutput">strg</span>
starting at the position specified in <span class="computeroutput">start</span> argument with length
specified in <span class="computeroutput">length</span> argument.
If <span class="computeroutput">length</span> is not specified,
it returns the substring starting at the position specified in the <span class="computeroutput">start</span> argument
and continuing to the end of the string.
</p>
<p>
XPATH 1.0 defines that &quot;each character in the string... is considered to have a numeric position: the position of the first character is 1, the position of the second character is 2 and so on.
This differs from Java and ECMAScript, in which the String.substring method treats the position of the first character as 0.&quot;
The returned substring contains those characters for which the position of the character is greater than or equal to <span class="computeroutput">start</span> and,
if <span class="computeroutput">length</span> is specified, less than the sum of <span class="computeroutput">start</span> and <span class="computeroutput">length</span>.
</p>
<p>
If <span class="computeroutput">start</span> and/or <span class="computeroutput">length</span> are not integers,
they are converted to integers following rules for round() XPATH function, before doing any other processing.
So they will be rounded first, and the sum of rounded values will be used as &quot;end position&quot;
</p>
<p>
If <span class="computeroutput">start</span> is greater than or equal to the length of string, the empty string is returned.
If <span class="computeroutput">length</span> is specified and the sum of <span class="computeroutput">start</span> is less than or equal to 1, the empty string is returned, too.
Otherwise, the result string will contains some characters even if <span class="computeroutput">start</span> is less than 1.
</p>
<p>
If <span class="computeroutput">length</span> <span class="computeroutput">start</span> is greater than or equal to the length of string, the empty string is returned.
</p>
    </div>
  <div class="refsect1">
      <div class="refsect1title">Parameters</div>
    <div class="refsect2">
        <span class="refsect2title">strg – </span>
      Source string. If the argument is not a string, it is converted to string first.</div>
    <div class="refsect2">
        <span class="refsect2title">start – </span>
      Position of first character of the substring in the source string.</div>
    <div class="refsect2">
        <span class="refsect2title">length – </span>
      Number of characters in the substring, if specified.</div>
  </div>
  <div class="refsect1">
      <div class="refsect1title">Return Types</div>
      <p>String</p>
    </div>
  <div class="refsect1">
      <div class="refsect1title">Examples</div>
    <a name="xpf_ex_substring" />
      <div class="example">
        <div class="exampletitle" />
      <p>The following expressions are all true:</p>
      <div>
          <pre class="screen">
substring(&quot;12345&quot;, 2, 3) = &quot;234&quot;
substring(&quot;12345&quot;, 2) = &quot;2345&quot;
substring(&quot;12345&quot;, 1.5, 2.6) = &quot;234&quot;
substring(&quot;12345&quot;, 0, 3) = &quot;12&quot;
substring(&quot;12345&quot;, -2, 5) = &quot;12&quot;
substring(&quot;12345&quot;, -2) = &quot;12345&quot;
</pre>
        </div>
    </div>
  </div>
  <div class="refsect1">
      <div class="refsect1title">See Also</div>
    <p>
        <a href="xpf_substring_before.html">substring-before()</a>
        <a href="xpf_substring_after.html">substring-after()</a>
      </p>
  </div>
</div>
  <div id="footer">
    <div>Copyright© 1999 - 2009 OpenLink Software All rights reserved.</div>
   <div id="validation">
    <a href="http://validator.w3.org/check/referer">
        <img src="http://www.w3.org/Icons/valid-xhtml10" alt="Valid XHTML 1.0!" height="31" width="88" />
    </a>
    <a href="http://jigsaw.w3.org/css-validator/">
        <img src="http://jigsaw.w3.org/css-validator/images/vcss" alt="Valid CSS!" height="31" width="88" />
    </a>
   </div>
  </div>
 </body>
</html>