免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2803 | 回复: 3
打印 上一主题 下一主题

请教:这种类型Template::Toolkit怎么写? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-07-04 17:08 |只看该作者 |倒序浏览
本帖最后由 骡子先生 于 2011-07-04 17:21 编辑

我从数据库取数据,通过tt显示,但是只能显示引用地址,请教这种情况如何处理?我的代码如下

  1. #!/usr/bin/perl
  2. use Dancer;
  3. use Data::Dumper;
  4. use DBI;
  5. use DBD::mysql;

  6. get '/sql/dbisql', sub {
  7.     my $host = '127.0.0.1';
  8.     my $port = '3306';

  9.     my $dbname = 'op_system';
  10.     my $username = 'op_system';
  11.     my $password = 'op_system';

  12.     my $dbh = DBI->connect("DBI:mysql:database=$dbname;host=$host;port=$port", $username, $password, {RaiseError => 1, AutoCommit => 1});
  13.     my $sth = $dbh->prepare("select * from dataCenter");
  14.     $sth->execute;

  15.     my $result = $sth->fetchall_hashref('id');

  16.     #print Dumper $result;

  17.     template 'dbisql',
  18.     {
  19.         head => 'use DBI',
  20.         content => $result,
  21.     };
  22. };

  23. dancer;

复制代码
数据结构如下
  1. $VAR1 = {
  2.           '1' => {
  3.                    'bandwidth' => undef,
  4.                    'telephone' => '010-2343244',
  5.                    'ip' => undef,
  6.                    'name' => '北京三元数据中心',
  7.                    'address' => '北京朝阳区三元桥大厦3楼',
  8.                    'id' => '1',
  9.                    'zipcode' => '100038'
  10.                  },
  11.           '3' => {
  12.                    'bandwidth' => undef,
  13.                    'telephone' => '012-6436353',
  14.                    'ip' => undef,
  15.                    'name' => '天津数据中心',
  16.                    'address' => '天津市海河区天津大厦2楼',
  17.                    'id' => '3',
  18.                    'zipcode' => '120003'
  19.                  },
  20.           '2' => {
  21.                    'bandwidth' => undef,
  22.                    'telephone' => '021-33232432',
  23.                    'ip' => undef,
  24.                    'name' => '上海静安数据中心',
  25.                    'address' => '上海市静安区发展大厦19楼',
  26.                    'id' => '2',
  27.                    'zipcode' => '200032'
  28.                  }
  29.         };
复制代码
dbisql.tt
  1. <h2><% head %></h2>

  2. <% FOREACH row IN content -%>
  3.    <% row %>
  4. <% END %>
复制代码
显示结果
  1. use DBI
  2. HASH(0x62718f0) HASH(0x6271ae0) HASH(0x6269b10)
复制代码

论坛徽章:
0
2 [报告]
发表于 2011-07-04 17:24 |只看该作者
回复 1# 骡子先生


已解决

用数据引用代替哈希引用
  my $result = $sth->fetchall_hashref('id'); =>  my $result = $sth->fetchall_arrayref();
  1. <h2><% head %></h2>

  2. <% FOREACH i IN content -%>
  3.    <% FOREACH j IN i -%>
  4.       <% j %>
  5.    <% END %><br>
  6. <% END %>
复制代码
  1. use DBI
  2. 1 北京三元数据中心 北京朝阳区三元桥大厦3楼 100038 010-2343244
  3. 2 上海静安数据中心 上海市静安区发展大厦19楼 200032 021-33232432
  4. 3 天津数据中心 天津市海河区天津大厦2楼 120003 012-6436353
复制代码

论坛徽章:
0
3 [报告]
发表于 2011-07-04 18:56 |只看该作者
收藏备用{:3_189:}

论坛徽章:
46
15-16赛季CBA联赛之四川
日期:2018-03-27 11:59:132015年亚洲杯之沙特阿拉伯
日期:2015-04-11 17:31:45天蝎座
日期:2015-03-25 16:56:49双鱼座
日期:2015-03-25 16:56:30摩羯座
日期:2015-03-25 16:56:09巳蛇
日期:2015-03-25 16:55:30卯兔
日期:2015-03-25 16:54:29子鼠
日期:2015-03-25 16:53:59申猴
日期:2015-03-25 16:53:29寅虎
日期:2015-03-25 16:52:29羊年新春福章
日期:2015-03-25 16:51:212015亚冠之布里斯班狮吼
日期:2015-07-13 10:44:56
4 [报告]
发表于 2011-07-04 22:01 |只看该作者
hash 有 hash 的用法,不会用可以查文档啊。http://template-toolkit.org/docs ... ash_Virtual_Methods
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP