com.microsoft.sqlserver.jdbc.SQLServerException: 索引 7 超出范围

本文涉及的产品
云数据库 RDS SQL Server,独享型 2核4GB
简介: com.microsoft.sqlserver.jdbc.SQLServerException: 索引 7 超出范围。

今天在做项目的时候,使用的jdbc底层增加,然后出现了个问题,找了好久没有找出来是什么问题,后来在网上查了下,发现别人都说是?写成了中文的了,于是我就返回来看,没看出来,继续找,前前后后折腾了估计有半小时还是找不出来,所有的问题都排除了,又回到了?上,难道真的是我写成了中文的了吗,重新切换输入法输入?的时候发现果然是这里的错,?写成了中文的了,大家以后一定得仔细点,别走我的老路了!下面的代码:
错误的代码:

public int addAccount(Account account) {
        int rel=0;
        String sql="insert INTO account(name,types,items_id,property_id,money,create_date,bz) " +
                "VALUES(?,?,?,?,?,?,?)";
        List<Object>prams=new ArrayList<Object>();
        prams.add(account.getName());
        prams.add(account.getTypes());
        prams.add(account.getItem_id());
        prams.add(account.getProperty_id());
        prams.add(account.getMoney());
        prams.add(account.getCreate_date());
        prams.add(account.getBz());
        System.out.println(sql);
        try {
            rel=connDbBean.executeUpdate(sql, prams);
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        } catch (SQLException e) {
            e.printStackTrace();
        }finally{
            connDbBean.closeAll();
        }
        return rel;
    }

正确的代码:

    public int addAccount(Account account) {
        int rel=0;
        String sql="insert INTO account(name,types,items_id,property_id,money,create_date,bz) " +
                "VALUES(?,?,?,?,?,?,?)";
        List<Object>prams=new ArrayList<Object>();
        prams.add(account.getName());
        prams.add(account.getTypes());
        prams.add(account.getItem_id());
        prams.add(account.getProperty_id());
        prams.add(account.getMoney());
        prams.add(account.getCreate_date());
        prams.add(account.getBz());
        System.out.println(sql);
        try {
            rel=connDbBean.executeUpdate(sql, prams);
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        } catch (SQLException e) {
            e.printStackTrace();
        }finally{
            connDbBean.closeAll();
        }
        return rel;
    }

他两的区别就在于sql语句中的问号,前者是中文输入法下的问号,后者是英文输入法下的问号,虽然看起来区别不是很大,但是程序是会报错的!

相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS&nbsp;SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/sqlserver
目录
相关文章
|
4月前
|
SQL 数据库 数据安全/隐私保护
SQL Server 数据操控,视图和索引
SQL Server 数据操控,视图和索引
99 0
|
1月前
|
SQL Java 数据库连接
com.microsoft.sqlserver.jdbc.SQLServerException: 索引 7 超出范围。
com.microsoft.sqlserver.jdbc.SQLServerException: 索引 7 超出范围。
9 0
|
6月前
|
SQL 索引
com.microsoft.sqlserver.SQLServerException:索引1超出范围
com.microsoft.sqlserver.SQLServerException:索引1超出范围
43 0
|
9月前
|
SQL 存储 数据库
【SQL server 2008】视图、索引、架构
【SQL server 2008】视图、索引、架构
87 0
|
SQL Java 数据库连接
com.microsoft.sqlserver.jdbc.SQLServerException: 索引 7 超出范围。
com.microsoft.sqlserver.jdbc.SQLServerException: 索引 7 超出范围。
233 0
|
10月前
|
SQL 存储 数据库
【SQL Server】数据库开发指南(六)索引和视图的使用技巧、方法与综合应用
索引就是数据表中数据和相应的存储位置的列表,利用索引可以提高在表或视图中的查找数据的速度。它类似于书籍的索引,可以帮助快速定位和检索数据。在数据库中,索引是对一个或多个列的值进行排序和存储的结构,它们包含指向实际数据位置的指针。视图就是一个虚拟的数据表,该数据表中的数据记录是由一条查询语句的查询结果得到的。
148 1
【SQL Server】数据库开发指南(六)索引和视图的使用技巧、方法与综合应用
|
索引
SqlServer 事物与索引
SqlServer 事物与索引
49 0
|
SQL 存储 数据库
数据库原理与应用(SQL Server)笔记 第五章 索引和视图
数据库原理与应用(SQL Server)笔记 第五章 索引和视图
数据库原理与应用(SQL Server)笔记 第五章 索引和视图
|
存储 SQL 数据库
SQL Server——SQL Server视图及索引技术
SQL Server——SQL Server视图及索引技术
263 0
SQL Server——SQL Server视图及索引技术
|
SQL 索引
Microsoft SQL Server 2008 R2出现索引超出数组界限
Microsoft SQL Server 2008 R2出现索引超出数组界限
491 0
Microsoft SQL Server 2008 R2出现索引超出数组界限

相关实验场景

更多