atitit.提升开发效率---MDA 软件开发方式的革命(3)----自动化建表
atitit.提升开发效率---MDA 软件开发方式的革命(3)----自动化建表
3. 自动建表工具::hibernate.hbm2ddl 跟Hibernate4.1 2
4. Table 'gialenweixin.gv_material' doesn't exist 4
5. hibernate Attribute "value" must be declared for element type "property". 4
1. 建模在后自动建表
1. 传统上,需要首先建表,在业务编码..
1. 摘要:很多程序只有源代码,没有配套的数据库sql语句。这样就很不容易演示或操作
2. 模型驱动建表---更多简化法是在建模在后自动建表
作者:: 老哇的爪子 Attilax 艾龙, EMAIL:1466519819@qq.com
转载请注明来源: http://blog.csdn.net/attilax
2. 自动建表的原理:
Sql生成:读取注解,生成sql,执行sql
3. 自动建表工具::hibernate.hbm2ddl 跟Hibernate4.1
配好的hibernate库和数据库的连接驱动。
数据库必须连接上,可以没有表。
Hibernate4.1已经可以自动建表,所以开发时只需要自己开发类然后配置好就OK。不需要考虑怎么建表
Hibernate配置文件生成sql文件
4. hbm2ddl最佳实践
update只是更新表结构,但不能生成..所以,你可以先用create属性,然后运行一次后改用update,以免数据丢收
3. hibernate.hbm2ddl.auto
<property name="hibernate.hbm2ddl.auto" value="update" />
update:
最常用的属性,第一次加载hibernate时根据model类会自动建立起表的结构(前提是先建立好数据库),以后加载 hibernate时根据 model类自动更新表结构,即使表结构改变了但表中的行仍然存在不会删除以前的行。要注意的是当部署到服务器后,表结构是不会被马上建立起来的,是要等 应用第一次运行起来后才会。
validate :
每次加载hibernate时,验证创建数据库表结构,只会和数据库中的表进行比较,不会创建新表,但是会插入新值
hbm2ddl 工具是个jar
hbm2ddl
5. Java语句执行
config = new Configuration()
.configure(new File("src/hibernate.cfg.xml"));
SchemaExport schemaExport = new SchemaExport(config);
schemaExport.setOutputFile("E:\\sql1.txt");
schemaExport.create(true, false);
System.out.println("Table created.");
6. 使用Ant 执行hbm2ddl
· <!-- create ddl form *.hbm.xml -->
· <target name="hbm2ddl"
· description="Generate DB schema from the O/R mapping files">
· <taskdef name="hbm2ddl"
· classname="org.hibernate.tool.ant.HibernateToolTask"
· classpathref="libraries"/>
· <hbm2ddl destdir="${ddlsqldir}">
· <configuration configurationfile="${basedir}/hibernate.cfg.xml" />
· <hbm2ddl export="true" console="false" create="true" update="false" drop="false" outputfilename="ddl.sql"/>
· </hbm2ddl>
· </target>
·
7. QA
4. Table 'gialenweixin.gv_material' doesn't exist
update只是更新表结构,但不能生成..所以,你可以先用create属性,然后运行一次后改用update,以免数据丢收
5. hibernate Attribute "value" must be declared for element type "property".
<property name="hibernate.hbm2ddl.auto" value=”update” />
Change to... Hb ver hb4
<property name="hibernate.hbm2ddl.auto" >update</property>
8. 参考
hibernate4.0+版本和3.0+版本的区别总结_xidianzxm_新浪博客.htm
Hibernate利用@DynamicInsert和@DynamicUpdate生成动态SQL语句 - QuantSeven - 博客园.htm
Hibernate配置文件生成sql文件_zjha4148_新浪博客.htm
atitit.提升开发效率---MDA 软件开发方式的革命(3)----自动化建表的更多相关文章
- atitit.提升开发效率---mda 软件开发方式的革命--(2)
atitit.提升开发效率---mda 软件开发方式的革命--(2) 1. 一个完整的MDA规范包含: 1 2. 一个完整的MDA应用程序包含: 1 3. MDA能够带来的最大的三个好处是什么? 2 ...
- atitit.提升开发效率---mda 软件开发方式的革命
atitit.提升开发效率---mda 软件开发方式的革命 1. 软件开发方式的革命开发工具的抽象层次将再次提升 1 2. 应用框架和其实现相分离 2 3. 目前的问题模型和代码不同步 2 4. MD ...
- atitit.提升开发效率---MDA 软件开发方式的革命(3)----自己主动化建表
atitit.提升开发效率---MDA 软件开发方式的革命(3)----自己主动化建表 1. 建模在后自己主动建表 1 1. 传统上,须要首先建表,在业务编码.. 1 2. 模型驱动建表---很多其它 ...
- atitit.提升开发效率---MDA 软件开发方式的革命(5)----列表查询建模
)----列表查询建模 1. 配置条件字段@Conditional 1 2. 配置条件字段显示类型为range----@Conditional(displayType = displayType.ra ...
- atitit.提升开发效率---MDA 软件开发方式的革命(4)----编辑表单建模
)----编辑表单建模 1. 建模语言的选型anno+html...不是uml 1 2. 指定显示模板 @BeanEditForm(tmplt="c:/edit.html") 1 ...
- atitit.提高开发效率---mda 革命性的软件开发方法
atitit.提高开发效率---mda 革命性的软件开发方法 1. 软件开发方式的革命开发工具的抽象层次将再次提升 1 2. 应用框架和事实上现相分离 2 3. 眼下的问题模型和代码不同步 2 4. ...
- Atitit. 提升开发效率与质量DSL ( 3) ----实现DSL的方式总结
Atitit. 提升开发效率与质量DSL ( 3) ----实现DSL的方式总结 1. 管道抽象 1 2. 层次结构抽象(json,xml etc) 1 3. 异步抽象promise 1 4. Ide ...
- atitit.提升开发效率---使用服务器控件生命周期 asp.net 11个阶段 java jsf 的6个阶段比较
atitit.提升开发效率---使用服务器控件生命周期 asp.net 11个阶段 java jsf 的6个阶段比较 如下列举了服务器控件生命周期所要经历的11个阶段. (1)初始化-- --在此 ...
- atitit.提升开发效率---动态语言总结
atitit.提升开发效率---动态语言总结 ruby,python 都不错,就是语法不好, 应用不广泛,文档,工具都非常少,不推荐... php狠不错,就是高级特性不行.. 看来子有.net/jav ...
随机推荐
- C++新特性(类)(转载)
C++新特性(类)里面讲的很清楚,转给大家分享一下 类机制: 类是对某一类对象的抽象:对象是某一类的实例: 类是一种复杂的数据类型,将不同类型的数据和这些数据相关的操作封装在一起的集合体: 通过一道程 ...
- HDU 4819 Mosaic (二维线段树)
Mosaic Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 102400/102400 K (Java/Others)Total S ...
- Selenium简单介绍
WEB自动化测试:指WEB应用系统从用户界面层面进行的自动化测试.通过用户界面测试内部的业务逻辑. 自身特点:(一)WEB页面上出现的元素有可能具有不确定性: (二)不同操作系统上不同WEB浏览器之间 ...
- 判断闰年的方法以及如何获得单链表的倒数第K个元素
今天很悲催,心中向往的公司,打电话过来面试,问到我两个问题,结果竟然都没有回答上,伤心了,记录下今天失败,希望以后不要被同样的问题给PASS. 问题1.如何判断是否为闰年 所谓闰年那就是:四年一闰,百 ...
- ListView和ScrollView冲突
当ListView放在ScrollView中的时候,无论你设置高度为 match_parent(填充父窗体)和wrap_content(包裹内容)都只显示一行,这是你把ListView放在Linear ...
- Nginx-->进阶-->Module-->ngx_http_stub_status_module
一.模块介绍 The ngx_http_stub_status_module module provides access to basic status information. This modu ...
- Python.Scrapy.11-scrapy-source-code-analysis-part-1
Scrapy 源代码分析系列-1 spider, spidermanager, crawler, cmdline, command 分析的源代码版本是0.24.6, url: https://gith ...
- 并查集+关系的传递(poj 1182)
题目:食物链 题意:给定一些关系.判断关系的正确性,后给出的关系服从之前的关系: 思路:难点不在并查集,在于关系的判断,尤其是子节点与根节点的关系的判断: 这个关系看似没给出,但是给出子节点与父节点的 ...
- 斯坦福第十三课:聚类(Clustering)
13.1 无监督学习:简介 13.2 K-均值算法 13.3 优化目标 13.4 随机初始化 13.5 选择聚类数 13.1 无监督学习:简介 在这个视频中,我将开始介绍聚类算法.这将是一个 ...
- Powershell-入门
什么是Powershell 中文博客:http://www.pstips.net/ 百度百科:是一种命令行外壳程序和脚本环境,使命令行用户和脚本编写者可以利用 .NET Framework 的强大功能 ...