JFinal框架操作oracle数据库,需要在configPlugin()方法中配置链接oracle数据库的相关配置

配置JFinal数据库操作插件,configPlugin方法

这里我加载jdbc.properties配置文件实在configConstant加载的

@Override

public void configConstant(Constants me) {

loadPropertyFile("jdbc.properties");//加载配置文件

me.setDevMode(getPropertyToBoolean("config.devModel", false));

me.setViewType(ViewType.JSP);

me.setEncoding("UTF-8");

}

jdbc.properites配置文件

oracle.driver=oracle.jdbc.driver.OracleDriver

oracle.url=jdbc:oracle:thin:@127.0.0.1 :1521:orcl

oracle.username=scott

oracle.password=xiaohu

config.devModel=true

@Override

public void configPlugin(Plugins me) {

ActiveRecordPlugin arp=null;

String driver=getProperty("oracle.driver");

String url=getProperty("oracle.url");

String username=getProperty("oracle.username");

String password=getProperty("oracle.password");

DruidPlugin dp=newDruidPlugin(url, username, password, driver);

me.add(dp);

arp=newActiveRecordPlugin(dp);//设置数据库方言

arp.setDialect(new OracleDialect());

arp.setContainerFactory(new CaseInsensitiveContainerFactory());//忽略大小写

me.add(new EhCachePlugin());

arp.addMapping("users", "id",Users.class);

me.add(arp);

}

需要注意一点的是,由于oracle数据库中在创建表时,会自动的将所有的字段自动转为大写,因此在避免后面操作的时候出现大小写错误的相关异常,这里需要配置忽略大小写的功能

arp.setContainerFactory(new CaseInsensitiveContainerFactory());//忽略大小写

如果不需要对数据库进行增加操作,则必须配置忽略大小写,如果不配置忽略大小写,在保存源代码的该段代码中会出现属性id找不到的异常

/**

* Save model.

*/

public boolean save() {

Config config=getConfig();

Table table=getTable();

StringBuilder sql=newStringBuilder();

Listparas=newArrayList();

config.dialect.forModelSave(table, attrs, sql, paras);

// if (paras.size() == 0)   return false;   // The sql "insert into tableName() values()" works fine, so delete this line

// --------

Connection conn=null;

PreparedStatement pst=null;

int result=0;

try {

conn=config.getConnection();

if (config.dialect.isOracle())

pst=conn.prepareStatement(sql.toString(), new String[]{table.getPrimaryKey()});

else

pst=conn.prepareStatement(sql.toString(), Statement.RETURN_GENERATED_KEYS);

config.dialect.fillStatement(pst, paras);

result=pst.executeUpdate();

getGeneratedKey(pst, table);//如果不配置忽略大小写,执行到这里会出现异常,虽然可以添加到数据库,但是这里报错,界面还是会显示500错误

getModifyFlag().clear();

return result >= 1;

} catch (Exception e) {

throw new ActiveRecordException(e);

} finally {

config.close(pst, conn);

}

getGeneratedKey()源代码部分

/**

* Get id after save method.

*/

private void getGeneratedKey(PreparedStatement pst, Table table) throws SQLException {

String pKey=table.getPrimaryKey();

if (get(pKey) == null || getConfig().dialect.isOracle()) {

ResultSet rs=pst.getGeneratedKeys();

if (rs.next()) {

Class colType=table.getColumnType(pKey);

if (colType== Integer.class ||colType== int.class)

set(pKey, rs.getInt(1));

else if (colType== Long.class ||colType== long.class)

set(pKey, rs.getLong(1));

else

set(pKey, rs.getObject(1));     // It returns Long object for int colType

rs.close();

}

}

}

set()源代码部分

/**

* Set attribute to model.

* @param attr the attribute name of the model

* @param value the value of the attribute

* @return this model

* @throws ActiveRecordException if the attribute is not exists of the model

*/

public M set(String attr, Object value) {

if (getTable().hasColumnLabel(attr)) {//执行到这里返回false

attrs.put(attr, value);

getModifyFlag().add(attr);  // Add modify flag, update() need this flag.

return (M)this;

}

throw new ActiveRecordException("The attribute name is not exists: " + attr);//抛出该异常

}

现在来说说如果不配置,为什么会出现 The attribute name is not exists:这个异常,这是因为oracle中的字段是大写的,而set方法中传入的attr属性的值是小写,而getTable()中的属性对应的就是oracle字段,这些属性则是大写,因此这里使用getTable().hasColumnLabel(attr)判断是否存在该字段,就会找不到,这时就会抛出该异常,因此就必须配置忽略大小写的方法,就不会出现该异常

实体类:

package com.tenghu.core.model;

import com.jfinal.plugin.activerecord.Model;

public class Users extends Model{

public static Users dao=newUsers();

}

操作数据:

Usersusers=newUsers();

users.set("id", "users_sequence.nextval");

users.set("username", "张三");

users.set("pwd", "sdfsdfs");

users.save();

ListtestList=Users.dao.find("select * from users");

这里就完成了JFinal框架操作oracle数据库,删除和修改就自己去测试了

oracle19c方言,JFinal框架操作oracle数据库相关推荐

  1. jfinal连接oracle_JFinal框架操作oracle数据库

    JFinal框架操作oracle数据库,需要在configPlugin()方法中配置链接oracle数据库的相关配置 配置JFinal数据库操作插件,configPlugin方法 这里我加载jdbc. ...

  2. Python FastAPI 框架 操作Mysql数据库 增删改查

    2 比 1 更容易理解,可以先看2(单文件级别) 1.FastAPI 框架 操作Mysql数据库(项目多文件级别) FastAPI 可以使用任何您想要的关系型数据库. 在这里,让我们看一个使用着SQL ...

  3. Python应用实战系列-如何通过Python来操作Oracle数据库:cx_Oracle

    最近需要将一批数据从csv文件中迁移到Oracle数据库中,打算用Python来实现,趁着这个机会,写一篇博客学习总结一些如何使用Python来操作Oracle数据库. 1 安装与导入 Python操 ...

  4. Python操作Oracle数据库:cx_Oracle

    1 安装与导入 Python操作Oracle数据库多用cx_Oracle这个第三方扩展,总体而言,cx_Oracle的使用方式与Python操作MySQL数据库的pymysql库还是很相似的,如果还没 ...

  5. java mysql nclob_java语言操作Oracle数据库中的CLOB数据类型 (转)

    java语言操作Oracle数据库中的CLOB数据类型 (转)[@more@] 有关字段类型的相关信息可以查阅oracle技术网.下面摘抄一些有关blob.clob等类型的说明.又便于大家的了解. 字 ...

  6. jdbc链接mysql按照id查询_使用jdbc连接并操作Oracle数据库(增删改查IDUS)

    使用jdbc连接并操作Oracle数据库(增删改查IDUS) [oracle@zaibei-db ~]$ sqlplus /nolog SQL*Plus: Release 11.2.0.4.0 Pro ...

  7. python操作Oracle数据库

    1. 准备工作 ① 首先,你必须安装好Oracle数据库.Oracle数据库的安装并不是那么容易,大家可以去找一个安装教程,慢慢研究. ② 其次,你既然用Python操作Oracle,你必须要安装Py ...

  8. 连接Linux服务器操作Oracle数据库

    1.连接到Linux服务器(输入服务器的ip地址) ssh 10.199.94.227 连接成功后会提示输入密码,输入成功会提示. 2.切换到操作Oracle数据库 su - oracle 切换成功会 ...

  9. Oracle REST Data Services(ORDS)-通过REST接口操作Oracle数据库

    Oracle REST Data Services(ORDS)-通过REST接口操作Oracle数据库 https://blog.csdn.net/q499803363/article/details ...

最新文章

  1. spring整合mybatis(入门级简单教程3)--获取sqlSession对象
  2. php公用一个尾部,19.2 共用显示部分 - 19.2.2 共用尾部页面 - 《零基础学PHP+MySQL (零基础学编程)》 - D云...
  3. python快速自学方式-Python怎样自学?
  4. PKU2019暑期学堂 游记
  5. Exp3 免杀原理与实践 20154320 李超
  6. Intellij IDEA 默认打开上次项目设置与取消设置
  7. android自带中文字体,Android更换系统默认显示的字体使用自定义字体
  8. android离线宝,Android 离线安装宝典
  9. python怎么给画布填上颜色_python numpy matplotlib画小方块填充背景色和添加不同色彩的文字...
  10. Putty打开.pem加密的服务器
  11. 记一次vCenter转移CentOS6.5至workstation的网卡问题
  12. qt 按钮 gradient_少造轮子!推荐一个Qt的Python组件库
  13. 使用ucinet和netdraw做文献计量的可视化分析+利用spss做系统聚类分析
  14. 产品开发流程的几个主要阶段
  15. excel 如何删除有颜色的行
  16. grep -A -B -C -a -c -n -v -i等
  17. 【运维心得】如何一步切换企业邮箱主域名
  18. Oracle如何导出存储过程
  19. Word文档打开后不能编辑,可以这样处理
  20. 20191207-CHKDSK命令修复磁盘教程

热门文章

  1. 怎么在html中加入pjax,pjax加载多说的三种方法
  2. php ajax 表格编辑,php ajax表格实时编辑 PHP Ajax实现表格实时编辑
  3. c语言金箍棒答案,《西游记》阅读测试题(带答案)
  4. 初学JavaWeb需要的前端js,JavaScript是什么样的?
  5. android 为什么fragment在调用hide方法后没有生效_Android 多 Fragment 切换优化
  6. rizomuv缩放排布_RizomUV
  7. @RequestMapping
  8. python学习笔记(10)--组合数据类型(序列类型)
  9. 重装mysql出现无法start service的问题
  10. IntelliJ IDEA 16创建Web项目