您的位置:首页 > 数据库

perl的dbi数据访问odbc读取sqlserver数据被截断的问题

2013-11-07 19:35 411 查看
select时报错

DBD::ODBC::st fetchrow_arrayref failed: st_fetch/SQLFetch (long truncated DBI attribute LongTruncOk not set and/or LongReadLen too small) (SQL-HY000)

这种情况加上

$dbh_mssql->{LongTruncOk} = 1;

可以解决。

但是这种方式会截断字符串。

我不想截断字符串,想要完整的读取出来。看了下资料 说是可以设置Long的长度。

使用如下:

$dbh_mssql->{LongReadLen} = 512 *1024;

单独使用时无效。

还是报同样的错误。

$dbh_mssql->{LongReadLen} = 512 *1024;

$dbh_mssql->{LongTruncOk} = 0;

时还是报错

但是跟 $dbh_mssql->{LongTruncOk} = 1;一起使用时就没问题 只是还是会截断。

还是说 我这里的len长度还不够? 2048*2048还是不行

结果 跟数据类型有关。

$sql_select ="select top 5 [name] , [address] , [developer] , CAST([othercondition] as TEXT), [projectsquare] , [usinglandarea] from new_baseinfo";

注意红色部分。

原来还涉及到数据类型的问题。把被截断的字段改为text。

然后设置。

my $dbh_mssql=DBI->connect("dbi:ODBC:$source_name",$source_user_name,$source_user_psd);

$dbh_mssql->{LongTruncOk}=1;

$dbh_mssql->{LongReadLen} = 1048576*1024;

print "LongReadLen: $dbh_mssql->{LongReadLen}\n";

就可以了

参考资料:
http://blog.csdn.net/aylazhang/article/details/1707745 http://www.freetds.org/userguide/troubleshooting.htm
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: