一、Cannot determine value type from string ‘admin‘,二、returned by selectOne(), but found: 2

SSM的框架上根据String字段的值查询数据库中是否已存在该值

然而出现了异常报错,具体如下:

org.springframework.web.util.NestedServletException: Request processing failed; nested exception is org.springframework.dao.DataIntegrityViolationException: Error attempting to get column 'emp_name' from result set.  Cause: java.sql.SQLDataException: Cannot determine value type from string 'admin'
; Cannot determine value type from string 'admin'; nested exception is java.sql.SQLDataException: Cannot determine value type from string 'admin'
	org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1014)
	org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:898)
	javax.servlet.http.HttpServlet.service(HttpServlet.java:626)
	org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:883)
	javax.servlet.http.HttpServlet.service(HttpServlet.java:733)
	org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53)
	org.springframework.web.filter.HiddenHttpMethodFilter.doFilterInternal(HiddenHttpMethodFilter.java:94)
	org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:119)
	org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:201)
	org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:119)

原因1:类里面设置了有参构造函数,没有无参构造函数。需把无参构造函数加上

原因2:传入的参数类型不对,比如:数据库是int类型,而你输入的是String。改成一样的

原因3:输出的参数类型不对,比如:数据库查询的结果是对象集合,而你设置输出的是int 或 String

我出现的错误是原因3:

根据String字段的值查询数据库中是否已存在该值,我返回的是java.lang.Integer类型,可能当时想着根据返回个数来判断是否存在该用户,个数是int类型就直接写成Integer的了。

  <select id="checkUse" parameterType="java.lang.String" resultType="java.lang.Integer">
    select emp.emp_name
    from tbl_emp emp
    where emp_name= #{empName}
  </select>

 后面想着返回的用户名肯定是String类型,就改成如下:

  <select id="checkUse" parameterType="java.lang.String" resultType="java.lang.String">
    select emp.emp_name
    from tbl_emp emp
    where emp_name= #{empName}
  </select>

然后又出现了异常报告,原因是我查询的结果有两个,但是用String接收只能接收一个

Request processing failed; nested exception is org.mybatis.spring.MyBatisSystemException: 
nested exception is org.apache.ibatis.exceptions.TooManyResultsException:
Expected one result (or null) to be returned by selectOne(), but found: 2

解决方法:返回对象列表

<select id="checkUse" parameterType="java.lang.String" resultMap="BaseResultMapWithDept">
    select emp.emp_name
    from tbl_emp emp
    where emp_name= #{empName}
 </select>

接口中也需返回对象集合List<Employee>。
List<Employee>  checkUse(String empName);

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
"Cannot determine value type from string"是一个常见的错误信息,它意味着在程序中无法确定字符串'xxx'的值类型。这个错误可能有几种常见的原因。 首先,可能是因为在代码中使用了错误的数据类型转换方法。例如,将字符串'xxx'转换为整数类型时,但实际上该字符串不是有效的数字。 其次,可能是因为在代码中使用了不支持的数据类型转换。例如,将字符串'xxx'转换为日期类型时,但实际上该字符串不符合日期的格式要求。 另外,还有可能是因为程序中缺少必要的数据类型定义或声明。例如,在使用某个变量之前没有明确指定其数据类型。 为了解决这个问题,你可以先检查代码中的数据类型转换部分,确保使用正确的转换方法和正确的数据格式。另外,你也可以检查代码中是否有缺失的数据类型定义或声明,确保所有的变量都有明确的数据类型。 综上所述,"Cannot determine value type from string"错误的出现可能是由于错误的数据类型转换、不支持的数据类型转换或缺失的数据类型定义引起的。你可以通过检查代码中的这些方面来解决这个问题。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [关于[Cannot determine value type from string ‘xxx‘]的一些问题](https://blog.csdn.net/weixin_45966334/article/details/125925698)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [【java】Cannot determine value type from stringadmin‘几种常见报错原因](https://blog.csdn.net/weixin_46329748/article/details/116918302)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值