ORM框架简介

news2025/1/15 12:49:08

什么是ORM?

ORM(Object-Relational Mapping,对象关系映射)是一种编程技术,用于在关系数据库和对象程序语言之间转换数据。ORM框架允许开发者以面向对象的方式来操作数据库,而不需要编写复杂的SQL语句。简单来说,ORM通过描述对象和数据库之间映射的元数据,将程序中的对象自动持久化到关系数据库中。
在这里插入图片描述

ORM的核心优势

  1. 提高开发效率:ORM可以自动对Entity对象与数据库中的Table进行字段与属性的映射,减少了手动编写SQL的工作量。
  2. 简化代码:面向对象的编程方式使得代码更加简洁、易读。
  3. 跨数据库支持:ORM框架通常支持多种数据库,便于项目迁移和扩展。
  4. 减少SQL注入风险:ORM框架通常内置了防止SQL注入的机制。

常用ORM框架

Hibernate(Java)

Hibernate是Java领域最著名的ORM框架之一。它提供了强大的对象持久化功能,支持多种数据库,并且具有良好的性能和扩展性。

// 引入Hibernate核心库
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
public class HibernateExample {
    public static void main(String[] args) {
        // 配置Hibernate
        Configuration cfg = new Configuration();
        cfg.configure("hibernate.cfg.xml");
        // 创建SessionFactory
        SessionFactory factory = cfg.buildSessionFactory();
        // 获取Session
        Session session = factory.openSession();
        // 开始事务
        Transaction tx = session.beginTransaction();
        // 创建对象
        User user = new User();
        user.setName("John Doe");
        // 保存对象
        session.save(user);
        // 提交事务
        tx.commit();
        // 关闭Session
        session.close();
        factory.close();
    }
}

SQLAlchemy(Python)

SQLAlchemy是Python领域最流行的ORM框架之一。它提供了灵活且强大的数据库访问能力,支持多种数据库,并且具有良好的性能和扩展性。

# 引入SQLAlchemy核心库
from sqlalchemy import create_engine, Column, Integer, String
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import sessionmaker
# 创建数据库连接
engine = create_engine('sqlite:///example.db', echo=True)
# 创建基类
Base = declarative_base()
# 定义模型
class User(Base):
    __tablename__ = 'users'
    id = Column(Integer, primary_key=True)
    name = Column(String)
# 创建表
Base.metadata.create_all(engine)
# 创建Session
Session = sessionmaker(bind=engine)
session = Session()
# 创建对象
user = User(name='John Doe')
# 保存对象
session.add(user)
session.commit()
# 查询对象
user = session.query(User).filter_by(name='John Doe').first()
print(user.name)

Entity Framework(.NET)

Entity Framework是.NET领域最流行的ORM框架之一。它提供了强大的对象持久化功能,支持多种数据库,并且具有良好的性能和扩展性。

// 引入Entity Framework核心库
using System;
using System.Data.Entity;
using System.Linq;
// 定义模型
public class User
{
    public int Id { get; set; }
    public string Name { get; set; }
}
// 定义DbContext
public class UserContext : DbContext
{
    public DbSet<User> Users { get; set; }
}
class Program
{
    static void Main()
    {
        // 创建DbContext
        using (var context = new UserContext())
        {
            // 创建对象
            var user = new User { Name = "John Doe" };
            // 保存对象
            context.Users.Add(user);
            context.SaveChanges();
            // 查询对象
            var query = from u in context.Users
                        where u.Name == "John Doe"
                        select u;
            var result = query.FirstOrDefault();
            Console.WriteLine(result.Name);
        }
    }
}

ORM的实际应用

ORM框架使得数据的持久化变得非常简单。开发者只需要定义好模型类,然后通过简单的API调用即可完成数据的增删改查操作。此外,ORM框架通常提供了数据库迁移工具,可以帮助开发者管理数据库schema的变化。例如,SQLAlchemy提供了Alembic工具,Entity Framework提供了Code First Migrations功能。

总结

ORM技术极大地简化了数据库操作,提高了开发效率。本文介绍了ORM的基本概念、常用框架及实际应用,并通过代码示例帮助大家快速理解和应用这一技术。希望本文能对大家有所帮助,欢迎大家在实际项目中尝试和应用ORM技术。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2201376.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

CMake 属性之目录属性

【写在前面】 CMake 的目录属性是指在特定目录&#xff08;及其子目录&#xff09;范围内有效的设置。 这些属性不同于全局变量或目标&#xff08;Target&#xff09;属性&#xff0c;它们提供了一种机制&#xff0c;允许开发者为项目中的不同部分定义不同的构建行为。 通过目录…

HarmonyOS NEXT应用开发实战(二、封装比UniApp和小程序更简单好用的网络库)

网络访问接口&#xff0c;使用频次最高。之前习惯了uniapp下的网络接口风格&#xff0c;使用起来贼简单方便。转战到鸿蒙上后&#xff0c;原始网络接口写着真累啊&#xff01;目标让鸿蒙上网络接口使用&#xff0c;简单程度比肩uniapp&#xff0c;比Axios更轻量级。源码量也不多…

Spring Cloud全解析:链路追踪之springCloudSleuth简介

文章目录 springCloudSleuth简介链路追踪&#xff1f;SpringCloudSleuth术语链路示意图zipkin依赖配置 springCloudSleuth简介 链路追踪&#xff1f; 什么是链路追踪&#xff1f;就是将一次分布式请求还原成调用链路&#xff0c;将一次分布式请求的调用情况集中展示&#xff…

SpringBoot教程(二十四) | SpringBoot实现分布式定时任务之Quartz(多数据源配置)

SpringBoot教程&#xff08;二十四&#xff09; | SpringBoot实现分布式定时任务之Quartz&#xff08;多数据源配置&#xff09; 前言多数据源配置引入aop依赖1. properties配置多数据源2. 创建数据源枚举类3. 线程参数配置类4. 数据源动态切换类5. 多数据源配置类HikariCP 版本…

【JS】用哈希法得到四数相加元组数

思路 根据题目这里是四个数组abcd的数相加&#xff0c;将数组两两分组&#xff0c;A大组为ab&#xff0c;B大组为cd由abcd0可得AB0&#xff0c;即B0-A遍历数组分别计算出AB大组所有sum值&#xff0c;先将A组sum值存进map里&#xff0c;再从map里面寻找有count个合适的B值&#…

Python in Excel 正式发布!

Excel 中的 Python 现已正式发布&#xff0c;适用于 Microsoft 365 商业版和企业版的 Windows 用户。去年 8 月&#xff0c;微软与 Anaconda 合作&#xff0c;通过集成 Python 为 Excel 引入了一个令人兴奋的新增功能&#xff0c;从而可以将 Python 和 Excel 分析无缝结合到同一…

使用npm i报错node-sass失败问题解决

node 版本&#xff1a;v14.15.4 解决方法&#xff1a; npm config set sass_binary_sitehttps://npmmirror.com/mirrors/node-sass设置完之后&#xff0c;再npm i 就可以下载成功 亲测有效

MySQL--视图(详解)

目录 一、前言二、视图2.1概念2.2语法2.3创建视图2.3.1目的 2.4查看视图2.5修改数据2.5.1通过真实表修改数据&#xff0c;会影响视图2.5.2通过修改视图&#xff0c;会影响基表 2.6注意2.7 删除视图2.8 视图的优点 一、前言 欢迎大家来到权权的博客~欢迎大家对我的博客进行指导&…

历时一个多月,搭建了一款培训考试小程序系统

前不久&#xff0c;一位在机构单位工作的朋友联系到我&#xff0c;说他们需要搭建一款内部培训考试系统&#xff0c;是关于安全知识学习与考试的。 此处省略好多张聊天页...... 为此&#xff0c;针对用户的需求&#xff0c;在搭建前&#xff0c;我做了大量的竞品分析&#xff…

探索 MicroRabbit:Python 中的通信新纪元

文章目录 探索 MicroRabbit&#xff1a;Python 中的通信新纪元背景&#xff1a;为什么选择 MicroRabbit&#xff1f;MicroRabbit 是什么&#xff1f;如何安装 MicroRabbit&#xff1f;简单的库函数使用方法场景应用示例常见 Bug 及解决方案总结 探索 MicroRabbit&#xff1a;Py…

计算机毕业设计 基于Python的智能停车管理系统的设计与实现 Python+Django+Vue 前后端分离 附源码 讲解 文档

&#x1f34a;作者&#xff1a;计算机编程-吉哥 &#x1f34a;简介&#xff1a;专业从事JavaWeb程序开发&#xff0c;微信小程序开发&#xff0c;定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事&#xff0c;生活就是快乐的。 &#x1f34a;心愿&#xff1a;点…

UML/SysML建模工具更新情况(2024年10月)(1)Rhapsody 10.0.1

DDD领域驱动设计批评文集 做强化自测题获得“软件方法建模师”称号 《软件方法》各章合集 工具最新版本&#xff1a;SinelaboreRT 6.4 更新时间&#xff1a;2024年9月23日 工具简介 状态机图和活动图代码生成工具。先在EA、Visual Paradigm 、Cadifra、UModel、MagicDraw、…

衡石分析平台系统管理手册-智能运维之系统设置

系统设置​ HENGSHI 系统设置中展示了系统运行时的一些参数&#xff0c;包括主程序相关信息&#xff0c;Base URL、HTTP 代理、图表数据缓存周期、数据集缓存大小、租户引擎等相关信息。 主程序​ 系统设置中展示了主程序相关信息&#xff0c;这些信息是系统自动生成的&#…

AOC商用显示器助力智能制造,赋能数智化发展!

摘要&#xff1a;为制造型企业向数字化、智能化转型提供有力助益&#xff01; 当今时代&#xff0c;我国制造业呈现出蓬勃发展之势。其中&#xff0c;显示器作为信息呈现的关键载体&#xff0c;其在制造业智能化进程中愈发发挥着重要作用&#xff0c;有助于实时、准确地展示生…

Mysql数据库安装与C++配置

本文档旨在为需要安装和配置MySQL 8.3、MySQL Workbench以及C Connector的用户提供详细的步骤指导。在安装过程中&#xff0c;可能会遇到一些常见问题&#xff0c;如DLL文件缺失等&#xff0c;本指南也会提供相应的解决办法。 1.安装Mysql8.3 安装Mysql有很多教程&#xff0c…

体感魂斗罗(二)姿势/手势与键位

文章目录 姿势/手势与键位映射 姿势/手势与键位映射 姿势/手势与键位映射暂时定为如下表的映射&#xff0c;搞出来一版&#xff0c;后续再优化 姿势/手势键位手掌上抬键位-上手掌下压键位-下手掌左挥键位-左手掌右挥键位-右挥拳A键抬腿B键OK手势暂停-开始

105. 从前序与中序遍历序列构造二叉树【 力扣(LeetCode) 】

文章目录 零、LeetCode 原题一、题目描述二、测试用例三、解题思路四、参考代码 零、LeetCode 原题 105. 从前序与中序遍历序列构造二叉树 一、题目描述 给定两个整数数组 preorder 和 inorder &#xff0c;其中 preorder 是二叉树的先序遍历&#xff0c; inorder 是同一棵树的…

『网络游戏』客户端使用PESorket发送消息到服务器【14】

上一章服务器已经完成使用PESorket 现在我们将其导出在客户端中使用 生成成功后复制 粘贴到Unity项目中 进入Assets文件夹 粘贴两个.dll 创建脚本:ClientSession.cs 编写脚本: ClientSession.cs 编写脚本:GameStart.cs 将GameStart.cs脚本绑定在摄像机上 运行服务器 运行客户端…

【python实操】python小程序之封装(家具管理)

引言 python小程序之封装&#xff08;家具管理&#xff09; 文章目录 引言一、封装&#xff08;家具管理&#xff09;1.1 题目1.2 代码1.3 代码解释1.3.1 类 HouseItem1.3.2 类 House1.3.3 实例化与调用1.3.4 运行结果 四、思考 一、封装&#xff08;家具管理&#xff09; 1.1…

基于IDEA+SpringBoot+Vue+Uniapp的投票评选小程序系统的详细设计和实现

2. 详细视频演示 文章底部名片&#xff0c;联系我获取更详细的演示视频 3. 论文参考 4. 项目运行截图 代码运行效果图 代码运行效果图 代码运行效果图 代码运行效果图 代码运行效果图 5. 技术框架 5.1 后端采用SpringBoot框架 Spring Boot 是一个用于快速开发基于 Spring 框…