网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > Java
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
本月文章推荐
.jdk-1_5_0_04-nb-4_1-win简体中文.
.使用J2ME与MIDP进行手机开发的全.
.jBPM 在定义文件里面设置Action .
.基于SWING与AWT小应用程序的区别.
.Eclipse走向MDA,到达Rational A.
.Sun.XVR-1200图形加速器的使用.
.JDBC 解决方案.
.EJB的专用术语解释.
.手把手教您JbuliderX+Tomcat5.0的.
.Java模式研究袖珍版之Flyweight模.
.在JAVA中使用文档对象模型DOM经验.
.基于SPRING的应用增加简单规则引.
.垃圾!.
.如何用 java 编写一个扫描仪程序.
.Java 中的异常处理从概念到实例.
.如何安装配置DSML以及创建激活的.
.编程技术分享:Hibernate开发心得.
.破除Java神话之一.
..NET应用程序的授权模型使系统更.
.John Hancock互助人寿保险公司.

sqlserver2000的jdbc驱动和PreparedStatement的性能问题。

发表日期:2008-1-5


人们都说用PreparedStatement会提高程序的性能。我在sqlserver下面试了一下,结果令我大吃一惊 。
connection.setAutoCommit(false);
pstmt = connection.prepareStatement(sql);
pstmt.setFetchSize(100);
pstmt.setString(1,"026011009004");
ResultSet rs = pstmt.executeQuery();
connection.commit();
做一个查询竟然需要6秒多,在数据库里数据很少的情况下很快的,但是数据库表里面的记录多到100万的时候查询真的很慢。一开始我怀疑是jdbc驱动的事情可是我换了一个sqlserver的jdbc驱动结果还是一样。

当向pstmt 设置int类型的参数时性能又正常了。
为什么设置string类型的时候会出现的?令我百思不得其解。
我查看sqlserver jdbc 驱动的文档 发现里面有这么一个参数:
SendStringParameters
AsUnicode
SendStringParametersAsUnicode={true false}. Determines
whether string parameters are sent to the SQL Server database in
Unicode or in the default character encoding of the database.
True means that string parameters are sent to SQL Server in
Unicode. False means that they are sent in the default encoding,
which can improve performance because the server does not need
to convert Unicode characters to the default encoding. You
should, however, use default encoding only if the parameter
string data that you specify is consistent with the default
encoding of the database.
The default is true

原来string型的参数传到数据库里面默认是转换成unicode的。
当我把SendStringParameters 设置成false时,查询的性能得到了巨大的提高,原来用6秒的查询现在只需要16毫秒了。
问题解决了。


上一篇:Java程序设计的基本结构 人气:925
下一篇:理解Subjects, Principals and Credentials 人气:580
浏览全部Java的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐