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 软件开发方式的革命

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

  2. atitit.提升开发效率---使用server控件生命周期 asp.net 11个阶段 java jsf 的6个阶段比較...

    atitit.提升开发效率---使用server控件生命周期  asp.net 11个阶段  java jsf 的6个阶段比較 例如以下列举了server控件生命周期所要经历的11个阶段. (1)初始 ...

  3. Atitit外包优缺点 提升开发效率 外包模式 1.一般来说外包优点 1.1.更加方便快捷 时间成本降低了 1.2.会导致 经济成本高,,时间成本降低了, 2.缺点 2.1.成本高 2.2.

    Atitit外包优缺点  提升开发效率 外包模式 一般来说外包优点 更加方便快捷  时间成本降低了 会导致 经济成本高,,时间成本降低了, 缺点 成本高 缺少控制 但是少部分,比如理发,经济时间成本都 ...

  4. order by 影响效率么_提升开发效率N倍的20+命令行神器

    图 by:石头@青海湖 关于作者:程序猿石头(ID: tangleithu),现任阿里巴巴技术专家,清华学渣,前大疆后端 Leader.以每篇文章都让人有收获为目的,欢迎关注,交流和指导! 背景 本文 ...

  5. 猿创征文|后端开发工程师提升开发效率神器推荐

    简介 对于现在的后端工程师来说,并不仅仅局限于编写代码和解决bug,这两个要素了.如果你目前还只是忙碌的写代码和改bug的话,那要深度思考一下,我为什么日复一日的写这些重复代码?这样有何意义?或者说, ...

  6. 对提升开发效率的总结

    做软件开发好几年了,总结下开发经验. 如何提升开发效率: 1.扎实的技术功底 2.强大的学习理解能力 3.丰富的处理经验 4.业务与需求的理解度 扎实的技术功底自然是作为一名优秀的开发人员必不可少的, ...

  7. idea从零到精通08之IDEA常用插件、提升开发效率

    文章目录 作者简介 引言 导航 热门专栏推荐 概述 一.插件安装方式 二.在Idea中无法直接安装插件 三.常用插件 1.ECTranslation 2.Grep Console 3.CodeGlan ...

  8. 提升开发效率N倍的20+命令行神器!(附 demo)

    点击上方蓝色字体,关注我 -- 一个在阿里云打工的清华学渣! 图 by:石头@青海湖 关于作者:程序猿石头(ID: tangleithu),现任阿里巴巴技术专家,清华学渣,前大疆后端 Leader.以 ...

  9. Python学习笔记:Day13 提升开发效率

    前言 最近在学习深度学习,已经跑出了几个模型,但Pyhton的基础不够扎实,因此,开始补习Python了,大家都推荐廖雪峰的课程,因此,开始了学习,但光学有没有用,还要和大家讨论一下,因此,写下这些帖 ...

  10. 深度解读Microsoft Build 2020:提升开发效率,优化开发环境

    Microsoft Build 2020 在众多新产品与技术发布中圆满落幕 但身为开发技术人深知 技术世界的更迭.求索却从未止步 唯有不断提升自身技能栈创新 方能从技术浮沉中获得更多养分 让技术予力世 ...

最新文章

  1. [七月挑选]使用idea创建spring boot 项目
  2. 树莓派 rtl8188eu 芯片wifi驱动
  3. [剑指offer][JAVA][面试第40题][最小的k个数][快选][堆][BST]
  4. 公文字体字号标准2020_一文了解公文格式规范,图文并茂(建议收藏备用)
  5. Android 应用开发(28)----APP功耗测试方法
  6. PYTHON之计算机语言基础知识 —— 字符编码
  7. android实现Materia Design风格APP(五):RecyclerView自定义item动画和共享元素动画
  8. android学习笔记之系统签名
  9. 51单片机DS1302时钟
  10. 大数据概述及电信大数据应用
  11. 校园江湖前情回顾(一二三)
  12. 打开计算机任务栏有桌面没,电脑桌面任务栏不显示打开的窗口怎么办
  13. SpringBoot单元测试保姆级教程,文末介绍Postman的基本使用
  14. mysql中where in用法
  15. ubuntu 我喜欢的快捷键
  16. Virtual host / experienced an error on node rabbit@ xx and may be inaccessible Totals问题的解决
  17. 多层板交期怎么才能有效把控?
  18. 如何生成26个英文字母
  19. lenove Anti-Vieus Powered by Huorong Security保护已过期怎么办
  20. 在虚拟机中通过vs2010连接到2013 access数据库

热门文章

  1. 汇编指令大全及标志位
  2. 解决ubuntu 用anaconda 安装R 语言后,无法安装R语言package的问题
  3. mybatis 注解的方式批量插入,更新数据
  4. BEGINNING SHAREPOINT#174; 2013 DEVELOPMENT 第9章节--client对象模型和REST APIs概览 client对象模型(CSOM)基础...
  5. javascript异步代码的回调地狱以及JQuery.deferred提供的promise解决方式
  6. Nginx location 配置踩坑过程分享
  7. javascript document.cookie
  8. MYSQL的简单命令
  9. 你要好好的---歌词
  10. gcc对C语言的扩展:标签变量(Labels as Values)