免费注册 查看新帖 |

Chinaunix

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

求助Win32::OLE::Variant=SCALAR(0x1904a60) [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-12-14 13:36 |只看该作者 |倒序浏览
读sql server 的datetime 字段出来了这个,请教这是什么问题,如何解决?

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
2 [报告]
发表于 2007-12-14 13:38 |只看该作者
原帖由 想像的瞬间 于 2007-12-14 13:36 发表
请教这是什么问题

你猜!

论坛徽章:
0
3 [报告]
发表于 2007-12-14 13:43 |只看该作者
原帖由 flw 于 2007-12-14 13:38 发表

你猜!

我是新手,要定义变量类型?

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
4 [报告]
发表于 2007-12-14 13:55 |只看该作者
原帖由 想像的瞬间 于 2007-12-14 13:43 发表

我是新手,要定义变量类型?

你再猜!

论坛徽章:
0
5 [报告]
发表于 2007-12-14 14:06 |只看该作者
原帖由 flw 于 2007-12-14 13:55 发表

你再猜!

。。。。。需要http:date?

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
6 [报告]
发表于 2007-12-14 14:10 |只看该作者
原帖由 想像的瞬间 于 2007-12-14 14:06 发表

。。。。。需要http:date?

其实是需要你的源代码。
不然我就只能再再猜了。

论坛徽章:
0
7 [报告]
发表于 2007-12-14 14:21 |只看该作者
原帖由 flw 于 2007-12-14 14:10 发表

其实是需要你的源代码。
不然我就只能再再猜了。







use Win32::ADO qw/CheckDBErrors/;
use Win32::OLE;
my $Conn = new Win32::OLE('ADODB.Connection' );
#~ $Conn = $Server->CreateObject("ADODB.Connection ";
$Conn->Open( " Provider=sqloledb; User ID=; Password=; Initial Catalog=; Data Source=" );
CheckDBErrors($Conn, \@DBErrors) or die "SQL Failed at ", __LINE__, "\n", @DBErrors;
my $RS = $Conn->Execute( "SELECT atterm FROM table where flag='1';" );
CheckDBErrors($Conn, \@DBErrors) or die "SQL Failed at ", __LINE__, "\n", @DBErrors;

while ( ! $RS->{EOF} ) {
        $atterm      = $RS->Fields(0)->{Value};

        print $atterm;

        $RS->MoveNext;
}
$RS->Close;
$Conn->Close;




$atterm 输出出来是Win32::OLE::Variant=SCALAR(0x1904a60)  atterm字段是datatime类型的

[ 本帖最后由 想像的瞬间 于 2007-12-14 14:23 编辑 ]

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
8 [报告]
发表于 2007-12-14 14:43 |只看该作者
你不能直接 print,
你应该用:
  1. print $atterm->Date( DATE_SHORTDATE ), $atterm->Time(TIME_FORCE24HOURFORMAT|TIME_NOTIMEMARKER), "\n";
复制代码

详细信息参见 perldoc Win32::OLE::Variant;

论坛徽章:
0
9 [报告]
发表于 2007-12-14 15:03 |只看该作者
原帖由 flw 于 2007-12-14 14:43 发表
你不能直接 print,
你应该用:
print $atterm->Date( DATE_SHORTDATE ), $atterm->Time(TIME_FORCE24HOURFORMAT|TIME_NOTIMEMARKER), "\n";
详细信息参见 perldoc Win32::OLE::Variant;

谢谢版版啊 
原来要这样

use Win32::OLE::Variant;

my $atterm = Variant(UT_DATE,'Jan 1,1970');

$atterm      = $RS->Fields(1)->{Value};

论坛徽章:
0
10 [报告]
发表于 2007-12-14 15:50 |只看该作者
my $atterm = Variant(UT_DATE,'Jan 1,1970');
这行是多余的。不需要。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP