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. mysql数据库从删库到跑路之mysql存储引擎

    一 什么是存储引擎 mysql中建立的库===>文件夹 库中建立的表===>文件 现实生活中我们用来存储数据的文件应该有不同的类型:比如存文本用txt类型,存表格用excel,存图片用pn ...

  2. EasyUI合并行

    扩展一下 EasyUI   下面湿扩展EasyUI 合并行的方法 $.extend($.fn.datagrid.methods, { autoMergeCells: function (jq, fie ...

  3. IISExpress 站点信息

    目录:C:\Users\huxl16\Documents\IISExpress\config applicationhost:applicationhost.config

  4. 解决Ubuntu sudo apt-get install遇到的E: Sub-process /usr/bin/dpkg returned an error code (1)问题

    如题,本人在安装samba等软件的时候,在命令行敲入: sudo apt-get install samba4命令的时候,系统在下载之后报错,大致内容如下: ~$ sudo apt-get insta ...

  5. javascript 理解对象--- 定义多个属性和读取属性的特性

    一 定义多个属性 ECMAScript5 定义了一个Object.defineProperties()方法,用于定义多个属性.此方法接受两个对象参数: 第一个对象:要添加或修改其属性的对象 第二个对象 ...

  6. python 字符串的一些操作

    name = "my \tname is {name} and i am {year} old" print(name.capitalize()) #将首字母都大写 print(n ...

  7. PHP开发之环境配置

    nignx //start nginx -s reload //restart composer create-project laravel/laravel learnlaravel5 //自动创建 ...

  8. python文件和目录操作方法

    一.python中对文件.文件夹操作时经常用到的os模块和shutil模块常用方法.1.得到当前工作目录,即当前Python脚本工作的目录路径: os.getcwd()2.返回指定目录下的所有文件和目 ...

  9. 你可能不熟悉的JS总结

    暂时性死区 只要块级作用域存在let命令,它所声明的变量就"绑定"这个区域,不再受外部的影响.这么说可能有些抽象,举个例子: var temp = 123; if(true) { ...

  10. 从HighGUI的一段代码中看OpenCV打开视频的方式

      OpenCV的HighGUI提供了视频和摄像头的直接打开.那么它是如何实现的了?这里进行初步分析.     ;    switch(apiPreference) {    default:    ...