关于hibernate多条件查询

Queryquery=session.createQuery("fromXsxkb_beanxsxkwherexsxk."+propertyNameO+"="+value... Query query = session.createQuery("from Xsxkb_bean xsxk where xsxk."+propertyNameO+" ="+valueO+" and xsxk."+propertyNameT+" ="+valueT);
List<Xsxkb_bean> list = query.list();
org.hibernate.exception.SQLGrammarException: could not execute query
at org.hibernate.exception.SQLStateConverter.convert(SQLStateConverter.java:90)
at org.hibernate.exception.JDBCExceptionHelper.convert(JDBCExceptionHelper.java:66)
at org.hibernate.loader.Loader.doList(Loader.java:2235)
at org.hibernate.loader.Loader.listIgnoreQueryCache(Loader.java:2129)
at org.hibernate.loader.Loader.list(Loader.java:2124)
at org.hibernate.loader.hql.QueryLoader.list(QueryLoader.java:401)
at org.hibernate.hql.ast.QueryTranslatorImpl.list(QueryTranslatorImpl.java:363)
at org.hibernate.engine.query.HQLQueryPlan.performList(HQLQueryPlan.java:196)
at org.hibernate.impl.SessionImpl.list(SessionImpl.java:1149)
at org.hibernate.impl.QueryImpl.list(QueryImpl.java:102)
at dao.impl.XsxkbImpl.selectByThree(XsxkbImpl.java:66)
at function.impl.GetHtmlStringFunction_impl.getXsmdString(GetHtmlStringFunction_impl.java:88)
at fx.actionForAjax.GetXsmd.getXsmd(GetXsmd.java:66)
... 72 more
展开
 我来答
CM娱新世界
推荐于2016-01-24 · TA获得超过308个赞
知道小有建树答主
回答量:337
采纳率:100%
帮助的人:142万
展开全部

你这典型的将hibernate+标准sql混合使用

xsxk."+propertyNameO+" ="+valueO+" and xsxk."+propertyNameT+" ="+valueT

xsxk.属性名="+valueO+"

Storm代理
2023-07-25 广告
StormProxies是一家国内优质海外HTTP代理商,拥有一个庞大的IP资源池,覆盖200多个地区,IP数量大且匿名度高。其优点还包括超高并发、稳定高效、技术服务等特点,同时提供HTTP、HTTPS以及SOCKS5协议支持。此外,Sto... 点击进入详情页
本回答由Storm代理提供
匿名用户
2013-11-17
展开全部
为何不使用参数的做法呢
追问
什么参数的做法?
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
趣事情
推荐于2016-08-15 · 知道合伙人互联网行家
趣事情
知道合伙人互联网行家
采纳数:517 获赞数:5452
电脑技术,软件开发。移动开发。网站建设相关专业知识。都可以提供解答和相关技术指导。

向TA提问 私信TA
展开全部
1.使用CTime类(获取系统当前时间,精确到秒)
CString str;
//获取系统时间
CTime tm;
tm=CTime::GetCurrentTime();//获取系统日期
str=tm.Format("现在时间是%Y年%m月%d日 %X");
MessageBox(str,NULL,MB_OK);

a,从CTimet中提取年月日时分秒

 CTime t = CTime::GetCurrentTime();
  int d=t.GetDay(); //获得几号

  int y=t.GetYear(); //获取年份

  int m=t.GetMonth(); //获取当前月份

  int h=t.GetHour(); //获取当前为几时

  int mm=t.GetMinute(); //获取分钟

  int s=t.GetSecond(); //获取秒

  int w=t.GetDayOfWeek(); //获取星期几,注意1为星期天,7为星期六

b,计算两段时间的差值,可以使用CTimeSpan类,具体使用方法如下:

  CTime t1( 1999, 3, 19, 22, 15, 0 );

CTime t = CTime::GetCurrentTime();

CTimeSpan span=t-t1; //计算当前系统时间与时间t1的间隔

  int iDay=span.GetDays(); //获取这段时间间隔共有多少天

  int iHour=span.GetTotalHours(); //获取总共有多少小时

  int iMin=span.GetTotalMinutes();//获取总共有多少分钟

  int iSec=span.GetTotalSeconds();//获取总共有多少秒

c,获得当前日期和时间,并可以转化为CString

  CTime tm=CTime::GetCurrentTime(); CString str=tm.Format("%Y-%m-%d");//显示年月日

2.使用GetLocalTime:Windows API 函数,获取当地的当前系统日期和时间 (精确到毫秒)

  此函数会把获取的系统时间信息存储到SYSTEMTIME结构体里边

  typedef struct _SYSTEMTIME

  {

  WORD wYear;//年
  WORD wMonth;//月
  WORD wDayOfWeek;//星期:0为星期日,1为星期一,2为星期二……
  WORD wDay;//日
  WORD wHour;//时
  WORD wMinute;//分
  WORD wSecond;//秒
  WORD wMilliseconds;//毫秒
  }SYSTEMTIME,*PSYSTEMTIME;
例:
SYSTEMTIME st;
CString strDate,strTime;
GetLocalTime(&st);
strDate.Format("%4d-%2d-%2d",st.wYear,st.wMonth,st.wDay);
strTime.Format("%2d:%2d:%2d",st.wHour,st.wMinute,st.wSecond) ;
AfxMessageBox(strDate);
AfxMessageBox(strTime);

3.使用GetTickCount:从操作系统启动到现在所经过(elapsed)的毫秒数,它的返回值是DWORD。(精确到毫秒)

//获取程序运行时间
long t1=GetTickCount();//程序段开始前取得系统运行时间(ms)
Sleep(500);
long t2=GetTickCount();();//程序段结束后取得系统运行时间(ms)
str.Format("time:%dms",t2-t1);//前后之差即 程序运行时间
AfxMessageBox(str);
//获取系统运行时间
long t=GetTickCount();
CString str,str1;
str1.Format("系统已运行 %d时",t/3600000);
str=str1;
t%=3600000;
str1.Format("%d分",t/60000);
str+=str1;
t%=60000;
str1.Format("%d秒",t/1000);
str+=str1;
AfxMessageBox(str);
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式