oracle19c方言,JFinal框架操作oracle数据库
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数据库相关推荐
- jfinal连接oracle_JFinal框架操作oracle数据库
JFinal框架操作oracle数据库,需要在configPlugin()方法中配置链接oracle数据库的相关配置 配置JFinal数据库操作插件,configPlugin方法 这里我加载jdbc. ...
- Python FastAPI 框架 操作Mysql数据库 增删改查
2 比 1 更容易理解,可以先看2(单文件级别) 1.FastAPI 框架 操作Mysql数据库(项目多文件级别) FastAPI 可以使用任何您想要的关系型数据库. 在这里,让我们看一个使用着SQL ...
- Python应用实战系列-如何通过Python来操作Oracle数据库:cx_Oracle
最近需要将一批数据从csv文件中迁移到Oracle数据库中,打算用Python来实现,趁着这个机会,写一篇博客学习总结一些如何使用Python来操作Oracle数据库. 1 安装与导入 Python操 ...
- Python操作Oracle数据库:cx_Oracle
1 安装与导入 Python操作Oracle数据库多用cx_Oracle这个第三方扩展,总体而言,cx_Oracle的使用方式与Python操作MySQL数据库的pymysql库还是很相似的,如果还没 ...
- java mysql nclob_java语言操作Oracle数据库中的CLOB数据类型 (转)
java语言操作Oracle数据库中的CLOB数据类型 (转)[@more@] 有关字段类型的相关信息可以查阅oracle技术网.下面摘抄一些有关blob.clob等类型的说明.又便于大家的了解. 字 ...
- jdbc链接mysql按照id查询_使用jdbc连接并操作Oracle数据库(增删改查IDUS)
使用jdbc连接并操作Oracle数据库(增删改查IDUS) [oracle@zaibei-db ~]$ sqlplus /nolog SQL*Plus: Release 11.2.0.4.0 Pro ...
- python操作Oracle数据库
1. 准备工作 ① 首先,你必须安装好Oracle数据库.Oracle数据库的安装并不是那么容易,大家可以去找一个安装教程,慢慢研究. ② 其次,你既然用Python操作Oracle,你必须要安装Py ...
- 连接Linux服务器操作Oracle数据库
1.连接到Linux服务器(输入服务器的ip地址) ssh 10.199.94.227 连接成功后会提示输入密码,输入成功会提示. 2.切换到操作Oracle数据库 su - oracle 切换成功会 ...
- Oracle REST Data Services(ORDS)-通过REST接口操作Oracle数据库
Oracle REST Data Services(ORDS)-通过REST接口操作Oracle数据库 https://blog.csdn.net/q499803363/article/details ...
最新文章
- spring整合mybatis(入门级简单教程3)--获取sqlSession对象
- php公用一个尾部,19.2 共用显示部分 - 19.2.2 共用尾部页面 - 《零基础学PHP+MySQL (零基础学编程)》 - D云...
- python快速自学方式-Python怎样自学?
- PKU2019暑期学堂 游记
- Exp3 免杀原理与实践 20154320 李超
- Intellij IDEA 默认打开上次项目设置与取消设置
- android自带中文字体,Android更换系统默认显示的字体使用自定义字体
- android离线宝,Android 离线安装宝典
- python怎么给画布填上颜色_python numpy matplotlib画小方块填充背景色和添加不同色彩的文字...
- Putty打开.pem加密的服务器
- 记一次vCenter转移CentOS6.5至workstation的网卡问题
- qt 按钮 gradient_少造轮子!推荐一个Qt的Python组件库
- 使用ucinet和netdraw做文献计量的可视化分析+利用spss做系统聚类分析
- 产品开发流程的几个主要阶段
- excel 如何删除有颜色的行
- grep -A -B -C -a -c -n -v -i等
- 【运维心得】如何一步切换企业邮箱主域名
- Oracle如何导出存储过程
- Word文档打开后不能编辑,可以这样处理
- 20191207-CHKDSK命令修复磁盘教程
热门文章
- 怎么在html中加入pjax,pjax加载多说的三种方法
- php ajax 表格编辑,php ajax表格实时编辑 PHP Ajax实现表格实时编辑
- c语言金箍棒答案,《西游记》阅读测试题(带答案)
- 初学JavaWeb需要的前端js,JavaScript是什么样的?
- android 为什么fragment在调用hide方法后没有生效_Android 多 Fragment 切换优化
- rizomuv缩放排布_RizomUV
- @RequestMapping
- python学习笔记(10)--组合数据类型(序列类型)
- 重装mysql出现无法start service的问题
- IntelliJ IDEA 16创建Web项目