geotools导出shapefile出错: java.io.IOException: Current fid index is null, next must be called before write()

geotools导出shapefile出错:

java.io.IOException: Current fid index is null, next must be called before write()

经过查找,发现出现该问题的原因是SQLServer数据库中有几个字符型字段的类型为NVARCAHR类型。
NVARCHAR类型支持双字节,shapefile数据是用DBF文件来存储。字符类型text只支持单字节数据。
因此,如果字段QI_YUAN在SQLServer定义成NVARCHAR(6),导出的DBF结构为text(6)。QI_YUAN值为"人工造林"时,
存入SQLServer是没问题的,但存入DBF就会出错。DBF将"人工造林"算成8个字节,超出定义的text(6)。

解决方法:
将SQLServer中可能出错的NVARCHAR字段类型长度加长或增加一倍也行。

原文地址:https://www.cnblogs.com/janehlp/p/3613116.html