<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>SharePointBlog.nl &#187; SharePoint</title>
	<atom:link href="http://www.sharepointblog.nl/category/sharepoint/feed/" rel="self" type="application/rss+xml" />
	<link>http://www.sharepointblog.nl</link>
	<description>Michiel Lankamp</description>
	<lastBuildDate>Wed, 26 May 2010 09:37:26 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.0.1</generator>
		<item>
		<title>FullTextSqlQuery Exception from HRESULT: 0x80040E60</title>
		<link>http://www.sharepointblog.nl/2010/05/25/fulltextsqlquery-exception-from-hresult-0x80040e60/</link>
		<comments>http://www.sharepointblog.nl/2010/05/25/fulltextsqlquery-exception-from-hresult-0x80040e60/#comments</comments>
		<pubDate>Tue, 25 May 2010 22:09:16 +0000</pubDate>
		<dc:creator>Michiel</dc:creator>
				<category><![CDATA[SharePoint]]></category>
		<category><![CDATA[Exception]]></category>
		<category><![CDATA[FullTextSqlQuery]]></category>
		<category><![CDATA[Search]]></category>
		<category><![CDATA[SharePoint 2010]]></category>

		<guid isPermaLink="false">http://www.sharepointblog.nl/?p=52</guid>
		<description><![CDATA[After upgrading a webpart from SharePoint 2007 to 2010 I got a exception from de search engine about the query format. I used the following code: var sqlQuery = new FullTextSqlQuery(SPContext.Current.Site); sqlQuery.ResultTypes = ResultType.RelevantResults; sqlQuery.TrimDuplicates = false; sqlQuery.QueryText = "SELECT Path, Title FROM scope() ORDER BY Title"; // Return the search results to a ResultTableCollection. [...]]]></description>
			<content:encoded><![CDATA[<div class="tweetmeme_button" style="float: right; margin-left: 10px;">
			<a href="http://api.tweetmeme.com/share?url=http%3A%2F%2Fwww.sharepointblog.nl%2F2010%2F05%2F25%2Ffulltextsqlquery-exception-from-hresult-0x80040e60%2F"><br />
				<img src="http://api.tweetmeme.com/imagebutton.gif?url=http%3A%2F%2Fwww.sharepointblog.nl%2F2010%2F05%2F25%2Ffulltextsqlquery-exception-from-hresult-0x80040e60%2F&amp;source=m_lampje&amp;style=normal&amp;service=bit.ly" height="61" width="50" /><br />
			</a>
		</div>
<p>After upgrading a webpart from SharePoint 2007 to 2010 I got a exception from de search engine about the query format. I used the following code:</p>
<pre class="csharpcode">var sqlQuery = <span class="kwrd">new</span> FullTextSqlQuery(SPContext.Current.Site);
sqlQuery.ResultTypes = ResultType.RelevantResults;
sqlQuery.TrimDuplicates = <span class="kwrd">false</span>;
sqlQuery.QueryText = <span class="str">"SELECT Path, Title FROM scope() ORDER BY Title"</span>;

<span class="rem">// Return the search results to a ResultTableCollection.</span>
var results = sqlQuery.Execute();</pre>
<p>When I debugged the code I found out that the ORDER BY clause was causing the problem. When I used a integer or date managed property in the order by clause the problem disappeared. I started investigating the options for text managed properties, in the properties for a managed property I found a new option:</p>
<p><img style="display: inline; border: 0px;" title="image" src="http://www.sharepointblog.nl/wp-content/uploads/2010/05/image1.png" border="0" alt="image" width="499" height="31" /></p>
<p>The explanation for this option is:</p>
<blockquote><p>To reduce storage requirements, new text properties are automatically treated as a hash which limits comparisons <strong>(including sorting</strong>) to equality/inequality.  Unselect this option to enable other types of comparisons (less than, greater than, order by).</p></blockquote>
<p><span style="color: #666666;">When I enabled this option and started a full-crawl the problems are gone. In my opinion the error message should have been a bit more clearer.</span></p>
]]></content:encoded>
			<wfw:commentRss>http://www.sharepointblog.nl/2010/05/25/fulltextsqlquery-exception-from-hresult-0x80040e60/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>FieldRefs not working with XML comments</title>
		<link>http://www.sharepointblog.nl/2010/05/25/fieldrefs-not-working-with-xml-comments/</link>
		<comments>http://www.sharepointblog.nl/2010/05/25/fieldrefs-not-working-with-xml-comments/#comments</comments>
		<pubDate>Tue, 25 May 2010 20:55:44 +0000</pubDate>
		<dc:creator>Michiel</dc:creator>
				<category><![CDATA[SharePoint]]></category>
		<category><![CDATA[contentype]]></category>
		<category><![CDATA[fields]]></category>
		<category><![CDATA[SharePoint 2010]]></category>
		<category><![CDATA[visual studio]]></category>

		<guid isPermaLink="false">http://www.sharepointblog.nl/?p=44</guid>
		<description><![CDATA[After provisioning a custom content type it contained no custom fields. After investigation the problem was found in the SharePoint xml parser, it can't handle xml comments.]]></description>
			<content:encoded><![CDATA[<div class="tweetmeme_button" style="float: right; margin-left: 10px;">
			<a href="http://api.tweetmeme.com/share?url=http%3A%2F%2Fwww.sharepointblog.nl%2F2010%2F05%2F25%2Ffieldrefs-not-working-with-xml-comments%2F"><br />
				<img src="http://api.tweetmeme.com/imagebutton.gif?url=http%3A%2F%2Fwww.sharepointblog.nl%2F2010%2F05%2F25%2Ffieldrefs-not-working-with-xml-comments%2F&amp;source=m_lampje&amp;style=normal&amp;service=bit.ly" height="61" width="50" /><br />
			</a>
		</div>
<p>Today I was working on a SharePoint 2010 project where the custom fields and content types where provisioned using a feature. After the feature was activated the custom fields and content types where provisioned in SharePoint, except the content type contained no fields. The element manifest file contained the following xml:</p>
<pre class="csharpcode">  <span class="rem">&lt;!-- Base Page --&gt;</span>
<span class="kwrd">&lt;</span><span class="html">ContentType</span> <span class="attr">ID</span><span class="kwrd">="0x010100C568DB52D9D0A1...84E219954237AF3901"</span>
              <span class="attr">Name</span><span class="kwrd">="Basepage"</span>
              <span class="attr">Description</span><span class="kwrd">="Basepage"</span>
              <span class="attr">Group</span><span class="kwrd">="Publishing"</span>
              <span class="attr">Sealed</span><span class="kwrd">="TRUE"</span>
              <span class="attr">Inherits</span><span class="kwrd">="TRUE"</span>
              <span class="attr">Version</span><span class="kwrd">="1"</span><span class="kwrd">&gt;</span>
  <span class="kwrd">&lt;</span><span class="html">FieldRefs</span><span class="kwrd">&gt;</span>
    <span class="rem">&lt;!-- Originating from MOSS --&gt;</span>
    <span class="kwrd">&lt;</span><span class="html">FieldRef</span> <span class="attr">ID</span><span class="kwrd">="{b66e9b50-a28e-469b-b1a0-af0e45486874}"</span>
            <span class="attr">Name</span><span class="kwrd">="Keywords"</span> <span class="kwrd">/&gt;</span>
    <span class="rem">&lt;!-- Custom fields --&gt;</span>
    <span class="kwrd">&lt;</span><span class="html">FieldRef</span> <span class="attr">ID</span><span class="kwrd">="{30607e4e-a3e1-4662-9766-56e1faedb875}"</span>
            <span class="attr">Name</span><span class="kwrd">="AdminComments"</span> <span class="kwrd">/&gt;</span>
  <span class="kwrd">&lt;/</span><span class="html">FieldRefs</span><span class="kwrd">&gt;</span>
<span class="kwrd">&lt;/</span><span class="html">ContentType</span><span class="kwrd">&gt;</span></pre>
<p>The ULS logs showed no errors and I couldn’t figure out what the problem was because the same element manifest file was used in SharePoint 2007. After the stripping the file I figured out that the xml comments were causing the problem. Now my element manifest contains the following:</p>
<pre class="csharpcode"><span class="kwrd">&lt;</span><span class="html">ContentType</span> <span class="attr">ID</span><span class="kwrd">="0x010100C568DB52D9D0A1...84E219954237AF3901"</span>
              <span class="attr">Name</span><span class="kwrd">="Basepage"</span>
              <span class="attr">Description</span><span class="kwrd">="Basepage"</span>
              <span class="attr">Group</span><span class="kwrd">="Publishing"</span>
              <span class="attr">Sealed</span><span class="kwrd">="TRUE"</span>
              <span class="attr">Inherits</span><span class="kwrd">="TRUE"</span>
              <span class="attr">Version</span><span class="kwrd">="1"</span><span class="kwrd">&gt;</span>
  <span class="kwrd">&lt;</span><span class="html">FieldRefs</span><span class="kwrd">&gt;</span>
    <span class="kwrd">&lt;</span><span class="html">FieldRef</span> <span class="attr">ID</span><span class="kwrd">="{b66e9b50-a28e-469b-b1a0-af0e45486874}"</span>
            <span class="attr">Name</span><span class="kwrd">="Keywords"</span> <span class="kwrd">/&gt;</span>
    <span class="kwrd">&lt;</span><span class="html">FieldRef</span> <span class="attr">ID</span><span class="kwrd">="{30607e4e-a3e1-4662-9766-56e1faedb875}"</span>
            <span class="attr">Name</span><span class="kwrd">="AdminComments"</span> <span class="kwrd">/&gt;</span>
  <span class="kwrd">&lt;/</span><span class="html">FieldRefs</span><span class="kwrd">&gt;</span>
<span class="kwrd">&lt;/</span><span class="html">ContentType</span><span class="kwrd">&gt;</span></pre>
<p>The content is the same except the comments are missing.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.sharepointblog.nl/2010/05/25/fieldrefs-not-working-with-xml-comments/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>SearchBox changed in October Cumulative Update</title>
		<link>http://www.sharepointblog.nl/2010/01/28/searchbox-changed-in-october-cumulative-update/</link>
		<comments>http://www.sharepointblog.nl/2010/01/28/searchbox-changed-in-october-cumulative-update/#comments</comments>
		<pubDate>Thu, 28 Jan 2010 16:48:15 +0000</pubDate>
		<dc:creator>Michiel</dc:creator>
				<category><![CDATA[SharePoint]]></category>
		<category><![CDATA[MOSS]]></category>
		<category><![CDATA[Multilingual]]></category>
		<category><![CDATA[October update]]></category>
		<category><![CDATA[ScopeDisplayGroupName]]></category>
		<category><![CDATA[SearchBoxEx]]></category>

		<guid isPermaLink="false">http://www.sharepointblog.nl/2010/01/28/searchbox-changed-in-october-cumulative-update/</guid>
		<description><![CDATA[The problem With the introduction of the October Cumulative Update for SharePoint 2007 I encountered a problem with the search box on multilingual sites. After the installation of the update the scopes dropdown list always uses the same scope display group. After investigation I found that the language of the root web is used to [...]]]></description>
			<content:encoded><![CDATA[<div class="tweetmeme_button" style="float: right; margin-left: 10px;">
			<a href="http://api.tweetmeme.com/share?url=http%3A%2F%2Fwww.sharepointblog.nl%2F2010%2F01%2F28%2Fsearchbox-changed-in-october-cumulative-update%2F"><br />
				<img src="http://api.tweetmeme.com/imagebutton.gif?url=http%3A%2F%2Fwww.sharepointblog.nl%2F2010%2F01%2F28%2Fsearchbox-changed-in-october-cumulative-update%2F&amp;source=m_lampje&amp;style=normal&amp;service=bit.ly" height="61" width="50" /><br />
			</a>
		</div>
<h3>The problem</h3>
<p>With the introduction of the October Cumulative Update for SharePoint 2007 I encountered a problem with the search box on multilingual sites. After the installation of the update the scopes dropdown list always uses the same scope display group. After investigation I found that the language of the root web is used to determine the scope display group.</p>
<h3>The cause</h3>
<p>This behavior was not present in the control prior to the October update, in the description of the update (KB975731) we found:</p>
<blockquote><p>&quot;All sites,&quot; &quot;People,&quot; and &quot;This site&quot; search scopes are available only for English language sites. Sites that are written in other languages show only the &quot;This site&quot; search scope.</p>
</blockquote>
<p>This explains that the control has been changed in this update.</p>
<h3>The reason</h3>
<p>Before the October Update the property ScopeDisplayGroupName is set in the constructor of the SearchBoxEx control:</p>
<pre class="csharpcode"><span class="kwrd">this</span>._ScopeDisplayGroupName =
    SearchCommon.GetLocResourceString(
        LocStringId.ScopeDisplayGroup_SearchDropdown_Name);</pre>
<p>In the October Update this line of code has been changed to:</p>
<pre class="csharpcode"><span class="kwrd">this</span>._ScopeDisplayGroupName = GetScopeDisplayGroupNameDefaultValue();</pre>
</p>
<p>This function uses the language from the root web is to determine the value for the ScopeDisplayGroupName property:</p>
<pre class="csharpcode"><span class="kwrd">private</span> <span class="kwrd">static</span> <span class="kwrd">string</span> GetScopeDisplayGroupNameDefaultValue()
{
    <span class="kwrd">if</span> (SPContext.Current != <span class="kwrd">null</span>)
    {
        <span class="kwrd">while</span> (SPContext.Current.Site != <span class="kwrd">null</span>)
        {
            <span class="typ">CultureInfo</span> siteCollectionCulture = <span class="kwrd">null</span>;
            SPSecurity.RunWithElevatedPrivileges(<span class="kwrd">delegate</span> {
                siteCollectionCulture = <span class="kwrd">new</span> CultureInfo(
                    (<span class="kwrd">int</span>) SPContext.Current.Site.RootWeb.Language);
            });
            <span class="kwrd">return</span> StringResourceManager.GetString(
                LocStringId.ScopeDisplayGroup_SearchDropdown_Name,
                    siteCollectionCulture);
        }
    }

    <span class="kwrd">return</span> SearchCommon.GetLocResourceString(
            LocStringId.ScopeDisplayGroup_SearchDropdown_Name);
}</pre>
<h3>The solution</h3>
<p>For this website I want the value for the ScopeDisplayGroupName property to be based on the culture of the current web. To re-enable this functionality we updated our custom master page and added the following to the SearchBoxEx control:</p>
<pre class="csharpcode"><span class="kwrd">&lt;</span><span class="html">sharepoint:searchboxex</span> <span class="attr">runat</span><span class="kwrd">=&quot;server&quot;</span> ...
 <span class="attr">ScopeDisplayGroupName</span><span class="kwrd">=&quot;&lt;%$Resources:searchfix,ScopeDisplayGroup_SearchDropdown_Name%&gt;&quot;</span> <span class="kwrd">/&gt;</span></pre>
<p>In the App_GlobalResources I added custom resource files with the correct translations for the resource key ScopeDisplayGroup_SearchDropdown_Name.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.sharepointblog.nl/2010/01/28/searchbox-changed-in-october-cumulative-update/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>
