Java-使用Hibernate和MS SQL Server的性能很慢
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了Java-使用Hibernate和MS SQL Server的性能很慢,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1223字,纯文字阅读大概需要2分钟。
内容图文
![Java-使用Hibernate和MS SQL Server的性能很慢](/upload/InfoBanner/zyjiaocheng/884/856ff6b076a343ba8f517f4d0ac466b4.jpg)
我正在使用休眠模式,而db是sqlserver.
SQL Server将其支持Unicode的数据类型与仅支持ASCII的数据类型区分开.例如,支持Unicode的字符数据类型为nchar,nvarchar,longnvarchar,其中,它们的ASCII计数器部分分别为char,varchar和longvarchar.默认情况下,所有Microsoft的JDBC驱动程序都会以Unicode格式将字符串发送到SQL Server,而不管SQL Server中定义的相应列的数据类型是否支持Unicode.在列的数据类型支持Unicode的情况下,一切都很顺利.但是,在列的数据类型不支持Unicode的情况下,会出现严重的性能问题,尤其是在数据获取期间.在进行比较之前,SQL Server尝试将表中的非Unicode数据类型转换为Unicode数据类型.此外,如果非Unicode列上存在索引,则它将被忽略.这最终将导致在数据获取期间进行整个表扫描,从而大大降低搜索查询的速度.
我们使用的解决方案是,我们发现有一个名为sendStringParametersAsUnicode的属性,该属性有助于摆脱这种Unicode转换.此属性默认为“ true”,这使得JDBC驱动程序默认将Unicode格式的每个字符串发送到数据库.我们关闭了此属性.
我的问题是,现在我们无法以Unicode转换发送数据.将来,如果将varchar的db列更改为nvarchar(仅一列而不是所有varchar列),现在我们应该以unicode格式发送字符串.
请建议我如何处理该方案.
谢谢.
解决方法:
您需要指定属性:连接字符串url中的sendStringParametersAsUnicode = false.
jdbc:sqlserver://localhost:1433;databaseName=mydb;sendStringParametersAsUnicode=false
内容总结
以上是互联网集市为您收集整理的Java-使用Hibernate和MS SQL Server的性能很慢全部内容,希望文章能够帮你解决Java-使用Hibernate和MS SQL Server的性能很慢所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。