hibernate为什么要有方言?HQL是什么?
数据库的语言不是都差不多么,为什么要设置方言,而且还每种数据库都不同。然后HQL是什么?麻烦大概说一下。和方言有什么区别?...
数据库的语言不是都差不多么,为什么要设置方言,而且还每种数据库都不同。
然后HQL是什么?麻烦大概说一下。
和方言有什么区别? 展开
然后HQL是什么?麻烦大概说一下。
和方言有什么区别? 展开
4个回答
展开全部
首先数据库都是支持sql的,不过不同的数据库会存在一些语法上面的差异,而方言则是解决hql翻译成sql保证语法的正确。
hql则是基于对象的查询语言,hibernate会结合对象的配置文件以及方言,将写的hql翻译成sql。
至于为什么要这么做,假如系统需要数据库的变换时,那么用hibernate的话就只需要改一改配置文件(修改连接字符串、驱动类、方言等),而用传统的jdbc时,那么sql语言可能就要有很多改动,基本就是dao层重写一遍吧。
hql则是基于对象的查询语言,hibernate会结合对象的配置文件以及方言,将写的hql翻译成sql。
至于为什么要这么做,假如系统需要数据库的变换时,那么用hibernate的话就只需要改一改配置文件(修改连接字符串、驱动类、方言等),而用传统的jdbc时,那么sql语言可能就要有很多改动,基本就是dao层重写一遍吧。
2016-01-28
长沙汇德教育咨询有限公司
汇德教育,专注于职(执)业资格培训、学历教育、证书挂靠、人才服务、教育产品研发为一体的大型职业教育机构。汇德教育拥有超前的发展理念,领先的发展战略,良好的发展基础,为企业和个人提供全方位服务
向TA提问
关注
展开全部
hibernate中,方言是解决hql翻译成sql保证语法的正确,首先数据库都是支持sql的,不同的数据库会存在一些语法上面的差异。
HQL则是基于对象的查询语言,当系统需要数据库的变换时,那么用hibernate的话就只需要改一改配置文件(修改连接字符串、驱动类、方言等),而用传统的jdbc时,那么sql语言可能就要有很多改动。
HQL则是基于对象的查询语言,当系统需要数据库的变换时,那么用hibernate的话就只需要改一改配置文件(修改连接字符串、驱动类、方言等),而用传统的jdbc时,那么sql语言可能就要有很多改动。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
其实每家公司的数据库产品都只有不超过80%的符合标准sql。
例如oracle的pL/sql就根本跟通常的sql相去甚远。
而且每种产品的jdbc驱动也不相同,所以需要定义方言。
例如oracle的pL/sql就根本跟通常的sql相去甚远。
而且每种产品的jdbc驱动也不相同,所以需要定义方言。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
hibernate相当于封住了一次jdbc,使hibernate不用考虑你是用的什么数据库,他的HQL语句都可以根据你不同数据库的方言编译成相对应的数据库sql语句,这是hibernate的一大优势,但是因为他的HQL语句都要经过编译才能成对应数据库可以执行的语句,所以用它做持久层他比ibatis稍慢。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询