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

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),布布扣,bubuko.com

时间: 2024-12-11 07:55:40

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

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

切入点 前面,我们已经搭建好了web端的一种基本结构,需要进一步定位的主要问题有三点: 1.界面的选择和确定,用extjs做的初步样式,进一步改动为jqueryUI/html,再进一步改变为HTML5等.我们思考一种用户思维,只要有一个地方让用户不喜欢,用户就会全盘否定该款软件:所以,软件界面一定要简单.精致.能引起用户的兴趣.符合用户习惯和用户思维. 2.框架的选择和确定,struts2,hibernate/mybatis,spring等,在编写知识体核心功能模块前,需要完成选择和改写. 3.

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

demo model 我们采用mvc软件架构模式,方便以后用Struts2框架技术优化.重构.封装.这次主要设计一些常用的方法工具,即数据访问逻辑.工具:eclipse.oracle.sqldeveloper. 思路如下: 1.  用sqldeveloper新建表oneds,写入一条name="cookie"的数据. 细节: 参数越多,越要细致检查单词拼写. 2.  用java读取和写入对象属性,与数据库互动. 3.  用java进行数据访问,先完成五个方法,查询所有知识点,增加知识点

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

demo view 夜已深,我们先简单演示一下,完成一个小段落了.涉及工具及技术知识:图形处理软件photoshop cs6,js类库ext. 思路如下: 1.下载ps6,有破解版本的,dll文件覆盖即可,玩个把小时,看看文字.图片jpg.png.gif动画怎么玩的,实际用时找对应方法. 2.下载ext2,docs(这个就是API)-->examples-->HelloWorld.工具栏.菜单栏.表单.面板.布局.事件.类.DOM...... 3.整理结构,注释代码,记录日志. 4.管理员登陆

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

关 键 字 搜 索 (1)匹配单个属性的关键字:(2)匹配单个对象的关键字:(3)匹配对象集合的关键字:(4)基于事件驱动的:(5)实时搜索,参考win7的搜索功能. 1.备份,java代码,数据库数据. 2.oracle数据库,用户操作. (1)查看数据库默认表空间. select * from database_properties;(2)创建用户create user 用户名 identified by 密码 默认表空间 临时表空间create user dyl identified by

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

物理分页 这次我们运用Mybatis拦截器来实现物理分页,后面会运用动态sql来实现,或者运用Map/CollectionUtils/StringUtils编写工具类来实现.oracle是运用的rownum,mysql是运用的limit offset,pagesize.代码中有大量注释,可以参考Mybatis基本原理一起阅读.后面,我们会根据一些实际开发需要,把物理分页功能的代码封装成jar包,以后直接调用就好了,比如Mybatis+Spring3的运行环境,可以采用Mybatis动态sql来实

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

架 构 描 述 01.数据层,数据源,有形资源入库,无形资源整理,对外搜索引擎,对内平台搜索,数据类型(文字.图片.声音.视频.组合),数据时空优化,数据安全方案(数据进站关卡,数据出战关卡),数据并发方案,大数据分布式处理. 02.数据层,数据库,概念数据,物理数据,面向对象,业务程序,数据流程,数据ER图(实体.属性.关联). 03.数据层,数据集,数据采集.数据传递.数据储存.数据加工.数据维护.数据使用. -----------------------------------------

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

第 一 步 做 什 么 我们该如何入手呢?先来看看目前常用的三个方法. 1.从事物产生的源头出发,层层推进,步步验证,最后开花结果.这种方法经常用于科研项目,或者三期以后的工程,国家政府项目用的较多. 2.以结果为导向的方法,我们需要什么结果,逆向推论出我们该如何进行工作.这种方法常用于盈利性比较强的短期项目,或者就是为了赶工的. 3.大项目分解成中项目,中项目分解成小项目.每个项目单位功能齐全,小项目组合成大项目,功能运行正常,也就是常用的敏捷开发方式. 考虑到实际工作生活情况,和我们的出发点

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

英 语 短 文 需 求 分 析   版本号 创建人 创建时间 更新人 更新时间 KBS 1.1.0 duyaolin 2015/2/2   1.功能描述 编写一个工具类功能模块,可以收集.整理平时工作中常见英语词汇.句子.短文,和这些英语内容相关问题的解决方案等,提高工作效率.此功能模块归属为,学习管理.英语学习.计算机专业英语运用下的一个需求版本. 2.需求分析 2.1 管理英语短文 2.1.1 功能描述 收集工作中常用英语短文(包括词汇.短语.句子). 2.1.2 用例图 2.1.3 用例分

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

demo controller我们从前面的实现过程可以得出三种普遍使用的信息处理方式:1.操作数据库,对数据进行增删改查,比如运用sqldevloper查看数据信息.2.运用计算机程序语言,对数据进行增删改查,比如eclipse->window->show view->console.3.通过用户界面,对数据进行增删改查,比如各种browser.PC端.APP端. 我们编写的软件,是数据的一系列操作行为,数据库方式<-->计算机程序语言方式<-->用户界面方式(U