徒手从零开始,使用netbeans和对象持久化,写一个典型的数据库应用程序

本文主要是介绍徒手从零开始,使用netbeans和对象持久化,写一个典型的数据库应用程序,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

转自:寂静的疯人院:点击打开链接

http://hi.baidu.com/%BC%C5%BE%B2%B5%C4%B7%E8%C8%CB%D4%BA/blog/item/dd8d4e16cbffd0064a90a793.html


    一个典型的数据库应用,就是出一个table,允许修改内容,然后能提交这些修改。 netbeans提供了wizard,一眨眼就能弄一个,但是要搞明白,还是得徒手写一遍。

    首先,建立一个空项目,啥都没有。

     然后,新建一个JFrame类,里面啥也没有。 此时run 一下,就能看到一个空的窗口。

    好,现在该填料了,放入JTable ,点右键,选择“表内容”,点“将数据导入到窗体”。 系统会自动跳出一个连接数据库的向导,选择jdbc驱动,选择表......

    完了之后,系统会自动生成一个新类,这个类对应刚才选择的表。 ORM 就建立起来了。

   

     此时如果直接运行,啥也看不到。 因为没有指定需要显示的列。

这里还能制定列的显示名称,可以用中文。

锦上添花一下,加一个JtextField上去,选“绑定”,“绑定源”选 table ,绑定表达式可以选出列的值。 其他绑定源无法选到具体的列值,只有table才行哦。

当然这步不是必须的。

好,然后运行的话,就可以看到一个表,表里有内容,选择行,则jTextField 的内容会跟随着变化。 想修改的话,也可以随便改,但是改了没用,因为没有保持功能。

最后一步: 保存

放置一个jButton ,点右键,选“事件”,选“mouse” ----“mouseClicked” 。系统自动产生一段代码:

    private void jButton1MouseClicked(java.awt.event.MouseEvent evt) {
        // TODO add your handling code here:
    }

在里面填充内容:

        testPUEntityManager.getTransaction().begin();
        for(Iterator i = athletesList.iterator(); i.hasNext();) {
            testPUEntityManager.persist(i.next());
        }
        testPUEntityManager.getTransaction().commit();

解释一下:

testPUEntityManager 是个EntityManager ,这是刚才系统生成ORM模型的时候自动搞出来的。

for ..... 这段是遍历那个athletesList , 这个List 也是系统自动搞出来的。 List 是一个数据类型,里面装了好多Athletes对象。 遍历它,可以用传统的 for (i=0 ;i++; list.size() ) ,也可以用上面这个方法。 iterator比较洋气一些,所以我用它,因为我们口号是----只用贵的,不用对的。

循环体中的 testPUEntityManager.persist(i.next()); 是关键句。 persist(object) 就是把这个object 持久化。 本文中的 i.next() 其实是个 athletes类的对象。

最后,看官会问,sql语句在哪里? 它在Query对象中

SELECT a FROM Athletes a 。 这其实不叫sql

系统自动生成了它(Query),还生成了EntityManager和List。

ok,没什么别的可说了,很简单吧。

至于ORM怎么用好,怎么替代传统数据库,前一篇说过了。 另外,用UML图可以创建类。用一些工具,比如rational Rose , PowerDesigner, Together ,可以设计类,然后让类变成数据库表,这个不详细说了。下一篇吧。



【要点】:

jTable和<实体类>List绑定,若参数是 READ_WRITE ,则 jTable变了,List会跟着变,反之亦然。

        tb = SwingBindings.createJTableBinding(AutoBinding.UpdateStrategy.READ_WRITE, sucaiList, jTable1);

【insert 怎么弄】?  咱一般都直接new 一个新的对象
Sucai s = new Sucai();
s.setDengJi(jTextField1.getText());
这样最方便,因为Sucai 这个类,Netbeans会帮助我们建好。 s.setXXXX 也都是现成的。
一堆 setXXXX 赋值完毕后,
luyinPUEntityManager.getTransaction().begin();
luyinPUEntityManager.persist(s);
luyinPUEntityManager.getTransaction().commit();
这样就保存进数据库了。
这样是不会自动关联到 jTable 然后自动刷新的。 因为jTable 关联的是 List ,它压根没变。 这里往往有一个难点,因为数据库表往往有一个auto inc 的ID,不是我们赋值的。不知道这个值,就不能直接List.add()
解决办法是,
sucaiList.clear(); 这是清空
sucaiList.addAll(sucaiQuery.getResultList() );   sucaiQuery类似sucai是一个系统自动建的类。
注意: sucaiList = sucaiQuery.getResultList(); 这样是不行的,真奇怪啊。
虽然 sucaiList.size() 会显示此list 已经有值了。

【强制刷新】
bindingGroup.unbind();
bindingGroup.bind();
系统会自动建立这两个咚咚。unbind ,bind 算是强制刷新吧。
jTable1.updateUI() ,jTable1.repaint() 有时候会出错,有时候不管用。 反正我不用。
当然,List没有变,强制也没用。

这篇关于徒手从零开始,使用netbeans和对象持久化,写一个典型的数据库应用程序的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/190252

相关文章

Java String字符串的常用使用方法

《JavaString字符串的常用使用方法》String是JDK提供的一个类,是引用类型,并不是基本的数据类型,String用于字符串操作,在之前学习c语言的时候,对于一些字符串,会初始化字符数组表... 目录一、什么是String二、如何定义一个String1. 用双引号定义2. 通过构造函数定义三、St

Pydantic中Optional 和Union类型的使用

《Pydantic中Optional和Union类型的使用》本文主要介绍了Pydantic中Optional和Union类型的使用,这两者在处理可选字段和多类型字段时尤为重要,文中通过示例代码介绍的... 目录简介Optional 类型Union 类型Optional 和 Union 的组合总结简介Pyd

Vue3使用router,params传参为空问题

《Vue3使用router,params传参为空问题》:本文主要介绍Vue3使用router,params传参为空问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录vue3使用China编程router,params传参为空1.使用query方式传参2.使用 Histo

Spring Security基于数据库的ABAC属性权限模型实战开发教程

《SpringSecurity基于数据库的ABAC属性权限模型实战开发教程》:本文主要介绍SpringSecurity基于数据库的ABAC属性权限模型实战开发教程,本文给大家介绍的非常详细,对大... 目录1. 前言2. 权限决策依据RBACABAC综合对比3. 数据库表结构说明4. 实战开始5. MyBA

使用Python自建轻量级的HTTP调试工具

《使用Python自建轻量级的HTTP调试工具》这篇文章主要为大家详细介绍了如何使用Python自建一个轻量级的HTTP调试工具,文中的示例代码讲解详细,感兴趣的小伙伴可以参考一下... 目录一、为什么需要自建工具二、核心功能设计三、技术选型四、分步实现五、进阶优化技巧六、使用示例七、性能对比八、扩展方向建

使用Python实现一键隐藏屏幕并锁定输入

《使用Python实现一键隐藏屏幕并锁定输入》本文主要介绍了使用Python编写一个一键隐藏屏幕并锁定输入的黑科技程序,能够在指定热键触发后立即遮挡屏幕,并禁止一切键盘鼠标输入,这样就再也不用担心自己... 目录1. 概述2. 功能亮点3.代码实现4.使用方法5. 展示效果6. 代码优化与拓展7. 总结1.

使用Python开发一个简单的本地图片服务器

《使用Python开发一个简单的本地图片服务器》本文介绍了如何结合wxPython构建的图形用户界面GUI和Python内建的Web服务器功能,在本地网络中搭建一个私人的,即开即用的网页相册,文中的示... 目录项目目标核心技术栈代码深度解析完整代码工作流程主要功能与优势潜在改进与思考运行结果总结你是否曾经

Linux中的计划任务(crontab)使用方式

《Linux中的计划任务(crontab)使用方式》:本文主要介绍Linux中的计划任务(crontab)使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、前言1、linux的起源与发展2、什么是计划任务(crontab)二、crontab基础1、cro

kotlin中const 和val的区别及使用场景分析

《kotlin中const和val的区别及使用场景分析》在Kotlin中,const和val都是用来声明常量的,但它们的使用场景和功能有所不同,下面给大家介绍kotlin中const和val的区别,... 目录kotlin中const 和val的区别1. val:2. const:二 代码示例1 Java

Ubuntu中远程连接Mysql数据库的详细图文教程

《Ubuntu中远程连接Mysql数据库的详细图文教程》Ubuntu是一个以桌面应用为主的Linux发行版操作系统,这篇文章主要为大家详细介绍了Ubuntu中远程连接Mysql数据库的详细图文教程,有... 目录1、版本2、检查有没有mysql2.1 查询是否安装了Mysql包2.2 查看Mysql版本2.