`

rails结合oracle时的一些命名麻烦处理

 
阅读更多
大概翻了一下书店里的一些关于Ruby on Rails的书籍,和网上的一些教材,大多都是讲述rails和MySql的的例子,并且例子中用到的表结构大部份都是使用rails默认主键名称“ID”, 并且大都遵行Rails的默认命名规则。对象用单数,表名用复数,主键默认为“id”类型为自增类型的。如果是Oracle数据库的话没有自增类型的字段,就要建间一个名称为“表名_seq”的sequence(序列)。这对于将一个现有的系统转型为Ruby无疑是太多的限制。网上关于解决这方面的中文教程却很少。因此把我的学习经验发出来与大家共享。

背景:
刚接触Ruby,想把一个现有系统的部份主要功能用Ruby实现,看Ruby是否真如它说的那样能提高程序员很高的开发效率。因此所有的操作都必须在已为的数据库结构中实现。所以就要解除rails默让规则的限制。数据库用的是oracle9i,以一个最简单的例子“系统登陆”讲述这次的学习过程。

这个功能涉及三张表:S_USER(用户表)  S_ROLE(角色表) S_USER_2_ROLES(用户与角色的关系)



create table S_ROLE
(
  ROLE_ID   VARCHAR2(10) not null,
  ROLE_NAME VARCHAR2(30),
  POPEDOMS  NCLOB,
  ROLE_BEW  VARCHAR2(20),
  ROLE_JB   VARCHAR2(1)
);
create table S_USER
(
  USER_ID        VARCHAR2(6) not null,
  USER_NAME      VARCHAR2(20),
  PASSWD         VARCHAR2(32),
  DEPARTMENT_NUM VARCHAR2(12),
  PHONE_NUM      VARCHAR2(21),
);
create table S_USER_2_ROLES
(
  USER_ID VARCHAR2(10),
  ROLE_ID VARCHAR2(10)
);

用户与角色是多对多的关系。用过rails的朋友看了以上这个表结构有很多地主都与rails的默认惯例不符,主要体现为以下内容:
1、rails默认表名都是复数的,这里面的表名都不是复数。
2、rails默认主键名称为ID,类型为自动类型。而这里面S_USER的主键为USER_ID,S_ROLE的主键为ROLE_ID并且都是字符型。
3、在多对多的关系时,保存关系的表名默认为:“表名1_表名2”,两个表名以字母的顺序排列,所以默认情况下上面这个结构的关系统表的名称应该是“S_ROLE_S_USER”,因为R的字母在U的字母前面。而我这里的表名是S_USER_2_ROLES显示也与Rails的默认惯例不符。
4、rails默认在多对多的关系时,中间表的中保存两个表的主键的字段应该为“类名的小写_id”也就是我上面的S_USER_2_ROLES应改为如下结构:



create table S_USER_2_ROLES
(
  rails中用户表的类名_ID VARCHAR2(10),
  rails中角色表的类名_ID VARCHAR2(10)
)

可是这已经是一个现有系统,暂时不可能这样改。

好了目前面对的是以上的这些总是,下面看看我们要怎么解决这些总是。首先先看看rails中有什么函数能帮我们解决这些总是。
一、解决问题1、2:参考Class  ActiveRecord::Base帮助:
它有以下函数帮我们解决这些问题
set_table_name(value = nil, &block)
用于设置对象与数据库对应的表名。

set_sequence_name(value = nil, &block)
如果是使用Oracle并且想使用类似于自动主键的功能,可以设置这个值,告诉rails用哪个序例来实现自增。

set_primary_key(value = nil, &block)
设置表的主键名称,这样可以解除rails中默认id字段为主键的限制。
以下是一个例子:
class SRole < ActiveRecord::Base
set_table_name "s_role" #设置本对象与数据表s_role对应
set_primary_key 'role_id' #设置该表的字段为role_id
end
class SUser < ActiveRecord::Base
set_table_name "s_user"
set_primary_key 'user_id'
end

一、解决问题3、4:参考Module ActiveRecord::Associations::ClassMethods帮助:
d 在处理多对多的对应关系时,我们会用到has_and_belongs_to_many(association_id, options = {}, &extension)函数。这个函数的第二个参数是一个hash表。里面的一些值可以帮助我们解除rails的默认

:class_name 用于指定与本Class关联的类的名称。
:join_table 用于指定保存对应关系统的中间表的名称。如我们上面的例子中可以指定这个键的值为s_user_2_roles,来解决问题3.
:foreign_key 用于指定中间表中用于记录本类的主键的字段的名称。
:association_foreign_key 用于指定中间表中记录关系类的主键的字段的名称。结合:foreign_key 我们可以用这个属性帮助解决上面的问题4
另外还有一些有用的键值如:
:order 指定关系类的排序方式。
:offset 指定从第几个记录开始提取
:limit 指定提取多少条记录等等.....

最后给出我们上面这个实例中的完整代码:
class SUser < ActiveRecord::Base
has_and_belongs_to_many :roles,:foreign_key=>"user_id",
  :association_foreign_key =>"role_id",:class_name=>"SRole",:join_table=>"S_USER_2_ROLES"
set_table_name "s_user"
set_primary_key 'user_id'
end

class SRole < ActiveRecord::Base
has_and_belongs_to_many :users,:foreign_key=>"role_id",
  :association_foreign_key =>"user_id",:class_name=>"SUser",:join_table=>"S_USER_2_ROLES"
set_table_name "s_role"
set_primary_key 'role_id'
end
分享到:
评论

相关推荐

    基于springboot的酒店管理系统源码(java毕业设计完整源码+LW).zip

    项目均经过测试,可正常运行! 环境说明: 开发语言:java JDK版本:jdk1.8 框架:springboot 数据库:mysql 5.7/8 数据库工具:navicat 开发软件:eclipse/idea

    蓄电池与超级电容混合储能并网matlab simulink仿真模型 (1)混合储能采用低通滤波器进行功率分配,可有效抑制功率波动,并对超级电容的soc进行能量管理,soc较高时多放电,较低时少放电

    蓄电池与超级电容混合储能并网matlab simulink仿真模型。 (1)混合储能采用低通滤波器进行功率分配,可有效抑制功率波动,并对超级电容的soc进行能量管理,soc较高时多放电,较低时少放电,soc较低时状态与其相反。 (2)蓄电池和超级电容分别采用单环恒流控制,研究了基于超级电容的SOC分区限值管理策略,分为放电下限区,放电警戒区,正常工作区,充电警戒区,充电上限区。 (3)采用三相逆变并网,将直流侧800v电压逆变成交流311v并网,逆变采用电压电流双闭环pi控制,pwm调制。 附有参考资料。

    017 - 搞笑一句话台词.docx

    017 - 搞笑一句话台词

    基于微信小程序的购物系统+php后端毕业源码案例设计全部资料+详细文档.zip

    【资源说明】 基于微信小程序的购物系统+php后端毕业源码案例设计全部资料+详细文档.zip 【备注】 1、该项目是个人高分项目源码,已获导师指导认可通过,答辩评审分达到95分 2、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 3、本项目适合计算机相关专业(人工智能、通信工程、自动化、电子信息、物联网等)的在校学生、老师或者企业员工下载使用,也可作为毕业设计、课程设计、作业、项目初期立项演示等,当然也适合小白学习进阶。 4、如果基础还行,可以在此代码基础上进行修改,以实现其他功能,也可直接用于毕设、课设、作业等。 欢迎下载,沟通交流,互相学习,共同进步!

    基于APS.net的办公物品管理系统全部资料+详细文档.zip

    【资源说明】 基于APS.net的办公物品管理系统全部资料+详细文档.zip 【备注】 1、该项目是个人高分项目源码,已获导师指导认可通过,答辩评审分达到95分 2、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 3、本项目适合计算机相关专业(人工智能、通信工程、自动化、电子信息、物联网等)的在校学生、老师或者企业员工下载使用,也可作为毕业设计、课程设计、作业、项目初期立项演示等,当然也适合小白学习进阶。 4、如果基础还行,可以在此代码基础上进行修改,以实现其他功能,也可直接用于毕设、课设、作业等。 欢迎下载,沟通交流,互相学习,共同进步!

    一个使用 Rust 语言编写的简单命令行计算器程序示例,它可以实现基本的加、减、乘、除运算功能

    一个使用 Rust 语言编写的简单命令行计算器程序示例,它可以实现基本的加、减、乘、除运算功能。

    “服务之心”:大学生自愿者服务网系统的功能开发

    在数字化时代背景下,网络技术的发展极大地改变了人们的生活方式,不仅满足了物质需求,也为精神生活提供了更多可能性。阅读作为精神享受的重要途径,其便捷性的需求也随之增加。为了迎合这一需求,珠江学院大学生自愿者服务网系统应运而生,旨在通过网络提供便捷的志愿服务信息。 本文详细介绍了珠江学院大学生自愿者服务网系统的开发过程。系统基于SSM框架构建,融合了Vue技术,并采用MySQL数据库,确保了系统的稳定性与安全性。文章从系统概述、需求分析、系统设计、数据库设计、系统测试以及总结等多个角度对珠江学院大学生自愿者服务网系统进行了全面分析,用户可以通过该系统轻松获取所需的志愿服务信息。 该珠江学院大学生自愿者服务网系统以其稳定的运行性能、便捷的操作流程、清晰的界面设计和全面的功能性,展现出强大的实用性。

    慧集通(DataLinkX)集成客户案例:水泥行业海运运输业务致远OA与畅捷通TCloud集成解决方案

    内容概要:文章介绍了慧集通集成平台在水泥行业海运运输业务中致远OA与畅捷通TCloud的集成方案,涵盖库存、销售、运输、财务等多个环节的数据互通与流程协同。重点介绍了通过慧集通数据集成平台实现的具体对接内容及其策略,旨在提高企业的信息化管理水平,减少人为差错,提升工作效率。 适用人群:企业信息化管理人员、IT项目负责人、ERP及OA系统的实施顾问和运维人员。 使用场景及目标:适用于希望改善业务与财务流程、降低人力成本、提升数据一致性和准确性的中小企业。帮助企业实现内部信息系统的一体化,提供了一个成功的参考案例。 其他说明:案例详细阐述了多个具体业务场景下致远OA与畅捷通TCloud的对接方法及效果验证,为企业数字化转型和信息化建设提供了宝贵的经验。

    基于java+springboot+mysql+微信小程序的社区超市管理系统 源码+数据库+论文(高分毕业设计).zip

    项目已获导师指导并通过的高分毕业设计项目,可作为课程设计和期末大作业,下载即用无需修改,项目完整确保可以运行。 包含:项目源码、数据库脚本、软件工具等,该项目可以作为毕设、课程设计使用,前后端代码都在里面。 该系统功能完善、界面美观、操作简单、功能齐全、管理便捷,具有很高的实际应用价值。 项目都经过严格调试,确保可以运行!可以放心下载 技术组成 语言:java 开发环境:idea、微信开发者工具 数据库:MySql5.7以上 部署环境:maven 数据库工具:navicat

    Java毕设项目:基于spring+mybatis+maven+mysql实现的鲸落文化线上体验馆前后台管理系统【含源码+数据库+毕业论文】

    一、项目简介 本项目是一套基于SSM框架实现的鲸落文化线上体验馆 包含:项目源码、数据库脚本等,该项目附带全部源码可作为毕设使用。 项目都经过严格调试,eclipse或者idea 确保可以运行 二、技术实现 jdk版本:1.8 及以上 ide工具:IDEA或者eclipse 数据库: mysql5.7及以上 后端:spring+springmvc+mybatis+maven+mysql 前端: vue , css ,js 等 三、系统功能 系统用户包括有管理员、用户 1、后台主要功能如下: 用户登录 首页 个人中心 修改密码 个人信息 用户管理 用户禁言 视频分类管理 制作视频管理 趣味视频管理 视频预览 下载视频 系统管理 轮播图管理 历史背景 趣味故事 收藏管理等功能 2、前台主要功能如下: 用户登录 用户注册 首页 制作视频 点我收藏 点击下载 赞一下 踩一下 点击量统计 趣味视频 历史背景 趣味故事 个人中心 我的收藏等功能

    利用LabVIEW并基于LabVIEW编辑电流采样 这个已经很成熟的方案了,直接可以利用文件VI

    利用LabVIEW并基于LabVIEW编辑电流采样 这个已经很成熟的方案了,直接可以利用文件VI

    基于C++与Qt的金山培训大作业源码汇总

    本项目为金山培训大作业源码汇总,采用C++与Qt技术构建,包含401个文件,涵盖106个C++源文件、72个头文件、41个PNG图片、27个项目文件以及HTML、JavaScript、CSS等多种文件类型。项目包含四个主要模块:KVector向量库、命令行会议系统、KSvg绘图板和KHttp音乐播放器。尽管最终未能入选,但展现了作者在C++编程和Qt框架应用方面的扎实功底和努力。

    基于springboot的微服务的旅行社门店系统的设计实现源码(java毕业设计完整源码+LW).zip

    功能说明:可以管理首页、个人中心、用户管理、旅行社管理、产品分类管理、门店公告管理、行政中心管理、订单信息管理、合同信息管理、社区留言、系统管理等功能模块。环境说明:开发语言:Java框架:springboot,mybatisJDK版本:JDK1.8数据库:mysql 5.7数据库工具:Navicat11开发软件:eclipse/ideaMaven包:Maven3.6

    处理二维信号(或图像)的傅里叶变算法的MATLAB源代码,其中含:二维傅里叶变、用滤波器自动提取所需的频谱波峰、二维傅里叶反变、获取相位角分布、相位解包等频谱分析的整套流程(可用于干涉图处理)

    处理二维信号(或图像)的傅里叶变算法的MATLAB源代码,其中含:二维傅里叶变、用滤波器自动提取所需的频谱波峰、二维傅里叶反变、获取相位角分布、相位解包等频谱分析的整套流程(可用于干涉图处理)。

    基于java+springboot+mysql+微信小程序的黄师日报平安小程 源码+数据库+论文(高分毕业设计).zip

    项目已获导师指导并通过的高分毕业设计项目,可作为课程设计和期末大作业,下载即用无需修改,项目完整确保可以运行。 包含:项目源码、数据库脚本、软件工具等,该项目可以作为毕设、课程设计使用,前后端代码都在里面。 该系统功能完善、界面美观、操作简单、功能齐全、管理便捷,具有很高的实际应用价值。 项目都经过严格调试,确保可以运行!可以放心下载 技术组成 语言:java 开发环境:idea、微信开发者工具 数据库:MySql5.7以上 部署环境:maven 数据库工具:navicat

    C#全自动多线程上位机源码编程 0, 纯源代码 1, 替代传统plc搭载的触摸屏 2, 工控屏幕一体机直接和plc通信 3, 功能强大,多级页签 4, 可以自由设定串口或以太网通信

    C#全自动多线程上位机源码编程 0, 纯源代码。 1, 替代传统plc搭载的触摸屏。 2, 工控屏幕一体机直接和plc通信。 3, 功能强大,多级页签。 4, 可以自由设定串口或以太网通信。 5, 主页。 6, 报警页。 7, 手动调试页。 8, 参数设定页。 9, 历史查询页。 10,系统设定页。 11, 赠送所有控件。 12,使用的西门子Plc。 13,注册opcdaauto.dll组件,用于使用opc。 15,安装kepserverEx5。 16,可以链接其他数据库。

    模拟了一个基本的SRTP项目管理系统,这里主要包括项目申请、审批、进度跟踪和结果评估等功能

    由于大学生创新创业训练计划(简称SRTP)通常涉及到项目申请、管理和评估等多个环节,以下是一个简化的Python脚本,模拟了一个基本的SRTP项目管理系统。这里主要包括项目申请、审批、进度跟踪和结果评估等功能:

    基于springboot的音乐翻唱与分享平台源码(java毕业设计完整源码+LW).zip

    项目均经过测试,可正常运行! 环境说明: 开发语言:java JDK版本:jdk1.8 框架:springboot 数据库:mysql 5.7/8 数据库工具:navicat 开发软件:eclipse/idea

    csdn五:信息管理实现

    信息管理实现

    “银行业务数字化”:科技银行业务管理系统开发指南

    在信息技术飞速发展的今天,我们生活在一个信息高度发达的时代。随着计算机技术的进步和移动终端的普及,中国的信息技术已经在全球占据领先地位,我们正经历着信息大爆炸的社会。在这样的背景下,传统的手工信息处理方式已经无法满足现代社会的需求,计算机处理信息的效率远远超过传统方法。 本次开发的科技银行业务管理系统采用Java技术,旨在通过计算机化管理提升科技银行业务信息的管理效率。系统实现了贷款管理、贷款购买管理、理财产品管理、理财产品购买管理、审核人员管理、业务人员管理、银行卡管理、银行卡金额记录管理、银行卡补办管理、存款管理、取款管理、转账管理以及账户注销管理等多项功能。 科技银行业务管理系统通过计算机处理信息,确保了数据传输的即时性,无论是数据获取还是输入,都能迅速反馈,极大提升了工作效率。同时,系统采用MySQL数据库,为数据提供了安全可靠的存储解决方案。

Global site tag (gtag.js) - Google Analytics