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
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
相关文章推荐
- MSSQL SERVER 2008 R2 无法连接到数据库,用户sa登录失败,错误:18456
- Oracle中没有 if exists(...)
- MySQL导入.sql文件及常用命令
- SQL 语句
- 查看使用该数据库的用户
- 《数据库系统概论》实验指导书
- Mysql中校对集utf8_unicode_ci与utf8_general_ci的区别
- SQL Server 批量插入数据的两种方法
- 释放MySQL ibdata1文件的空间
- 高性能的MySQL(8)优化服务器配置一安全与稳定
- 高性能的MySQL(8)优化服务器配置一安全与稳定
- 如何配置oracle的性能分析工具statspack
- ubuntu 下安装mysql5.5.47 并装 hustoj
- Xshell连接Linux下Oracle无法回退的解决办法
- PHP操作MongoDB
- SQL 常用SQL说明
- sqoop export SQLSERVER 存储过程参数限制
- Oracle EXECUTE IMMEDIATE
- SQL 项目中常用SQL总结
- freeradius+mysql+nas(ros)