0

0

php怎么使用Wave ORM_php如何映射对象关系并支持事务操作

絕刀狂花

絕刀狂花

发布时间:2026-03-18 19:18:12

|

143人浏览过

|

来源于php中文网

原创

Wave ORM需手动声明映射:实体类加#[Table]、主键字段加#[Column(isPrimary: true)],非主键字段需显式#[Column];事务须用Connection显式控制;无自动关联加载,需手动查询组装;PHP 8.1+需处理枚举类型转换。

php怎么使用wave orm_php如何映射对象关系并支持事务操作

Wave ORM 的基本映射怎么写

Wave 不是 Laravel Eloquent 那种“开箱即用”的 ORM,它更轻、更显式——你得手动声明实体类和数据库表的对应关系。不写 #[Table]#[Column],它根本不知道哪个类该映射哪张表。

常见错误是直接 new 一个类然后调用 save(),结果抛出 Wave\Exception\NoMappingFoundException:因为 Wave 根本没扫描到你的类定义。

  • 必须在实体类上加 #[Table("users")],表名要和实际一致(区分大小写)
  • 主键字段必须显式标注 #[Column(isPrimary: true)],Wave 不自动猜 id
  • 非主键字段默认不参与 INSERT/UPDATE,要写 #[Column] 才会映射
  • 类属性名和数据库字段名默认需完全一致;想自定义映射,用 #[Column(name: "user_name")]

示例:

#[Table("users")]
class User
{
    #[Column(isPrimary: true)]
    public int $id;

    #[Column]
    public string $name;

    #[Column(name: "email_address")]
    public string $email;
}

事务操作为什么总不生效

Wave 的事务不是靠模型方法隐式开启的,save()delete() 这些操作默认各自走独立事务(或自动提交模式)。想跨多个操作共用事务,必须显式获取连接并手动控制。

立即学习PHP免费学习笔记(深入)”;

典型坑:写了 $user->save(); $profile->save(); 然后以为加个 try/catch 就能回滚——其实两个 save 各自 commit 了,第二个失败时第一个早已落库。

  • 事务起点是 $connection = Wave\Connection::get();,不是模型实例
  • 所有需要事务包裹的操作,必须用同一个 $connection 实例调用 insert()update() 等底层方法
  • 模型的 save() 方法不接受 connection 参数,不能直接塞进事务块里用
  • 正确做法是:先用 $connection->beginTransaction(),再用 $connection->insert($user)$connection->update($user),最后 commit()rollback()

Wave 怎么查关联数据(比如用户+订单)

Wave 没有内置的 with()belongsTo() 关系加载机制。它不自动 JOIN,也不延迟加载。所谓“关联”,得靠你自己组合查询或两次查询手动组装。

容易误以为 User::find(123)->orders 能跑通——其实会报 Undefined property,因为 orders 不是实体字段,Wave 不做魔法属性注入。

  • 一对多:先查 User,再用 $connection->select(Order::class)->where("user_id = ?", $user->id)->all()
  • 想 JOIN 查询:用 $connection->raw()->select(...)->from("users")->join("orders", "users.id = orders.user_id")...,返回的是数组,不是对象
  • 如果硬要封装成对象关系,得自己写方法,比如在 User 类里加 public function getOrders(): array { ... },内部调用 raw 查询
  • 注意:Wave 不缓存关联结果,每次调都发新查询

PHP 8.1+ 下运行 Wave 的兼容要点

Wave 依赖属性反射(PHP 8.0+ 的 #[Attribute]),但在 PHP 8.1+ 中,若实体类用了枚举属性(如 public Status $status;),而数据库字段是字符串,Wave 默认不会自动转换——它不做类型 coercion。

常见现象:Cannot assign string to property User::$status of type Status,哪怕数据库里存的是 "active"

  • 解决方案一:把属性改成 string 类型,业务层自己转枚举
  • 解决方案二:用 #[Column(transform: [Status::class, "from"])]],要求 Status::from() 是静态方法且接收字符串参数
  • 注意 transform 只作用于 SELECT → 对象赋值;INSERT/UPDATE 仍需你确保传入的是可 JSON 序列化的值(比如 $user->status = Status::Active->value;
  • Wave 不支持 PHP 8.2 的只读类(readonly class),实体类必须允许属性写入

复杂点不在语法,而在思维切换:Wave 要求你始终清楚“哪一步在操作连接”“哪个对象来自哪次查询”“类型边界在哪”。一旦当成 Eloquent 用,问题就从报错变成数据不一致。

相关文章

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2968

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1769

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1585

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

1204

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1646

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1316

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1786

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1333

2023.11.13

Python WebSocket实时通信与异步服务开发实践
Python WebSocket实时通信与异步服务开发实践

本专题聚焦 Python 在实时通信场景中的开发实践,系统讲解 WebSocket 协议原理、长连接管理、消息推送机制以及异步服务架构设计。内容包括客户端与服务端通信实现、连接稳定性优化、消息队列集成及高并发处理策略。通过完整案例,帮助开发者构建高效稳定的实时通信系统,适用于聊天应用、实时数据推送等场景。

7

2026.03.18

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 13.8万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.4万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号