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

本文涉及的产品
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
云数据库 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
相关文章
|
2月前
|
SQL 数据库 数据库管理
【SQL server】玩转SQL server数据库:第三章 关系数据库标准语言SQL(一)模式、表、索引与视图
【SQL server】玩转SQL server数据库:第三章 关系数据库标准语言SQL(一)模式、表、索引与视图
96 11
|
7月前
|
SQL 数据库 数据安全/隐私保护
SQL Server 数据操控,视图和索引
SQL Server 数据操控,视图和索引
140 0
|
9月前
|
SQL Java 数据库连接
联表查询 && 索引 && 事务 && JDBC使用 &&CPU工作原理 && 线程概念 && Thread类的用法
联表查询 && 索引 && 事务 && JDBC使用 &&CPU工作原理 && 线程概念 && Thread类的用法
141 0
|
2月前
|
SQL 自然语言处理 搜索推荐
SQL Server 索引和视图
SQL Server 索引和视图
|
2月前
|
Java 关系型数据库 MySQL
{MySQL}索引事务和JDBC
{MySQL}索引事务和JDBC
28 0
|
2月前
|
XML SQL 存储
SQL Server的索引选择
SQL Server的索引选择
18 0
|
9月前
|
SQL 索引
com.microsoft.sqlserver.SQLServerException:索引1超出范围
com.microsoft.sqlserver.SQLServerException:索引1超出范围
59 0
|
SQL 存储 数据库
【SQL Server】数据库开发指南(六)索引和视图的使用技巧、方法与综合应用
索引就是数据表中数据和相应的存储位置的列表,利用索引可以提高在表或视图中的查找数据的速度。它类似于书籍的索引,可以帮助快速定位和检索数据。在数据库中,索引是对一个或多个列的值进行排序和存储的结构,它们包含指向实际数据位置的指针。视图就是一个虚拟的数据表,该数据表中的数据记录是由一条查询语句的查询结果得到的。
195 1
【SQL Server】数据库开发指南(六)索引和视图的使用技巧、方法与综合应用
|
SQL Java 数据库连接
com.microsoft.sqlserver.jdbc.SQLServerException: 索引 7 超出范围。
com.microsoft.sqlserver.jdbc.SQLServerException: 索引 7 超出范围。
279 0
|
12月前
|
SQL 存储 数据库
【SQL server 2008】视图、索引、架构
【SQL server 2008】视图、索引、架构
96 0