我正在研究催化剂来设计数据库的前端。我是 perl 和催化剂的新手。我在控制器中遇到了一个错误。
我想从一个表中获取基因名称并将每个基因名称传递给将执行某些功能的子程序gene_name(调用子程序gene_name)。我知道如何获取带有基因名称的列,但它们是以哈希引用的形式对其他表进行的。我对gene_name 的调用不起作用。
知道如何将值传递给子程序而不是引用吗?我的代码如下:
my @gene_list = $c->model('Gene::GeneTable')->search({
},{
column =>[qw/symbol/],
}
);
foreach my $gene (@gene_list){
push @gene_aliases, &gene_name($gene);
}
执行代码后我得到的错误如下:
DBIx::Class::ResultSet::find(): Can't bind a reference (MyApp::Model::Gene::GeneTable=HASH(0x7ff6d88b7c58))
更新
我的gene_name() 子程序位于控制器中包含的另一个模块中。现在我已经改变了for循环(在控制器中)如下,目前它正在将基因名称传递给gene_name()以获取别名(但查询保持不变):
foreach my $gene (@gene_list){
push @gene_aliases, &gene_name($gene-> symbol);
}
我正在访问我的视图文件中的@gene_aliases,如下所示:
[% FOREACH g in gene_aliases -%]
[% g %]
[% END -%]
上面的代码是在页面中获取哈希引用而不是名称。我无法在网页上显示基因名称。如果我在 for 循环中给出 [% g.symbol %] 则页面将为空且没有错误消息。希望这将是回答我的问题的足够信息。如果不是,我会详细说明。
我的 SQL 查询如下:
Select Symbol from GeneTable;
提前致谢
更新2
由于我不是全职程序员,所以我在博客上提出这些问题。请帮助我解决我的问题。如果我有从用户获取基因名称的搜索表单,并且该基因名称必须传递给gene_name()子例程,我该如何传递它(到控制器以及如何调用gene_name())。请帮助我解决这个问题。我在 view.tt 中的表格如下:
<form method="post" action "[% c.uri_for('/gene')%]">
<input type="text" name="search_alias">
<input type="submit" name="alias_search" value="Search">
</form>
我所有的别名都在另一个名为 Alias 的表中,该表在gene_name() 子例程中使用。