JFinal对oracle数据库的操作配置
来源:互联网 发布:四个字的网络用语 编辑:程序博客网 时间:2024/05/18 03:22
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.OracleDriveroracle.url=jdbc:oracle:thin:@127.0.0.1:1521:orcloracle.username=scottoracle.password=xiaohuconfig.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=new DruidPlugin(url, username, password, driver); me.add(dp); arp=new ActiveRecordPlugin(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 = new StringBuilder(); List<Object> paras = new ArrayList<Object>(); 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<Users>{ public static Users dao=new Users();}
操作数据:
Users users=new Users();users.set("id", "users_sequence.nextval");users.set("username", "张三");users.set("pwd", "sdfsdfs");users.save();List<Users> testList=Users.dao.find("select * from users");
0 0
- JFinal对oracle数据库的操作配置
- JFinal框架操作oracle数据库
- Jfinal对Oracle数据库Date类型的字段个人感觉不是很好
- JFinal数据库配置
- c#对oracle数据库的基本操作
- ADO.Net对oracle数据库的操作
- Oracle数据库--对数据表结构的操作
- JFinal连接Oracle数据库实战
- JFinal学习--06操作数据库
- Jfinal数据库操作API总结
- 登陆ORACLE数据库和对数据库的一些简单操作
- Jfinal 连接oracle数据关于数据库大小的问题
- Jfinal 连接Oracle数据库 出现FROM不到关键字的解决方法
- 对ORACLE数据库进行操作
- linux对oracle数据库操作
- JFinal神器的配置
- spring配置mysql数据库及对数据库的操作
- oracle中的sql语句,对数据库的完全操作
- Dubbo 简单实例
- recylview和listview中item如何设置点击效果?
- 聊一聊Android 6.0的运行时权限
- 互联网协议入门
- 宿舍信息管理系统
- JFinal对oracle数据库的操作配置
- 十进制研究
- Weex Android SDK源码分析之Module(animation)
- 线程池的原理及实现&Java四种线程池的使用
- <%@ page language="java" contentType="text/html; charset=utf-8"pageEncoding="utf-8"%>这几个编码分别代表什么意思?
- 使用inf文件安装文件系统驱动程序的三种方式
- HTML <hr> 标签
- 互联网协议入门(二)
- [Sencha ExtJS6 Modern] 改进bug: 当容器(如Container/Panel/List)内容未超出容器高度时, Scroller无法上/下拉(即越界滚动)