atitit.提升开发效率---MDA 软件开发方式的革命(3)----自动化建表

1. 建模在后自动建表 1

1. 传统上,需要首先建表,在业务编码..
1

2. 模型驱动建表---更多简化法是在建模在后自动建表 1

2. 自动建表的原理: 1

3. 自动建表工具::hibernate.hbm2ddl 跟Hibernate4.1 2

4. hbm2ddl最佳实践 2

3. hibernate.hbm2ddl.auto 2

5. Java语句执行 3

6. 使用Ant 执行hbm2ddl 3

7. QA 4

4. Table 'gialenweixin.gv_material' doesn't exist 4

5. hibernate Attribute "value" must be declared for element type "property". 4

8. 参考 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)----自动化建表的更多相关文章

  1. atitit.提升开发效率---mda 软件开发方式的革命--(2)

    atitit.提升开发效率---mda 软件开发方式的革命--(2) 1. 一个完整的MDA规范包含: 1 2. 一个完整的MDA应用程序包含: 1 3. MDA能够带来的最大的三个好处是什么? 2 ...

  2. atitit.提升开发效率---mda 软件开发方式的革命

    atitit.提升开发效率---mda 软件开发方式的革命 1. 软件开发方式的革命开发工具的抽象层次将再次提升 1 2. 应用框架和其实现相分离 2 3. 目前的问题模型和代码不同步 2 4. MD ...

  3. atitit.提升开发效率---MDA 软件开发方式的革命(3)----自己主动化建表

    atitit.提升开发效率---MDA 软件开发方式的革命(3)----自己主动化建表 1. 建模在后自己主动建表 1 1. 传统上,须要首先建表,在业务编码.. 1 2. 模型驱动建表---很多其它 ...

  4. atitit.提升开发效率---MDA 软件开发方式的革命(5)----列表查询建模

    )----列表查询建模 1. 配置条件字段@Conditional 1 2. 配置条件字段显示类型为range----@Conditional(displayType = displayType.ra ...

  5. atitit.提升开发效率---MDA 软件开发方式的革命(4)----编辑表单建模

    )----编辑表单建模 1. 建模语言的选型anno+html...不是uml 1 2. 指定显示模板 @BeanEditForm(tmplt="c:/edit.html") 1 ...

  6. atitit.提高开发效率---mda 革命性的软件开发方法

    atitit.提高开发效率---mda 革命性的软件开发方法 1. 软件开发方式的革命开发工具的抽象层次将再次提升 1 2. 应用框架和事实上现相分离 2 3. 眼下的问题模型和代码不同步 2 4.  ...

  7. Atitit. 提升开发效率与质量DSL ( 3) ----实现DSL的方式总结

    Atitit. 提升开发效率与质量DSL ( 3) ----实现DSL的方式总结 1. 管道抽象 1 2. 层次结构抽象(json,xml etc) 1 3. 异步抽象promise 1 4. Ide ...

  8. atitit.提升开发效率---使用服务器控件生命周期 asp.net 11个阶段 java jsf 的6个阶段比较

    atitit.提升开发效率---使用服务器控件生命周期  asp.net 11个阶段  java jsf 的6个阶段比较 如下列举了服务器控件生命周期所要经历的11个阶段. (1)初始化-- --在此 ...

  9. atitit.提升开发效率---动态语言总结

    atitit.提升开发效率---动态语言总结 ruby,python 都不错,就是语法不好, 应用不广泛,文档,工具都非常少,不推荐... php狠不错,就是高级特性不行.. 看来子有.net/jav ...

随机推荐

  1. gawk快速入门

    基本定义: gawk 的主要功能是针对文本的每一行执行被指定的 actions. 命令格式: gawk option program file option: -F 指定的分隔符,默认的分隔符是空格, ...

  2. 批量导入Excel存在的问题及解决方案

    许多传统的做法,导入excel就是将excel上传到服务器的某个文件夹里如upload,之后再次读取,导入系统.这边就存在一些问题: 1.服务器需要安装Office,用于读取Excel文件. 2.系统 ...

  3. discuz数据库表

    http://faq.comsenz.com/library/database/x3/x3_index.htm    discuz数据库表字典 Discuz X3各数据库表用途 pre_common_ ...

  4. 7.5 [bx+idata] 书中错误

    这节中的问题 7.1 有错误 题目和我自己的注释为: 用 Debug 查看内存,结果如下: 2000:1000 BE 00 06 00 00 00 ... 写出下面程序执行后,ax,bx,cx中的内容 ...

  5. 怎么把U盘启动改为硬盘启动(适用于U盘安装系统时)

    两种方法: 一:安装时: 在自定义创建分区后,如图: 选择系统的启动程序安装的位置,在change  device 里设置第一启动装置,和第二启动装置! 二:安装后: 开机未进入系统按F2,进入BIO ...

  6. 诡异的too manany connections报错

    问题现象: 应用重启,日志里面报错too manany connections 问题分析: 昨天割接,线上该业务线应用全部重启,一个有38个应用,每个应用3台服务器,每台服务器启动5个链接: num= ...

  7. SQL Server存储过程中防止线程重入处理方式

    对于线程重入,在C#中有lock关键字锁住一个SyncObject,而SQL Server也可用一个表来模拟实现. 先创建一个同步表,相当于C#中的SyncObject,并插入一条记录(初始值为1) ...

  8. pro生成sln

    跳转到对应的工程目录,通过执行如下的命令:qmake -tp vc 命令实现

  9. Eclipse程序员要掌握的常用快捷键

    Ctrl+K 光标放在一个变量上(注意,是变量,如果你的光标放在了字符串上,如http://keleyi.com则没有任何作用的),按下Ctrl+K光标会定位到下一个相同的变量 Shift+Ctrl+ ...

  10. 分享一张SQLSERVER执行流程的图片

    分享一张SQLSERVER执行流程的图片 有天论坛里有人问,一时间并发连接很多,是不是可以在SSMS里配置连接池 连接池是属于客户端的,配置只能在连接字符串里配置,修改你的连接字符串,SSMS没有一个 ...