org.hibernate.exception.SQLGrammarException: could not extract ResultSet


错误如下

org.hibernate.exception.SQLGrammarException: could not extract ResultSet

check the manual that corresponds to your MySQL server version for the right syntax to use near '-BookInfo bookinfo0_ where bookinfo0_.isbn='0102'' at line 1


错误代码

public int findBookPriceByIsbn(String isbn) {
		String sql = "select b.price from BookInfo b where b.isbn = ?";
		System.out.println("sql:"+sql);
		Query query = getSession().createQuery(sql);
		query.setString(0, isbn);
		int bi = (int) query.uniqueResult();
		System.out.println("hahah"+bi);
		return bi;
	}

错误原因

跟数据库没有连接上,

一般测试连接正不正常都是通过以下代码实现的

package cn.com.dao.com;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

import cn.com.dao.service.BookShopService;
public class Test {
public static void main(String[] args) {
	      ApplicationContext ioc=new ClassPathXmlApplicationContext("applicationContext.xml");

	    DataSource da=ioc.getBean(DataSource.class);
	      try {
			System.out.println(da.getConnection());
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
}
}

我运行这个代码,没有报错,也返返回连接的信息,但是

如果把数据库关闭,也测试正常

这个真的是害人不浅啊,但是我不知道为什么?

只有运行这个代码,数据库能够自动生成映射文件对应的表,就说明Spring整合Hibernate的时候连接数据库是没有问题的



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

qq_37591637

请给我持续更新的动力~~

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值