- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我很好奇我的下一个项目完全使用架构导出。我认为这是真正处理对象而非基础数据库的非常有用的方法。只需创建并注释模型,然后将其导出即可。
但是从先创建表然后创建模型对象的习惯来看,我对完全使用模式导出有疑问。这主要是因为我真的很深入休眠。但是我仍然好奇使用模式导出时,该区域列表是否会成为问题。请分享您的经验..
表之间的关系
代理/复合主键支持
当我只想从多个模型中导出一些模型时,重新导出将重新创建所有数据库。
我目前无法想到的其他人
谢谢
最佳答案
我个人不喜欢导出DDL,原因如下。
数据库可能是应用程序中基础架构中最关键的部分之一,信任DDL生成以休眠意味着您必须检查由休眠生成的所有DDL以确保一切正常,检查过程非常耗时如编写DDL。
是时候发布该应用程序的新版本了,您将拥有一个现有的数据库,因此,您可能要使用alter语句,并使用一个upgrade-version-x.sql脚本来修改现有的数据库以使新数据库与新版本一起使用。此时,自动DDL生成将无济于事,因为带注释的hibernate类仅导致生成CREATE语句,而不导致ALTER DDL语句。
Hibernate / JPA注释分为两类,逻辑的和物理的。逻辑注释将是@Entity之类的东西,物理注释将是@ Table,@ Columns等之类的东西。在物理注释上定义的属性不足,无法精确地控制为SQL生成的数据库类型。例如,假设您有一个包含Date的列,并且正在使用@ Column,@ Temporal批注,通常有不止一种适合的数据库数据类型,相信冬眠选择默认值可能不是明智之举。
始终存在休眠不了解但DBA会知晓的特定于数据库的最佳实践。例如,如果要创建索引,则无法在休眠注释中指定索引,也无法指定要创建的索引类型,例如B-Tree,Bitmap ...等。如果是JPA / Hibernate注释进行了增强以允许您指定可以在数据库特定的DDL中指定的所有选项,则注释将比SQL更复杂,因为SQL是构建良好的域特定语言,并且注释永远不会像SQL DDL那样好,他们会比较罗word。您最终要做的就是在不降低复杂性的情况下转移复杂性。考虑一下您遇到的所有基于XML的配置语言,这些语言最终会越来越复杂,直到类似于一种真正的编程语言,并带有基于xml的循环,if语句,变量等。
如果应用程序不断增长并且是一个成功的商业应用程序,它具有大量数据,那么您最终将需要雇用DBA来进行调整,优化,镜像数据库...等等,DBA会了解其数据库的最佳实践,但不一定(可能)不了解Hibernate,这会使DBA的生活更加复杂。 DBA可以对数据库进行许多更改,这些更改不会影响基于休眠的Java代码,您是否真的希望DBA更改休眠代码以更改数据库设置。一旦DBA更改了数据库设置,现在您将拥有数据库的两个版本,休眠的生产版本和生产的版本,这才是真正的版本?
数据库设计最佳实践和面向对象设计最佳实践是不同的。从对象设计数据库可能意味着一个好的OO设计,但不是那么好的DB设计,先设计DB,然后再设计面向对象的Hibernate面向对象的代码可能意味着一个好的DB设计,但不是那么好的hibernate / OO设计。从哲学上讲,我更喜欢手工编写DDL以使自己处于数据库设计模式而不是OO设计模式。在一个成功的应用程序中,数据库设计可能要持续多年才能休眠。仅仅因为休眠是当今与数据库对话的唯一内容,并不意味着它将成为将来与数据库对话的唯一内容。因此,我倾向于使用数据库设计最佳实践而不是OO最佳实践来优化数据库设计。
Hibernate / ORM是泄漏的抽象,无法向开发人员隐瞒您正在处理SQL数据库的事实,如果您的开发人员不太了解SQL(他们很可能会使用SQL),请以使数据库成为数据库的方式使用休眠瓶颈。在hibernate上培训人员的个人经验告诉我,为了有效使用Hibernate,必须更好地理解SQL。您需要能够检查HQL或其他对象查询语言,并在心理上转换为SQL。您将需要知道何时可以映射关系并遍历它们(与使用报表查询相比)。您将需要了解为什么查询中的JOIN丢失是一个问题。我是ORM / Hibernate的忠实拥护者,可以有效地使用它,但是我发现许多开发人员低估了使用诸如休眠之类的ORM工具的复杂性/复杂性。
可能导致我导出Schema的唯一例外是,如果我正在编写一个废弃的原型,并且我不太了解特定于数据库的DDL。但是我还没有遇到很多突然消失的永久性原型。
这就是我反对从Hibernate批注生成DDL的原因。我希望其他人能以自己的思想和经验来理解。
关于java - Hibernate:现实世界中的模式导出?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4561487/
一个关于Lua和元表的初学者问题,以一个简单的Hello-World为例,涉及len事件,不幸的是它没有返回预期的结果(我使用的是从 Ubuntu 官方存储库安装的 Lua 5.1)。 案子 这是示例
我正在开发一个 OpenGL 应用程序。我需要一个地球自转模型(蓝色的水,绿色的土地)。我的问题不是处理 OpenGL/图形……而是处理数据。 我在哪里可以获得这些数据? (各个国家的边界)。如果
我试图了解在 OpenGL 中创建空间: 对象空间 世界空间 相机空间 投影空间 我对这些阶段的理解是否正确? “立方体”是在笛卡尔坐标系的中心创建的,直接在程序内部输入顶点坐标。 坐标转换为“世界”
我有一个Entity和Bundle的Components,我想附加到将成为第一个实体的子实体的实体上。我可以使用Commands生成带有我的组件的实体,但是我无法获得实际的Entity,这意味着我不能
我想创建一个游戏,它有一个无尽的(实际上是一个非常大的)世界,玩家可以在其中移动。我是否会抽出时间来实现游戏是一回事,但我发现这个想法很有趣,并且希望就如何实现它提供一些意见。 关键是要有一个所有数据
以下代码片段来自维基百科,是标准 Hello World! 的序言! Brainfuck 中的程序... 1. +++++ +++++ initialize counter (
就目前情况而言,这个问题不太适合我们的问答形式。我们期望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、民意调查或扩展讨论。如果您觉得这个问题可以改进并可能重新开放,visit
我正在尝试获取特定日期剩余的确切秒数、分钟数等。这听起来可能很愚蠢,但为什么结果会翻倍呢?这看起来不对,是吗? setInterval(function() { var startDate =
如果我有两个嵌套元素,假设: Foo 然后我对外部元素应用旋转,假设顺时针旋转 45 度: Foo 现在我想将内部 div 向下移动一点。 Foo http://j
在 WindowsForms 世界中,您可以获得可用图像编码器/解码器的列表 System.Drawing.ImageCodecInfo.GetImageDecoders() / GetImageEn
因此,作为我的计算机体系结构类(class)的一部分,我需要熟悉 Assembly,或者至少足够舒适,我正在尝试读取用户的输入然后重新打印(暂时),这是我的我是如何尝试用伪代码来展示它的: 声明 ms
在 HLSL 中有很多矩阵乘法,虽然我了解如何以及在何处使用它们,但我不确定它们是如何导出的或它们的实际目标是什么。 所以我想知道是否有在线资源可以解释这一点,我特别好奇将世界矩阵乘以 View 矩阵
我正在使用 http://jvectormap.owl-hollow.net/ 中的 jVectorMap一切正常。但世界地图的标准尺寸非常小。如果有人想打例如波斯尼亚和黑塞哥维那,他需要大眼镜!有可
我在做游戏。游戏由一个无限平面组成。单位必须在一个离散的正方形上,因此可以使用简单的 Location { x :: Int, y :: Int } 来定位它们。 可能有很多种Unit s。有些可能是
所以我创建了一个顶点着色器,它接受一个角度并计算旋转。尽管模型围绕世界中心而不是它自己的轴/原点旋转,但存在一个问题。 旁注:这是 2D 旋转。 如何让模型绕着自己的轴旋转? 这是我当前的顶点着色器:
所以我创建了一个顶点着色器,它接受一个角度并计算旋转。尽管模型围绕世界中心而不是它自己的轴/原点旋转,但存在一个问题。 旁注:这是 2D 旋转。 如何让模型绕着自己的轴旋转? 这是我当前的顶点着色器:
我最近萌生了创建标签云的想法,就像地球形状的动画一样。我从 ngdc.noaa.gov 中提取了海岸线坐标,并编写了一个小脚本,将其显示在我的浏览器中。现在您可以想象,整个海岸线由大约 48919 个
我使用 3d 模式渲染我的 2d 游戏,因为相机旋转和放大/缩小比 2d 模式容易得多。 现在我遇到了一个我似乎想不出如何解决的问题: 如何使我的世界的 2d 平面以 1 个纹理像素匹配屏幕上的 1
我正在寻找一种简单快捷的方法来清除整个 Phaser 屏幕,就像在 HTML5 canvas 中,您可以通过将 Canvas 的宽度重置为自身来删除所有内容。我无法通过搜索找到任何此类方法 - 只有
是否可以为这样的游戏创建一个 2.5D 世界(双龙)http://www.youtube.com/watch?v=xb9P0YTeq5Y使用box2d? 你知道任何工作示例吗? 预先感谢您的时间。 最
我是一名优秀的程序员,十分优秀!