开发者

SharePoint: CAML query error when creating SPQuery query

开发者 https://www.devze.com 2023-03-27 23:43 出处:网络
I have this CAML query var query = new SPQuery { Query = string.Format(@\"<Where> <Or> <Or>

I have this CAML query

var query = new SPQuery
                                {
                                    Query = string.Format(@"<Where>
                                        <Or>
                                            <Or>
                                                <Or>
                                                    <Or>
                                                        <Contains>
                                                            <FieldRef Name='{7}' />
                                                            <Value Type='Text'>{3}</Value>
                                                        </Contains>
                                                    </Or>
                                                    <Contains>
                                                        <FieldRef Name='{6}' />
                                                        <Value Type='Text'>{2}</Value>
                                                    </Contains>
                                                </Or
                                                <Contains>
                   开发者_JAVA技巧                                 <FieldRef Name='{5}' />
                                                    <Value Type='Text'>{1}</Value>
                                                </Contains>
                                            </Or>
                                            <Contains>
                                                <FieldRef Name='{4}' />
                                                <Value Type='Text'>{0}</Value>
                                            </Contains>
                                        </Or>
                                    </Where>", "title", "adress", "zipcode", "city", "searchTitle", "searchAdress", "searchZipcode", "searchCity")
                                };

Every time it's ran and I try to use List.GetItems(query); it throws this error:

One or more field types are not installed properly. Go to the list settings page to delete these fields.

BUT! If I remove all the <Or> tags it works and doesn't throw that error, but I need the <Or> tags to make sure it get all hits.

I've made sure all the fieldrefs matches the internal names of the columns 100%.


Have you tried your query without the around the Contains 7/3 element? This one is imo not needed.

Also one of your /Or's has no closing bracket <Value Type='Text'>{2}</Value></Contains></Or<Contains>, this could be causing the error.


correct your CAML

    var query = new SPQuery
                            {
                                Query = string.Format(@"<Where>
                                        <Or>
                                            <Or>
                                                <Or>
                                                    <Contains>
                                                        <FieldRef Name='{7}' />
                                                        <Value Type='Text'>{3}</Value>
                                                    </Contains>
                                                    <Contains>
                                                        <FieldRef Name='{6}' />
                                                        <Value Type='Text'>{2}</Value>
                                                    </Contains>
                                                </Or>
                                                <Contains>
                                                    <FieldRef Name='{5}' />
                                                    <Value Type='Text'>{1}</Value>
                                                </Contains>
                                            </Or>
                                            <Contains>
                                                <FieldRef Name='{4}' />
                                                <Value Type='Text'>{0}</Value>
                                            </Contains>
                                        </Or>
                                </Where>", "title", "adress", "zipcode", "city", "searchTitle", "searchAdress", "searchZipcode", "searchCity")
                            };
0

精彩评论

暂无评论...
验证码 换一张
取 消