Hibernate4 java.lang.ClassCastException

使用hibernate4java

public boolean exists(User user) {
	    SessionFactory factory = configureSessionFactory();
	    Session session = factory.getCurrentSession();
	T    ransaction transaction = session.beginTransaction();  
		
	    String sql = "select * FROM user";  
	    Query q = session.createSQLQuery(sql);  
	   
	    List<User> list = q.list(); 
	    transaction.commit();
	    for(User temp:list){
	    	if(temp.getUname().equals(user.getUname())){
	    		return true;
	    	}
	    }
	    return false;
		
	}

运行时报异常sql

java.lang.ClassCastException: [Ljava.lang.Object; cannot be cast to entiey.User

后来多方查找,发现有这样一种写法session

public boolean exists(User user) {
		SessionFactory factory = configureSessionFactory();
		Session session = factory.getCurrentSession();
		Transaction transaction = session.beginTransaction();  
		
		String sql = "select * FROM user";  
	    Query q = session.createSQLQuery(sql).addEntity(User.class);  
	    
	    List<User> list = q.list(); 
	    transaction.commit();
	    for(User temp:list){
	    	if(temp.getUname().equals(user.getUname())){
	    		return true;
	    	}
	    }
	    return false;
		
	}

试了下,果真正常了。原来查询后要加上hibernate

addEntity(User.class)