Redian新闻
>
请求审稿机会,谢谢!
avatar
d*e
2
Gulfstream Aerospace Corporation will be conducting interviews in Wichita,
KS on Wednesday, September 7 for positions located in Savannah, Georgia.
We are hiring for these skills now!
Aircraft Technicians
Interior Installers
Airworthiness Inspectors
Avionics Installers
Wire Harness Installation Engineers
Electrical Applications Engineers
Flight Deck & Furnishings Design Engineers
Flight Dynamics Engineers
Please contact Barbara Cromer ASAP at b************[email protected] to be
considered for interview.
We are also hosting an information session and would love for you to be our
guest!
Wednesday, September 7
Hyatt Regency Wichita
400 West Waterman
Wichita, Kansas
6:30 p.m.
Please come and learn more about the lifestyle, opportunity, challenge and
growth that a Gulfstream career can offer!
To view our current career opportunities please visit
jobs.gulfstream.com
avatar
s*7
3
请推荐审稿的机会,以下的方向都可以,十分感谢
avatar
d*e
5
anyone went?
avatar
t*e
6
买本书看看吧。这些问题很基本,每本hibernate书都会提到。而且用了hibernate,以
后碰到的问题会越来越多的。
avatar
T*g
7
简单说说我用Hibernate碰到的一些问题
1) 当SQL复杂到一定程度的时候,HQL和CRITERIA都非常难生成。
2) 当HIBERNATE升级的时候,很多兼容性问题。比如说你现在在用HIBERNATE 3.6,AP
P SERVER WEBLOGIC 10.3,假如你想要升级HIBERNATE到4.1,简直是场噩梦,太多HIBE
RNATE的DEPENDENCY,太多第三方的JAR和CONTAINER 提供的JAR有冲突。
3) CACHE。HIBERNATE的一级和二级缓存全部是关于ID的CACHE或者是QUERY CACHE。CA
CHE层被做到了DAO的下面,假设说我现在已经知道DATA实际就在CACHE里,而我想做基于
TABLE某个COLUMN的查找,HIBERNATE还是要DB SEARCH,因为它不知道应该在CACHE中查
找,这会大幅影响PERF。我觉得如果是大型项目的话,要避免HIBERNATE。可以考虑用SP
RING JDBC加某种分布式CACHE的结构,这样简单,快速,DEPEDENCY少。

【在 m***g 的大作中提到】
: 没用过 hibernate, project 需要,想看看是不是合适
: 比如下面的 class
: class A {
: int id;
: int a;
: int b;
: A next;
: }
: 是不是 hibernate 没法映射 next,我必须自己转换成 List 才行
: 还有一个问题就是,每个 class 都必须有 id 么,没有系统可以自动生成么?

avatar
B*g
8
thanks。
还有没有其他大牛讲讲hibernate的其他好处。俺也在学hibernate,感觉太费劲,
hibernate能干的俺写SQL都不用动脑子。SPRING还不会,要看看直接jdbc缓存怎么用。

AP
HIBE
CA
基于
SP

【在 T*********g 的大作中提到】
: 简单说说我用Hibernate碰到的一些问题
: 1) 当SQL复杂到一定程度的时候,HQL和CRITERIA都非常难生成。
: 2) 当HIBERNATE升级的时候,很多兼容性问题。比如说你现在在用HIBERNATE 3.6,AP
: P SERVER WEBLOGIC 10.3,假如你想要升级HIBERNATE到4.1,简直是场噩梦,太多HIBE
: RNATE的DEPENDENCY,太多第三方的JAR和CONTAINER 提供的JAR有冲突。
: 3) CACHE。HIBERNATE的一级和二级缓存全部是关于ID的CACHE或者是QUERY CACHE。CA
: CHE层被做到了DAO的下面,假设说我现在已经知道DATA实际就在CACHE里,而我想做基于
: TABLE某个COLUMN的查找,HIBERNATE还是要DB SEARCH,因为它不知道应该在CACHE中查
: 找,这会大幅影响PERF。我觉得如果是大型项目的话,要避免HIBERNATE。可以考虑用SP
: RING JDBC加某种分布式CACHE的结构,这样简单,快速,DEPEDENCY少。

avatar
T*g
9
没有直接JDBC缓存。一个简单的方法是用AOP拦截所有DAO里操作DB的方法,实现对缓存
数据的先查找,或者后更新。
你可以通过HIBERNATE学习一些一般的对DB操作的知识,比如说怎么通过乐观锁来提高并
发,悲观锁是什么概念,应该怎么使用。如何设计long session等等。你可以看看gavi
n king和christan baur写的Hibernate in action
Hibernate现在衍生出了一些很有意思的小项目,比如Hibernate shard,我觉得要是有
空的话,看看也挺有意思的。
意见仅供参考,本人并非大牛。

【在 B*****g 的大作中提到】
: thanks。
: 还有没有其他大牛讲讲hibernate的其他好处。俺也在学hibernate,感觉太费劲,
: hibernate能干的俺写SQL都不用动脑子。SPRING还不会,要看看直接jdbc缓存怎么用。
:
: AP
: HIBE
: CA
: 基于
: SP

avatar
g*g
10
Hibernate is an ORM. So the biggest benefit is the ORM, which
makes a clear layered structure, some level of DB independency.
e.g. If your project needs to support MySQL and Oracle at the
same time, it's much tougher to use plain SQL. Also, secondary
caching can be had with zero coding.

【在 B*****g 的大作中提到】
: thanks。
: 还有没有其他大牛讲讲hibernate的其他好处。俺也在学hibernate,感觉太费劲,
: hibernate能干的俺写SQL都不用动脑子。SPRING还不会,要看看直接jdbc缓存怎么用。
:
: AP
: HIBE
: CA
: 基于
: SP

avatar
B*g
11
简单sql支持不同数据库根本不是问题,复杂的要不同,不过hibernate也不支持
现在只发现caching确实是个好东西

【在 g*****g 的大作中提到】
: Hibernate is an ORM. So the biggest benefit is the ORM, which
: makes a clear layered structure, some level of DB independency.
: e.g. If your project needs to support MySQL and Oracle at the
: same time, it's much tougher to use plain SQL. Also, secondary
: caching can be had with zero coding.

avatar
g*g
12
你低估了当你需要效率并有一定复杂度时ORM有多好用。
举个简单例子,一个20个column的user profile table.
每个column都可能被单独修改,而你又希望只写改动
的column。用JDBC你试试?

【在 B*****g 的大作中提到】
: 简单sql支持不同数据库根本不是问题,复杂的要不同,不过hibernate也不支持
: 现在只发现caching确实是个好东西

avatar
B*g
13
re

【在 g*****g 的大作中提到】
: 你低估了当你需要效率并有一定复杂度时ORM有多好用。
: 举个简单例子,一个20个column的user profile table.
: 每个column都可能被单独修改,而你又希望只写改动
: 的column。用JDBC你试试?

avatar
r*s
14
这玩儿本来没啥好争论的
sql vs hibernate就不是一层的东西
ORM的关键是mapping不是query
你不需要考虑mapping的问题就不需要hibernate

【在 g*****g 的大作中提到】
: 你低估了当你需要效率并有一定复杂度时ORM有多好用。
: 举个简单例子,一个20个column的user profile table.
: 每个column都可能被单独修改,而你又希望只写改动
: 的column。用JDBC你试试?

avatar
t*e
15
感觉你的第一点导致了第三点的结论。
2nd-level cache是为lazy loading准备的。cache的key就是entity的primary key。只
有foreign key已知的情况,比如many-to-one,等等,这个cache才起作用。
一般情况下hibernate如何使用,看看RAD tool自动生成的code就明白了。lazy
loading为主,先把root object搞回来,再on demand搞relationships (2nd-level
cache有用了)。在java里面处理数据。如果performance太差了,再搞eager fetch来优
化。
Reporting database,ODS之类的会比较多用到复杂的query。这种情况2nd-level
cache几乎没用。query cache可以用,效果和spring cache一模一样,问题是你不知道
什么时候cache结果已经过时了。所以说用spring cache+jdbc效率的确差不多。

AP
HIBE
CA
基于
SP

【在 T*********g 的大作中提到】
: 简单说说我用Hibernate碰到的一些问题
: 1) 当SQL复杂到一定程度的时候,HQL和CRITERIA都非常难生成。
: 2) 当HIBERNATE升级的时候,很多兼容性问题。比如说你现在在用HIBERNATE 3.6,AP
: P SERVER WEBLOGIC 10.3,假如你想要升级HIBERNATE到4.1,简直是场噩梦,太多HIBE
: RNATE的DEPENDENCY,太多第三方的JAR和CONTAINER 提供的JAR有冲突。
: 3) CACHE。HIBERNATE的一级和二级缓存全部是关于ID的CACHE或者是QUERY CACHE。CA
: CHE层被做到了DAO的下面,假设说我现在已经知道DATA实际就在CACHE里,而我想做基于
: TABLE某个COLUMN的查找,HIBERNATE还是要DB SEARCH,因为它不知道应该在CACHE中查
: 找,这会大幅影响PERF。我觉得如果是大型项目的话,要避免HIBERNATE。可以考虑用SP
: RING JDBC加某种分布式CACHE的结构,这样简单,快速,DEPEDENCY少。

avatar
T*g
16
假设这样一种简单情况,我的MEM足够大,且我把某个表中所有的数据都已经LOAD到了C
ACHE中。我想实现的是对该表任意COLUMN的查询。HIBERNATE能有效的避免数据库命中吗
?我想不能。

【在 t*******e 的大作中提到】
: 感觉你的第一点导致了第三点的结论。
: 2nd-level cache是为lazy loading准备的。cache的key就是entity的primary key。只
: 有foreign key已知的情况,比如many-to-one,等等,这个cache才起作用。
: 一般情况下hibernate如何使用,看看RAD tool自动生成的code就明白了。lazy
: loading为主,先把root object搞回来,再on demand搞relationships (2nd-level
: cache有用了)。在java里面处理数据。如果performance太差了,再搞eager fetch来优
: 化。
: Reporting database,ODS之类的会比较多用到复杂的query。这种情况2nd-level
: cache几乎没用。query cache可以用,效果和spring cache一模一样,问题是你不知道
: 什么时候cache结果已经过时了。所以说用spring cache+jdbc效率的确差不多。

avatar
T*g
17
这个你说的很有道理。
我觉得在低并发,且开发效率优先的情况下,用ORM框架还是有好处的。

【在 g*****g 的大作中提到】
: 你低估了当你需要效率并有一定复杂度时ORM有多好用。
: 举个简单例子,一个20个column的user profile table.
: 每个column都可能被单独修改,而你又希望只写改动
: 的column。用JDBC你试试?

avatar
g*g
18
我不明白你在说啥,如果所有数据都在一级或者二级缓存里,
hibernate当然不会去数据库。

了C
中吗

【在 T*********g 的大作中提到】
: 假设这样一种简单情况,我的MEM足够大,且我把某个表中所有的数据都已经LOAD到了C
: ACHE中。我想实现的是对该表任意COLUMN的查询。HIBERNATE能有效的避免数据库命中吗
: ?我想不能。

avatar
t*e
19
cache只对fetch by primary key有用,因为cache的key就是entity的ID, arbitrary
query还是map成SQL执行的。即便整个table都cache了,hibernate根本不懂在cache里执
行JPQL或SQL的。

【在 g*****g 的大作中提到】
: 我不明白你在说啥,如果所有数据都在一级或者二级缓存里,
: hibernate当然不会去数据库。
:
: 了C
: 中吗

avatar
T*g
20
呵呵。基于某个COLUMN属性的查询,比如说 SELECT * FROM A a.prop = 1. 结果查询出
来之后,Hibernate把命中的对象放在二级缓存里,假如说全表所有的TUPLE都满足a.pr
op =1,那么其实全表都已经LOAD在内存里了。第二次查询的时候,我select * from A
where a.prop = 2。 虽然结果集已经在MEM里了,因为HIBERNATE不知道满足a.prop =
2的TUPLE有哪些,它还是会做SQL从DB里取,而且REFLECT生成结果集,并且重新REFRES
H二级缓存。所以,并不是说你的结果集已经在MEM中,HIBERNATE就不去DB了。这是HIB
ERNATE的DESIGN决定的。我觉得这不是一个有效率的好方法。

【在 g*****g 的大作中提到】
: 我不明白你在说啥,如果所有数据都在一级或者二级缓存里,
: hibernate当然不会去数据库。
:
: 了C
: 中吗

avatar
T*g
21
是。所以我觉得用类似Coherence一类的CACHE框架,在去HIBERNATE 做DB操作之前先查
找会更有效率。不过这种DESIGN就是以分布式CACHE为中心了。

里执

【在 t*******e 的大作中提到】
: cache只对fetch by primary key有用,因为cache的key就是entity的ID, arbitrary
: query还是map成SQL执行的。即便整个table都cache了,hibernate根本不懂在cache里执
: 行JPQL或SQL的。

avatar
a*n
22
用了n年的hinernate, 包括sharding. 也算半个砖家。
对我来说,hinernate的好处不在于object-relation-mapping. 数据库和对象的转换其
实很简单,有那么几百行程序就完全够用了。在我最近的一个项目中就自己实现了。
对我来说,hibernate的最大的好处是数据库table的自己创建。java类中增加了一个
field, hibernate就能自动在表中创建列。大大减少了开发人员的工作,提高了效率。
在单元测试中,用in-memory数据库的时候更是必不可少。这里也能体现hibernate的另
外一个好处就是隐藏了数据库之间的差异。
我用maven的时候,一般说来会创建几个profile, 比如 test, dev, stage, prod. 在
test profile中, 激活hibernate, 主要用于自动生成test需要的hsqldb in-memory
数据库。 在dev profile 中,一般说来是localhost mysql. 也激活hibernate, 帮我
自动生成mysql tables. 然后手工修改一些东西,比如创建fulltext 索引, trigger
等。stage和prod环境中完全不用hibernate. 我用自己写的一些orm和spring的
jdbctemplate.

【在 m***g 的大作中提到】
: 没用过 hibernate, project 需要,想看看是不是合适
: 比如下面的 class
: class A {
: int id;
: int a;
: int b;
: A next;
: }
: 是不是 hibernate 没法映射 next,我必须自己转换成 List 才行
: 还有一个问题就是,每个 class 都必须有 id 么,没有系统可以自动生成么?

avatar
s*o
23
do you also implement change tracking within your own orm?

memory

【在 a*******n 的大作中提到】
: 用了n年的hinernate, 包括sharding. 也算半个砖家。
: 对我来说,hinernate的好处不在于object-relation-mapping. 数据库和对象的转换其
: 实很简单,有那么几百行程序就完全够用了。在我最近的一个项目中就自己实现了。
: 对我来说,hibernate的最大的好处是数据库table的自己创建。java类中增加了一个
: field, hibernate就能自动在表中创建列。大大减少了开发人员的工作,提高了效率。
: 在单元测试中,用in-memory数据库的时候更是必不可少。这里也能体现hibernate的另
: 外一个好处就是隐藏了数据库之间的差异。
: 我用maven的时候,一般说来会创建几个profile, 比如 test, dev, stage, prod. 在
: test profile中, 激活hibernate, 主要用于自动生成test需要的hsqldb in-memory
: 数据库。 在dev profile 中,一般说来是localhost mysql. 也激活hibernate, 帮我

avatar
a*n
24
no and no cache.

【在 s***o 的大作中提到】
: do you also implement change tracking within your own orm?
:
: memory

avatar
s*o
25
without change tracking, how do you make persistence of your domain changes?
Recently I had a look on some "micro ORMs" (that's what we call them in .
NET world), and this is one problem I haven't found an answer...

【在 a*******n 的大作中提到】
: no and no cache.
avatar
t*e
26
正好看到这一块,过来update一下。
Shared Cache in JBoss/Hibernate4.0 - Infinispan, is marketed as a
"Transactional in-memory key/value NoSQL datastore & Data Grid"

里执

【在 t*******e 的大作中提到】
: cache只对fetch by primary key有用,因为cache的key就是entity的ID, arbitrary
: query还是map成SQL执行的。即便整个table都cache了,hibernate根本不懂在cache里执
: 行JPQL或SQL的。

avatar
a*a
27

memory
That is an interesting statement.
That is funny: Hibernate benefits Maven workflow only

【在 a*******n 的大作中提到】
: 用了n年的hinernate, 包括sharding. 也算半个砖家。
: 对我来说,hinernate的好处不在于object-relation-mapping. 数据库和对象的转换其
: 实很简单,有那么几百行程序就完全够用了。在我最近的一个项目中就自己实现了。
: 对我来说,hibernate的最大的好处是数据库table的自己创建。java类中增加了一个
: field, hibernate就能自动在表中创建列。大大减少了开发人员的工作,提高了效率。
: 在单元测试中,用in-memory数据库的时候更是必不可少。这里也能体现hibernate的另
: 外一个好处就是隐藏了数据库之间的差异。
: 我用maven的时候,一般说来会创建几个profile, 比如 test, dev, stage, prod. 在
: test profile中, 激活hibernate, 主要用于自动生成test需要的hsqldb in-memory
: 数据库。 在dev profile 中,一般说来是localhost mysql. 也激活hibernate, 帮我

avatar
a*a
28

Hibernate won't don what you claimed either.
For same reasons I designed two OR mapping models. Hibernate has a big
performance problem if you have tons data.

【在 g*****g 的大作中提到】
: 你低估了当你需要效率并有一定复杂度时ORM有多好用。
: 举个简单例子,一个20个column的user profile table.
: 每个column都可能被单独修改,而你又希望只写改动
: 的column。用JDBC你试试?

avatar
a*n
29
not quite sure about the problem you mentioned. the Micro ORM just some
helper classes. for example, orm.insert(Object), orm.update(object, columns.
..), orm.select(class, sql)

changes?

【在 s***o 的大作中提到】
: without change tracking, how do you make persistence of your domain changes?
: Recently I had a look on some "micro ORMs" (that's what we call them in .
: NET world), and this is one problem I haven't found an answer...

avatar
g*g
30
I could be wrong, I haven't been doing hibernate stuff for 3 years.
But I think it does check against your cached copy in memory
and it can do smart query.

【在 a*****a 的大作中提到】
:
: Hibernate won't don what you claimed either.
: For same reasons I designed two OR mapping models. Hibernate has a big
: performance problem if you have tons data.

相关阅读
logo
联系我们隐私协议©2024 redian.news
Redian新闻
Redian.news刊载任何文章,不代表同意其说法或描述,仅为提供更多信息,也不构成任何建议。文章信息的合法性及真实性由其作者负责,与Redian.news及其运营公司无关。欢迎投稿,如发现稿件侵权,或作者不愿在本网发表文章,请版权拥有者通知本网处理。