博客
关于我
ABP适配Oracle全过程
阅读量:468 次
发布时间:2019-03-06

本文共 1115 字,大约阅读时间需要 3 分钟。

ABP框架与Oracle的兼容性适配实践

背景

在现有的ABP框架资源完善的情况下,Oracle相关的支持内容却显得匮乏。ABP官网也未能提供一个优质的Oracle解决方案。经过对ABP源码的初步了解后,我决定尝试进行ABP与Oracle的兼容性适配工作。

准备工作

为了顺利完成Oracle的适配工作,我首先进行了以下准备:

  • 下载ABP模板:选择适用于.NET Framework的MVC版本模板。
  • 获取源码:通过Git仓库获取最新版本的ABP框架源码。
  • 数据库环境:使用Oracle 11g进行测试与开发。
  • 开发工具:使用Visual Studio 2017进行编码。
  • Oracle数据库的连接与配置

    在准备工作完成后,我开始着手进行Oracle数据库的连接配置。

    Oracle EF 驱动的安装

    通过NuGet安装Oracle.ManagedDataAccess.EntityFramework包,这个包会自动包含必要的ODP.NET引用。这一步标志着EF对Oracle的驱动支持已具备。

    数据库链接的配置

    web.config文件中,添加了Oracle的数据库连接配置。需要注意的是,Oracle的连接字符串需要完整,包含数据库名称、用户名和密码等信息。

    数据迁移的挑战

    在执行数据迁移时,EF会根据模型生成SQL语句。由于Oracle对PL/SQL表名和字段名具有区分大小写的特性,而EF生成的默认命名方式并不符合这一规则,导致生成的表结构与预期不符。

    源码改造

    为了解决数据迁移的问题,我需要对ABP框架的源码进行改造。

    表名和字段名的改写

  • 实体类库的修改:找到ABP.Zero.Common类库,修改相关实体类,通过特性将映射到数据库的实体名和属性名改为大写。
  • 迁移并验证:通过数据迁移工具将改写后的实体类生成到Oracle数据库中,确保表名和字段名符合要求。
  • 主键类型的调整

    由于Oracle 11g的主键不能自动递增,而ABP框架默认使用int类型的自增主键,这导致权限管理模块无法正常使用。因此,我需要将所有表的主键类型修改为string,并通过程序手动赋值主键值。

    问题与解决方案

    在完成源码改造并重新执行数据迁移后,系统能够正常运行并显示登录界面。然而,登录后发现角色管理和租户管理等功能无法显示。通过后台调试,发现权限角色无法获取相关值。为了解决这一问题,我计划进一步优化数据库迁移的脚本,并对基础数据进行手动录入,以确保系统能够正常运行。

    总结

    通过以上步骤,我成功实现了ABP框架与Oracle数据库的兼容性适配。虽然过程中遇到了一些技术挑战,但通过细致的源码改造和问题调试,最终达成了预期的目标。

    转载地址:http://irmbz.baihongyu.com/

    你可能感兴趣的文章
    Openlayers高级交互(10/20):绘制矩形,截取对应部分的地图并保存
    查看>>
    Openlayers高级交互(11/20):显示带箭头的线段轨迹,箭头居中
    查看>>
    Openlayers高级交互(13/20):选择左右两部分的地图内容,横向卷帘
    查看>>
    Openlayers高级交互(14/20):汽车移动轨迹动画(开始、暂停、结束)
    查看>>
    Openlayers高级交互(15/20):显示海量多边形,10ms加载完成
    查看>>
    Openlayers高级交互(16/20):两个多边形的交集、差集、并集处理
    查看>>
    Openlayers高级交互(17/20):通过坐标显示多边形,计算出最大幅宽
    查看>>
    Openlayers高级交互(18/20):根据feature,将图形适配到最可视化窗口
    查看>>
    Openlayers高级交互(19/20): 地图上点击某处,列表中显示对应位置
    查看>>
    Openlayers高级交互(2/20):清除所有图层的有效方法
    查看>>
    Openlayers高级交互(20/20):超级数据聚合,页面不再混乱
    查看>>
    Openlayers高级交互(3/20):动态添加 layer 到 layerGroup,并动态删除
    查看>>
    Openlayers高级交互(4/20):手绘多边形,导出KML文件,可以自定义name和style
    查看>>
    Openlayers高级交互(5/20):右键点击,获取该点下多个图层的feature信息
    查看>>
    Openlayers高级交互(6/20):绘制某点,判断它是否在一个电子围栏内
    查看>>
    Openlayers高级交互(7/20):点击某点弹出窗口,自动播放视频
    查看>>
    Openlayers高级交互(8/20):选取feature,平移feature
    查看>>
    Openlayers高级交互(9/20):编辑图形(放缩、平移、变形、旋转),停止编辑
    查看>>
    Openlayers:DMS-DD坐标形式互相转换
    查看>>
    openlayers:圆孔相机根据卫星经度、纬度、高度、半径比例推算绘制地面的拍摄的区域
    查看>>