草庐IT

c# - Solr.Net 查询 : ArgumentException in Windows Forms

coder 2024-06-07 原文

所以我启动并运行了一个 Windows 窗体项目。它使用 Lucene.Net 库,我用它制作了一个 Lucene 索引。该程序接受用户请求,通过一些算法运行它们并在 DataGridView 中显示结果集。

之后我安装了 XAMPP,使用 Tomcat 服务来设置 Solr 3.6.1。我将 schema.xml 配置如下(感谢 Can a raw Lucene index be loaded by Solr? ):

<fieldType name="tdouble" class="solr.TrieDoubleField" precisionStep="0" omitNorms="true" positionIncrementGap="0"/>
[...]
<field name="LuminaireId" type="string" indexed="true" stored="true"/>
<field name="LampCount" type="tdouble" multiValued="true" indexed="true" stored="true" required="false"/>
[...]

我搜索了一些关于如何设置所有东西的示例,并提出了一个用于映射值的产品类(还有一些值,但为了获得图片,我认为这就足够了),如下所示:

public class SolrProduct
{
      [SolrUniqueKey("LuminaireId")]
      public string LuminaireId { get; set; }

      [SolrField("LampCount")]
      public ICollection<double> LampCount { get; set; }
}

一个简单的测试查询(使用这个方法)

internal override List<KeyValuePair<Int64, Double>> CalculateRanking(List<T> checkedAttributes)
{
    Startup.Init<SolrProduct>("http://localhost:8983/solr/");
    var solr = ServiceLocator.Current.GetInstance<ISolrOperations<SolrProduct>>();
    var results = solr.Query("LampCount:1");
    // as is: no mapping for result-return for now, returning "null" instead
    return(null);
}

产生一个 ArgumentException,告诉我“System.Collections.ArrayList”类型的对象不能转换为“System.String”类型。即使在 Internet 上搜索该问题并调试程序后,我仍然不理解该异常。 “LampCount”是一个多值字段(以前是 Lucene 索引中的 NumericField),它应该可以在 Product.cs 中使用 schema.xml 和映射。

在 localhost:8983/solr/admin/上使用 Web 界面时,它可以工作,我可以将查询发送为“LampCount:1”,它会返回一堆正确找到的文档。这可能是另一个问题,但是对于所有“按原样设置”,Solr Web 界面的结果集 XML 显示(在每个找到的文档中):

<arr name="LampCount">
<str>ERROR:SCHEMA-INDEX-MISMATCH,stringValue=1</str>
</arr>

我为 Lucene 索引文档索引了 LampCount 字段

 var valueField = new NumericField(internalname, Field.Store.YES, true);
 valueField.SetDoubleValue(value);
 doc.Add(valueField);

这会是问题所在吗,因为我现在看不到大局,感到完全迷失了。如果你能解开我的脑结,我将不胜感激。 ;-)

提前致谢!

最佳答案

您的架构与 POCO 不匹配。基本上,Solr 试图将“tdouble”字段类型转换为您的集合。 你能做的最好的事情就是执行,你在管理控制面板和观察者中的查询返回了什么,然后问问自己你认为它将如何处理返回到你的 POCO 中的输入。

关于c# - Solr.Net 查询 : ArgumentException in Windows Forms,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12027451/

有关c# - Solr.Net 查询 : ArgumentException in Windows Forms的更多相关文章

  1. ruby-on-rails - Ruby net/ldap 模块中的内存泄漏 - 2

    作为我的Rails应用程序的一部分,我编写了一个小导入程序,它从我们的LDAP系统中吸取数据并将其塞入一个用户表中。不幸的是,与LDAP相关的代码在遍历我们的32K用户时泄漏了大量内存,我一直无法弄清楚如何解决这个问题。这个问题似乎在某种程度上与LDAP库有关,因为当我删除对LDAP内容的调用时,内存使用情况会很好地稳定下来。此外,不断增加的对象是Net::BER::BerIdentifiedString和Net::BER::BerIdentifiedArray,它们都是LDAP库的一部分。当我运行导入时,内存使用量最终达到超过1GB的峰值。如果问题存在,我需要找到一些方法来更正我的代

  2. ruby - ECONNRESET (Whois::ConnectionError) - 尝试在 Ruby 中查询 Whois 时出错 - 2

    我正在用Ruby编写一个简单的程序来检查域列表是否被占用。基本上它循环遍历列表,并使用以下函数进行检查。require'rubygems'require'whois'defcheck_domain(domain)c=Whois::Client.newc.query("google.com").available?end程序不断出错(即使我在google.com中进行硬编码),并打印以下消息。鉴于该程序非常简单,我已经没有什么想法了-有什么建议吗?/Library/Ruby/Gems/1.8/gems/whois-2.0.2/lib/whois/server/adapters/base.

  3. ruby - 如何模拟 Net::HTTP::Post? - 2

    是的,我知道最好使用webmock,但我想知道如何在RSpec中模拟此方法:defmethod_to_testurl=URI.parseurireq=Net::HTTP::Post.newurl.pathres=Net::HTTP.start(url.host,url.port)do|http|http.requestreq,foo:1endresend这是RSpec:let(:uri){'http://example.com'}specify'HTTPcall'dohttp=mock:httpNet::HTTP.stub!(:start).and_yieldhttphttp.shou

  4. ruby-on-rails - 在 Rails 和 ActiveRecord 中查询时忽略某些字段 - 2

    我知道我可以指定某些字段来使用pluck查询数据库。ids=Item.where('due_at但是我想知道,是否有一种方法可以指定我想避免从数据库查询的某些字段。某种反拔?posts=Post.where(published:true).do_not_lookup(:enormous_field) 最佳答案 Model#attribute_names应该返回列/属性数组。您可以排除其中一些并传递给pluck或select方法。像这样:posts=Post.where(published:true).select(Post.attr

  5. c# - 如何在 ruby​​ 中调用 C# dll? - 2

    如何在ruby​​中调用C#dll? 最佳答案 我能想到几种可能性:为您的DLL编写(或找人编写)一个COM包装器,如果它还没有,则使用Ruby的WIN32OLE库来调用它;看看RubyCLR,其中一位作者是JohnLam,他继续在Microsoft从事IronRuby方面的工作。(估计不会再维护了,可能不支持.Net2.0以上的版本);正如其他地方已经提到的,看看使用IronRuby,如果这是您的技术选择。有一个主题是here.请注意,最后一篇文章实际上来自JohnLam(看起来像是2009年3月),他似乎很自在地断言RubyCL

  6. C# 到 Ruby sha1 base64 编码 - 2

    我正在尝试在Ruby中复制Convert.ToBase64String()行为。这是我的C#代码:varsha1=newSHA1CryptoServiceProvider();varpasswordBytes=Encoding.UTF8.GetBytes("password");varpasswordHash=sha1.ComputeHash(passwordBytes);returnConvert.ToBase64String(passwordHash);//returns"W6ph5Mm5Pz8GgiULbPgzG37mj9g="当我在Ruby中尝试同样的事情时,我得到了相同sha

  7. ruby - Net::HTTP 获取源代码和状态 - 2

    我目前正在使用以下方法获取页面的源代码:Net::HTTP.get(URI.parse(page.url))我还想获取HTTP状态,而无需发出第二个请求。有没有办法用另一种方法做到这一点?我一直在查看文档,但似乎找不到我要找的东西。 最佳答案 在我看来,除非您需要一些真正的低级访问或控制,否则最好使用Ruby的内置Open::URI模块:require'open-uri'io=open('http://www.example.org/')#=>#body=io.read[0,50]#=>"["200","OK"]io.base_ur

  8. 基于C#实现简易绘图工具【100010177】 - 2

    C#实现简易绘图工具一.引言实验目的:通过制作窗体应用程序(C#画图软件),熟悉基本的窗体设计过程以及控件设计,事件处理等,熟悉使用C#的winform窗体进行绘图的基本步骤,对于面向对象编程有更加深刻的体会.Tutorial任务设计一个具有基本功能的画图软件**·包括简单的新建文件,保存,重新绘图等功能**·实现一些基本图形的绘制,包括铅笔和基本形状等,学习橡皮工具的创建**·设计一个合理舒适的UI界面**注明:你可能需要先了解一些关于winform窗体应用程序绘图的基本知识,以及关于GDI+类和结构的知识二.实验环境Windows系统下的visualstudio2017C#窗体应用程序三.

  9. Get https://registry-1.docker.io/v2/: net/http: request canceled while waiting - 2

    1.错误信息:Errorresponsefromdaemon:Gethttps://registry-1.docker.io/v2/:net/http:requestcanceledwhilewaitingforconnection(Client.Timeoutexceededwhileawaitingheaders)或者:Errorresponsefromdaemon:Gethttps://registry-1.docker.io/v2/:net/http:TLShandshaketimeout2.报错原因:docker使用的镜像网址默认为国外,下载容易超时,需要修改成国内镜像地址(首先阿里

  10. sql - 查询忽略时间戳日期的时间范围 - 2

    我正在尝试查询我的Rails数据库(Postgres)中的购买表,我想查询时间范围。例如,我想知道在所有日期的下午2点到3点之间进行了多少次购买。此表中有一个created_at列,但我不知道如何在不搜索特定日期的情况下完成此操作。我试过:Purchases.where("created_atBETWEEN?and?",Time.now-1.hour,Time.now)但这最终只会搜索今天与那些时间的日期。 最佳答案 您需要使用PostgreSQL'sdate_part/extractfunction从created_at中提取小时

随机推荐