demo  设 计

一个知识点demo,在数据库和用户界面的互动事件。分三个层次,数据存储,数据方法工具,数据呈现界面。这一次先完成数据存储,按以下逻辑实现。工具:eclipse,oracle数据库,sqldeveloper(改用oracle的sqldeveloper)。(当后面数据库复杂时可以考虑PowerDesigner。)

1、考虑软件功能、数据方法、商业元素、逻辑扩展等实用因素,设计实体类。

2、用jdbc连接oracle数据库。

3、数据储存在数据库中,分析oracle数据库的数据类型。

4、数据从oracle数据库,到java操作oracle数据库,那么数据库的数据类型是如何转换成java数据类型的呢?可以推理出,数据库的数据类型和java数据类型存在对应关系。用java测试数据类型的对应关系。

5、demo数据录入,在ide的console界面读取数据(程序员的用户界面)。

下面一一述说。

1、如图。

2、先导入jdbc的jar包,jdbc连接数据库可以参考以下步骤。

(1)加载jdbc驱动。通过java.lang.Class类的静态方法forName(String  className),加载想要连接的数据库的驱动到JVM(Java虚拟机),成功加载后,会将Driver类的实例注册到DriverManager类中。

(2)提供jdbc参数。连接oracle数据库的url,用户名,密码。根据这些参数创建数据库连接。

(3)获得java.sql.Statement实例,才能执行sql语句。我们这里通过PreparedStatement实例实现。

(4)执行sql语句,我们这里通过ResultSet executeQuery(String sqlString)实现。执行查询数据库的SQL语句,返回一个结果集(ResultSet)对象。

(5)处理结果。

(6)关闭jdbc对象,释放资源。关闭结果集,关闭声明,关闭连接。

物以类聚。我们习惯把参数类型的数据放在一个地方,方便修改,创建db.properties(java.util.Properties),保存jdbc参数;同样,我们习惯进行数据库连接封装(可以写一个DBUtils或者BaseDao),包括读取参数连接数据库,数据库的关闭等。如图:

3、通过sqldeveloper新建一张包括大部分oracle数据类型的表datatypes。如图:

大概整理一下常用的oracle数据类型:

(1)字符串类型。字符串数据类型可以依据存储空间分为固定长度类型(CHAR/NCHAR) 和可变长度类型(VARCHAR2/NVARCHAR2)两种。

(2)数字类型。number,integer,浮点数(binary_float和binary_double),float。

(3)日期类型。date,timestamp,interval year to moth,interval day to second。

(4)lob类型。内置的LOB数据类型包括BLOB、CLOB、NCLOB、BFILE(外部存储)的大型化和非结构化数据,如文本、图像、视屏、空间数据存储。

(这种类型后面用到,会用java来实现操作,比如增加修改查询,方法工具)

(5)raw,long raw类型。

(6)rowid类型。

4、oracle数据类型对应java数据类型。如图。

5、根据数据类型对应关系,和java实体类,设计java实体类对应的数据库表oneds。收集分析整理一个知识点,insert into oneds......数据录入,然后通过简单的get/set方法在控制台显示一些数据字段。

我们下一次需要完成的是,设计以这个知识点为对象的工具方法和逻辑处理类。比如,根据不同的搜索条件查询知识点对象,更新,排序,空间节点,关系设计,父子级联,追溯和提醒等。OK,我们下次见。

个人知识管理系统Version1.0开发记录(03)的更多相关文章

  1. 个人知识管理系统Version1.0开发记录(09)

    MyBatis初试 MyBatis 是支持普通 SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis 消除了几乎所有的JDBC代码和参数的手工设置以及结果集的检索.   运用Mybatis框 ...

  2. 个人知识管理系统Version1.0开发记录(01)

    架 构 描 述 01.数据层,数据源,有形资源入库,无形资源整理,对外搜索引擎,对内平台搜索,数据类型(文字.图片.声音.视频.组合),数据时空优化,数据安全方案(数据进站关卡,数据出战关卡),数据并 ...

  3. 个人知识管理系统Version1.0开发记录(02)

    第 一 步 做 什 么 我们该如何入手呢?先来看看目前常用的三个方法. 1.从事物产生的源头出发,层层推进,步步验证,最后开花结果.这种方法经常用于科研项目,或者三期以后的工程,国家政府项目用的较多. ...

  4. 个人知识管理系统Version1.0开发记录(12)

    最近碰到个问题,在五个工作日内阅读一个百万行左右代码量的新项目集合,如何解决呢? 第一个工作日,环境观察.待在那个项目组,看项目成员们在做些什么事情,开发,测试,聊天,或多或少可以收集到一些项目相关的 ...

  5. 个人知识管理系统Version1.0开发记录(10)

    物理分页 这次我们运用Mybatis拦截器来实现物理分页,后面会运用动态sql来实现,或者运用Map/CollectionUtils/StringUtils编写工具类来实现.oracle是运用的row ...

  6. 个人知识管理系统Version1.0开发记录(07)

    模 块 复 用 原本还要测试一会的,突然出现一连串诡异的问题,比如,编译少加载个类啊,输入地址少个字母啊,改几行代码一改就是半小时啊.这是在提醒我们大脑疲倦了,所以果断小结,下次继续.这一次简单完成了 ...

  7. 个人知识管理系统Version1.0开发记录(11)

    (1)匹配单个属性的关键字:(2)匹配单个对象的关键字:(3)匹配对象集合的关键字:(4)基于事件驱动的:(5)实时搜索,参考win7的搜索功能. 1.备份,java代码,数据库数据. 2.oracl ...

  8. 个人知识管理系统Version1.0开发记录(08)

    切入点 前面,我们已经搭建好了web端的一种基本结构,需要进一步定位的主要问题有三点: 1.界面的选择和确定,用extjs做的初步样式,进一步改动为jqueryUI/html,再进一步改变为HTML5 ...

  9. 个人知识管理系统Version1.0开发记录(05)

    demo controller我们从前面的实现过程可以得出三种普遍使用的信息处理方式:1.操作数据库,对数据进行增删改查,比如运用sqldevloper查看数据信息.2.运用计算机程序语言,对数据进行 ...

随机推荐

  1. (转)CreateThread与_beginthread,内存泄漏为何因(原帖排版有些不好 ,所以我稍微整理下)

            在写c++代码时,一直牢记着一句话:决不应该调用CreateThread. 应该使用Visual   C++运行时库函数_beginthreadex.好像CreateThread函数就 ...

  2. javascript 对象 原型

  3. android系统和ios系统是如何实现推送的,ios为什么没有后台推送

    ios系统为什么没有后台推送? iOS 为了真正地为用户体验负责,不允许应用在后台活动.有了这个限制,但是对于终端设备,应用又是有必要“通知”到达用户的,随时与用户主动沟通起来的(典型的如聊天应用). ...

  4. java 与C# 时间格式 交互

    方法一 C#端代码 IsoDateTimeConverter convert = new IsoDateTimeConverter(); string ret = JsonConvert.Serial ...

  5. 收藏 19 个 ES6常用的简写技巧

    代码精炼是每个有追求的程序所向往的,本文总结了19个JavaScript的简写技术,其中包括三元操作符.短路求值简写方式.声明变量简写方法等等,还有些自己的理解加上去:希望对你有帮助. 三元操作符 当 ...

  6. springmvc.xml和applicationContext.xml配置的特点

    1:springmvc.xml配置要点 一般它主要配置Controller的组件扫描器和视图解析器 下为:springmvc.xml文件 <?xml version="1.0" ...

  7. swift学习笔记 - swift3.0用GCD实现计时器

    swift3.0之后,GCD的语法发生了翻天覆地的变化,从过去的c语法变成了点语法,下面是变化之后用GCD实现计时器的方法: 先贴代码: // 定义需要计时的时间 var timeCount = 60 ...

  8. Hibernate的懒加载session丢失解决方法

    在web.xml加入spring提供的过滤器,延长session的生命周期 <!--Hibernate的懒加载session丢失解决方法 --> <filter> <fi ...

  9. intellij idea rearrange code

        reformat code的时候,无法将filed放在method前边,很恶心. 那么先去

  10. 爬虫框架Scrapy之CrawlSpiders

    CrawlSpiders 通过下面的命令可以快速创建 CrawlSpider模板 的代码: scrapy genspider -t crawl tencent tencent.com 上一个案例中,我 ...