sql server2005 jdbc快速解决自动增长列统一处理问题纪实

    作者:课课家更新于: 2015-11-07 10:49:26

    大神带你学编程,欢迎选课
    今天由小编为大家讲解有关语言编程的文章,相信对大家一定有很大的帮助

    c语言编程入门背景:系统要支持多种,统一insert的时候获取自动增长列的处理方式
    问题1:insert+select方案
    sqlserver2000可以使用insertSql  + SELECT @@IDENTITY AS 'Identity'的方式来获得,但是则只能使用executeUpdate(insertSql);
    executeQuery('SELECT last_insert_id() ')这样的方式,否则会抛出异常:sql.SQLException: Can not issue data manipulation statements with executeQuery()
    而两句话分开处理,总让人感觉不放心,如果并发操作比较多,存在潜在的危险。
    问题2:getGeneratedKeys方案
    mysql的驱动支持jdbc3.0,实现了getGeneratedKeys(),但sqlserver2000 jdbc驱动不支持getGeneratedKeys()
    解决思路:
    google了一下,据说2005是支持的,所以下下来看看
    下载地址:url:http://download.microsoft.com/download/2/8/9/289dd6a3-eeeb-46dc-9045-d0c6b59bfbc1/sqljdbc_1.1.1501.101_chs.exe
    C语言视频教程使用小结:
    1.2005jdbc驱动是支持jdbc 3.0 的。也就是说,的确支持getGeneratedKeys()方法。
    2.2005jdbc驱动url和包组织变动较大。
    举例对比:
    ================

    在网站维护中,站长朋友常常要对网站数据进行备份,以免出现意外情况而造成数据的损失。一般的下载备份方法不仅麻烦而且速度缓慢。这时我们就可以使用程序提供的文件压缩功能来快速进行网站数据的备份。
    首先将需要备份的网站文件前的复选框选中,然后点击“添加到压缩文件”超连接,接着在弹出的对话框中输入文件名称,注意一定要输入以zip为后缀的压缩文件格式。确定后稍等片刻,一个文件压缩包就制作完成了。只需要将其下载,放置在安全的地方保存就可以了。
    在管理器主页面的功能菜单中选择“上传文件”按钮,将在网页最下方打开文件上传模块(如图2),点击“浏览”按钮选择本地文件,然后再点击上传即可。程序中的文件容量栏目会自动显示该文件占用网站空间的大小,文件大小会以KB或Byte两种单位显示。我们可以根据此功能方便的对网站文件进行整理归类操作;点击下载超连接可以将网站文件下载到本地硬盘,操作方式与普通下载方式无异,还可以使用迅雷等下载工具进行文件的高速下载;软件还提供了功能强大的编辑器(如图3),点击编辑连接后会显示文件的源代码,它还提供了本地预览与在线预览的功能,使网站文件的调试工作变得非常简单高效;

    2000
    ================
    url="jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=mydb;SelectMethod=cursor"
    driverClassName="com.microsoft.sqlserver.jdbc.SQLServerDriver"
    ================
    2005
    ================
    url="jdbc:sqlserver://localhost:1433;DatabaseName=mydb;SelectMethod=cursor"
    driverClassName="com.microsoft.jdbc.sqlserver.SQLServerDriver"
    如果没注意这点,必将出现异常:Cannot load JDBC driver class'com.microsoft.jdbc.sqlserver.SQLServerDriver'
    做好第二步,出现
    3c语言程序设计.包的位置:环境变量CLASSPATH不是必须的。但sqljdbc.jar必须放置在tomcat/common/lib中(如果是租用空间,可能得跟对方商量了,看是否支持2005的驱动)。
    否则会发生异常:Cannot load JDBC driver class'com.microsoft.sqlserver.jdbc.SQLServerDriver'
    测试示例方法:

        public  String executeUpdate(String sql) throws    SQLException ...{
            Connection conn = getConnection();
            PreparedStatement pstmt = null;
            try ...{
                /**//*注意:jdbc3.0提供了Statement.RETURN_GENERATED_KEYS"用来指明需要从Statement中获得自动增长列值,
                如果不设置该参数,在执行getGeneratedKeys()时会抛出异常:"只有运行该语句,生成的键才会可用。"*/
                pstmt = conn.prepareStatement(sql,Statement.RETURN_GENERATED_KEYS);
                pstmt.executeUpdate();
                ResultSet rs =  pstmt.getGeneratedKeys();//为了insert准备
                if (rs.next())...{
                 return rs.getString(1);
                }
                return "-1";
            } catch (SQLException ex) ...{
                    throw new SQLException(
                                              "执行SQL语句失败。" +
                                              ex.toString() +
                                              "  sql:"+sql);

            } finally ...{
                freeConnection(conn,pstmt);
            }
        }  

    看完小编的文章是不是很精彩,更多关于在线教育的文章尽在课课家,希望你们多多关注。

课课家教育

未登录