SQLServer数据库JDBC连接串参数的简单学习
SQLServer数据库JDBC连接串参数的简单学习
背景
前段时间一直跟同事一起处理SQLServer 比其他数据库的deadlock更多的问题.
涉及到了几个驱动的参数. 想着问题基本上告一段落, 将这一块的情况总结一下.
便于后续遇到问题时的快速处理.
关于参数
现阶段的字符连接串为:
jdbc:sqlserver://ip:port;database=dbname;SelectMethod=direct;sendStringParametersAsUnicode=false
主要是修改了这两个字符串:
SelectMethod=direct
以及
sendStringParametersAsUnicode=false
这两个参数的含义:
1. SelectMethod
当这个参数值为cursor时, 理论上数据库里面被跟踪到了:
FETCH API_CURSOR00000000000880BE
类型的SQL就会少很多.
根据官网的解释, 这个参数是cursor 时, 会对大查询创建多个游标, 然后使用jdbc的client就可以每次获取一部分结果集来进行使用
当需要更多结果集时, 使用查询SQL时创建的这个游标 执行FETCH就可以获取后面的查询结果集.
优点:
降低jdbc客户端的内存使用量.每次只需要返回和接受一部分数据就可以了.
将值修改为 direct之后:
客户端需要全量返回数据, 对客户端内内存要求变高,但是大量数据的查询性能会变好
并且便于分析问题. 知道是谁被阻塞了.
2. sendStringParametersAsUnicode
这个参数是为了解决非utf8字符集情况下 unicode乱码问题的.
他会自动给应用程序生成的SQL做一次varchar类型到 nvarchar类型的转换.
会导致产品中大量出现隐式转换, 引起性能下降.
微软官方解释, 曾经将这个参数修改成false, 将数据库CPU使用率从100%,优化到30%
但是存在一个风险是,如果代码开发时 数据库时 nvarchar字段,用于存放多国语言, 但是程序里面使用的是varcahr字段类型
有一定的概率出现乱码的情况. 需要应用层进行适配和修改.
需要注意, 单独修改链接字符串可能无效, 需要jdbc解析字符串,并且准确的进行参数传递.
其他的优化知识
前期在查看durid连接池时,发现应用层总有一个: PrepateStatement 的参数信息
Oracle数据库很早之前就已经实现了.
应用层进行了SQL变量绑定之后,理论上每次过来的参数可以实现软软解析,最大程度的降低数据库的CPU算力.提高性能.
SQLServer数据库这一方面应该也有, 但是需要改天进行一下验证
一个简要总结
修改参数和修改驱动其实没啥太大的区别
建议必须做一下比较完备的功能验证.
一方面不应该导致性能下降, 至少应该在80%的大规模使用的场景上有性能提升才可以.
一方面 应该保证已有功能准确可用, 不会出现程序错误和乱码以及其他异常问题
如果仅仅是一两个功能有问题,可以找对应的开发进行修改和完善
如果是大批量的报错, 则需要综合评估一下修改的成本和产出.
官网的部分参数
第一个:
sendStringParameters
If the sendStringParametersAsUnicode property is set to "true", String parameters are sent to the server in Unicode format.
If the sendStringParametersAsUnicode property is set to "false", String parameters are sent to the server in non-Unicode format such as ASCII/MBCS instead of Unicode.
The default value for the sendStringParametersAsUnicode property is "true".
第二个:
selectMethod
If this property is set to "cursor," a database cursor is created for each query created on the connection for TYPE_FORWARD_ONLY and CONCUR_READ_ONLY cursors.
This property is typically required only if the application generates large result sets that can't be fully contained in client memory.
If this property is set to "cursor," only a limited number of result set rows are kept in client memory.
The default behavior is that all result set rows are kept in client memory.
This behavior provides the fastest performance when the application is processing all rows.
第三个:
serverPreparedStatement
(Version 6.2+)
This property can be used to control how many outstanding prepared statement discard actions (sp_unprepare) can be outstanding per connection
before a call to clean up the outstanding handles on the server is executed.
If this property is set to <= 1, unprepare actions are executed immediately on prepared statement close.
If it's set to > 1, these calls are batched together to avoid overhead of calling sp_unprepare too often.
其他类型:
workstationID
The workstation ID. Used to identify the specific workstation in various profiling and logging tools.
userName
The database user, if connection with SQL user and password.
sendTimeAsDatetime
Set to "true" to send java.sql.Time values to the server as SQL Server datetime values.
Set to "false" to send java.sql.Time values to the server as SQL Server time values.
一个其他的知识
使用mysql的预编译对象PrepateStatement时,
一定需要设置useServerPrepStmts=true开启服务器预编译功能,
设置cachePrepStmts=true开启客户端对预编译对象的缓存。
作者:zhuke
链接:https://www.jianshu.com/p/d46f84aef4bc
SQLServer数据库JDBC连接串参数的简单学习的更多相关文章
- sqlServer数据库常用连接字符串
sqlServer 数据库常用连接字符串 用户名和密码验证的方式去连接到数据库服务器 <add name="conStr" connectionString=" ...
- SQLServer数据库之连接查询
SQLServer数据库之连接查询 表的连接查询的几种方法介绍: inner join on内连接,left join on 左连接 , rigth join on 右连接, full join on ...
- Oracle可插拔数据库的jdbc连接串写法
我在服务器上部署某个第三方系统的数据库的时候,服务器数据库版本为oracle 12c.我采用的方式是新建了一个实例.访问正常. 后来项目的负责人告诉我,oracle12C支持所谓的可插拔数据库.可插拔 ...
- oracle,sqlserver,mysql常见数据库jdbc连接
发现JDBC连接字符串总是容易忘记,特此整理一下常用的几种数据的连接 ORACLE: /** * ORACLE * */ public static Connection getOracleConne ...
- jdbc连接sql server2017进行简单的增、删、改、查操作
这几天刚做完数据库的课程设计,来稍微总结一下如何通过jdbc访问sql server数据库进行简单的增删改查操作.在连接之前,需要简单地配置一下,包括下载对应jdk版本的驱动,设置环境变量等等.相关配 ...
- 数据库 ----jdbc连接池的弊端
jdbc连接池的弊端 1.数据库连接,使用时就创建,不使用立即释放,对数据库进行频繁连接开启和关闭,造成数据库资源浪费,影响 数据库性能.设想:使用数据库连接池管理数据库连接.2.将sql语句硬编码到 ...
- Java操作Sqlite数据库-jdbc连接
Java操作Sqlite数据库步骤: 1. 导入Sqlite jdbc 本文使用sqlite-jdbc-3.7.2.jar,下载地址 http://pan.baidu.com/s/1kVHAGdD 2 ...
- ASP.net分别连接SQLserver数据库与连接Access数据库精英版
-------------------------连接access2003 字符串------------------------- Provider=Microsoft.Jet.OLEDB.4.0; ...
- Mysql JDBC 连接串参数说明
MySQL的 JDBC URL 格式 for Connector/J 如下例: jdbc:mysql://[host:port],[host:port].../[database][?参数名1][= ...
- Mysql、Oracle、SqlServer的JDBC连接实现和对比(提供驱动包)
首先,我们需要准备数据库连接所需的jar包.目前mysql的驱动包可能比较好找,但是oracle和sqlserver的有很多,要找到能用的要花一点点心思,这里直接把下载地址和版本发送出来. Mysql ...
随机推荐
- 通过印模生成电子印章-Java源代码
以下代码是处理印模图片的核心代码,通过以下代码可以将公章图片转换为电子印章图片. 制作方式分为四步: 1.在白纸上加盖印章: 2.把加盖印章的白纸扫描,形成图片: 3.将图片通过下面的代码进行自动透明 ...
- 理论+实践详解最热的LLM应用框架LangChain
本文分享自华为云社区<LangChain是什么?LangChain的详细介绍和使用场景>,作者:码上开花_Lancer . 一.概念介绍 1.1 Langchain 是什么? 官方定义是: ...
- 云图说|每个成功的业务系统都离不开APIG的保驾护航
摘要:华为云API网关(APIG)是为企业开发者及合作伙伴提供的高性能.高可用.高安全的API托管服务, 帮助企业轻松构建.管理和部署不同规模的API. 本文分享自华为云社区<[云图说]第243 ...
- 想从单体架构演进到分布式架构,SBA 会是一个不错的选择
摘要:SBA 可以看成是单体架构和微服务架构之间的一个折中方案,它也是按照业务领域进行服务划分,但服务划分的粒度相比微服务要更粗.从单体架构演进到 SBA,会比直接演进到微服务架构更加容易. 本文分享 ...
- IaaS首席架构师的架构设计思考与实践
摘要:本文分享了华为云Stack IaaS的设计思考与实践,基于公有云先进的架构技术和创新能力,采用重构改造+积木式搭配+抽屉式替换等方式,健康的.可持续的为客户不断的提供产品和服务. 本文分享自华为 ...
- 火山引擎 DataTester 背后,抖音的名字原来是 AB 测试来的
更多技术交流.求职机会,欢迎关注字节跳动数据平台微信公众号,回复[1]进入官方交流群 抖音的名字是怎么来的? 在字节跳动火山引擎技术开放日上,字节跳动副总裁杨震原曾透露过"抖音"名 ...
- Solon 开发调试时能热更新吗?
1.调试模式 开启"调试模式"后,支持动态模板文件.静态资源文件可以实现动态更新.增加启动参数即可开启: --debug=1 使用 solon-test 进行单元测试时,会自动添加 ...
- PPT 文字穿插
软件文字,添加一个形状 先选形状,再选文字 选择拆分 设置对象格式
- MongoDB 占用CPU资源过高
情况如下 db.currentOp() 发现有全表扫描 将 Collscan 对应的 Collection 建索引 db.Table1.createIndex({"DataTime" ...
- Swagger2 Unable to infer base url. This is common
http://localhost:8080/swagger-ui.html 弹出: 解决方法:除了SwaggerConfig 上要加@EnableSwagger2 ,启动类上也要加 重启再次访问如下