经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 数据库/运维 » MS SQL Server » 查看文章
sql数据库查询结果字段包含换行符导致复制到Excel发生错位问题的解决
来源:cnblogs  作者:张工502219048  时间:2019/6/10 13:36:20  对本文有异议

问题描述:
在工作过程中,有时会遇到这样的问题,写好sql查询语句在数据库中查询数据,看到行数(比如说是1000行),但是把查询结果复制到Excel里面,却发生了行列错位问题,而导致Excel里面的行数是超过1000行的,造成数据行数的不一致。

问题重现:
字段值包含char(10)换行符,复制字段值到Excel.

根源:
某些行列对应单元格包含了换行符,导致复制到Excel里面发生错位。

解决方案:
方案1(推荐):把有问题的字段值,用英文双引号括起来,这样就能把字段值里面的换行符限制在正确的Excel单元格里面。
方案2:通过脚本把对应的字段值换行符去掉。

脚本:

  1. create table #t
  2. (
  3. Name nvarchar(50),
  4. Remark nvarchar(50)
  5. )
  6. --问题重现条件:单元格里面包含换行符
  7. insert into #t
  8. values ('A1' + char(10) + 'B1', '行1'), ('A2B2', '行2')
  9. --问题重现结果:把sql查询结果复制到Excel会错位
  10. select Name, Remark
  11. from #t
  12. --解决方案1:可以直接在字段加双引号处理,复制到Excel就不会错位,也不会显示多余的双引号。相当于把字段里的换行限制在单元格内
  13. select '"'+ Name + '"' as Name, Remark
  14. from #t
  15. --解决方案2:可以把换行符去掉
  16. select replace(replace(Name, char(13), ''), char(10), '') as Name, Remark
  17. from #t
  18. drop table #t

运行结果:

查询结果复制到Excel的效果:

后记:
以上是本人在日常工作中处理数据库查询结果复制到Excel发生错位问题、行数不一致问题所摸索到的解决办法,特此分享一下,希望对遇到同样问题的朋友有所帮助。如果帮助到了你,欢迎给我打赏支持一下哦。
【转载请注明博文来源:https://www.cnblogs.com/zhang502219048/p/10989296.html

原文链接:http://www.cnblogs.com/zhang502219048/p/10989296.html

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号