sql语句和hql语句的区别?

 我来答
hu12560321
2018-07-06 · TA获得超过1.3万个赞
知道小有建树答主
回答量:172
采纳率:100%
帮助的人:23.4万
展开全部

数据库中hql与sql的区别:

1、sql 面向数据库表查询。

2、hql 面向对象查询。

3、hql : from 后面跟的 类名+类对象 where 后 用 对象的属性做条件。

4、sql: from 后面跟的是表名             where 后 用表中字段做条件查询。

5、在Hibernate中使用查询时,一般使用Hql查询语句。

6、HQL(Hibernate Query Language),即Hibernate的查询语言跟SQL非常相像。不过HQL与SQL的最根本的区别,就是它是面向对象的。

在Hibernate中使用查询时,一般使用Hql查询语句。

HQL(Hibernate Query Language),即Hibernate的查询语言跟SQL非常相像。不过HQL与SQL的最根本的区别,就是它是面向对象的。

使用HQL时需要注意以下几点:

大小写敏感

因为HQL是面向对象的,而对象类的名称和属性都是大小写敏感的,所以HQL是大小写敏感的。

HQL语句:from Cat as cat where cat.id > 1;与from Cat as cat where cat.ID > 1;是不一样的,这点与SQL不同。

from子句

from Cat,该句返回Cat对象实例,开发人员也可以给其加上别名,eg. from Cat as cat,对于多表查询的情况,可参考如下:

from Cat as cat, Dog as dog

其它方面都与SQL类似,在此不再赘述。

百度网友7429e68
推荐于2017-11-28 · 超过20用户采纳过TA的回答
知道答主
回答量:58
采纳率:0%
帮助的人:47.4万
展开全部
hql是面向对象的 。
其实还是转成了sql语句
hql在数据库通用,切换数据库方言就可以
sql在不同数据库中语法有些不同
还是sql比较灵活一些。。

HQL(Hibernate Query Language)查询提供了更加丰富的和灵活的查询特性,因此Hibernate将HQL查询方式立为官方推荐的标准查询方式,HQL查询在涵盖 Criteria查询的所有功能的前提下,提供了类似标准SQL语句的查询方式,同时也提供了更加面向对象的封装。

sql只是结构化查询语言,只是面向数据检索,不具有面向对象的特征,所以HQL更加符合开发标准!
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
祁馨姬令璟
2020-03-06 · TA获得超过3492个赞
知道大有可为答主
回答量:3107
采纳率:28%
帮助的人:193万
展开全部
1,hql可以编译成不同数据库对应的sql语言
2,hql操作类和对象,sql操作过程
3,hql会编译成sql,因此在同等情况下sql效率更高
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
屈侬御冷
2019-10-04 · TA获得超过3840个赞
知道大有可为答主
回答量:3083
采纳率:27%
帮助的人:406万
展开全部
基本上一样。只不过hql是用于ORM,即对象映射。
可能你在用的时候,普通的sql是大小写不区分,并且字段名与数据库一致。
而hql则是大小写区分,字段名与你定义的pojo对象一致。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式