可以独立使用的迁移包对比后,感觉phinx更接近PHP的使用习惯。

为什么要单独用?

因为我不想数据库的迁移文件依赖于某种框架。本来是可以在框架里直接安装这个包的,但是发现这个包依赖cakephp,而cakephp的函数与thinkphp的env()函数冲突。

官方文档:Phinx Documentation - 0.16

安装

新建个空目录,然后在这个目录执行:

composer require robmorgan/phinx

安装好后,在目录vendor\bin中能找到文件:phinx.bat。

建议:将vendor\bin的路径加入到系统变量path中,就可以直接用这个命令了。

命令

查看可用命令列表

phinx

查看可用命令的帮助,如:

phinx init --help

初始配置文件

phinx init E:\a\b

假设项目目录为:E:\a\b\。在目录下创建配置文件phinx.php和phinx.yml,建议使用.php的文件(因为不用额外装包),删除掉phinx.yml。项目目录不是phinx的安装目录。

文件内容如下:

<?phpreturn
['paths' => ['migrations' => '%%PHINX_CONFIG_DIR%%/db/migrations','seeds' => '%%PHINX_CONFIG_DIR%%/db/seeds'],'environments' => ['default_migration_table' => 'phinxlog','default_environment' => 'development','production' => ['adapter' => 'mysql','host' => 'localhost','name' => 'production_db','user' => 'root','pass' => '','port' => '3306','charset' => 'utf8',],'development' => ['adapter' => 'mysql','host' => 'localhost','name' => 'development_db','user' => 'root','pass' => '','port' => '3306','charset' => 'utf8',],'testing' => ['adapter' => 'mysql','host' => 'localhost','name' => 'testing_db','user' => 'root','pass' => '','port' => '3306','charset' => 'utf8',]],'version_order' => 'creation'
];

[path] 节可以指定迁移文件和种子文件所在的目录,可以指定为数组,如:

'paths' => [

        'migrations' => [

            '%%PHINX_CONFIG_DIR%%/db/migrations',

            'd:/a/b'

        ],

        'seeds' => '%%PHINX_CONFIG_DIR%%/db/seeds'

    ],

%%PHINX_CONFIG_DIR%% 变量是phinx的内置变量,是配置文件所在的目录。

[environments] 节为数据库环境配置:

default_migration_table:指定保存迁移记录的表名,执行迁移时会生成以这个为表名的表,保存每次执行的记录。

default_environment:默认使用的环境,development为开发环境,将development节下的数据库配置好。

创建迁移文件

phinx create SystemDict --path=E:\a\b\db\migrations -c E:\a\b\phinx.php

phinx create 表名 --path=存放迁移文件的目录 -c 配置文件路径(即执行init时创建的文件)

将会在目录中创建一个迁移文件,名称类似于:20250830084537_system_dict.php。

如果用的是IDE打开文件,可以看到AbstractMigration是标红的,这是因为phinx包不在项目目录中。可以配置下IDE的PHP包含路径:D:\soft\php\tools\vendor。

这是vscode的配置,我这里用的是Trae。

执行迁移

phinx migrate -c E:\a\b\phinx.php

将命令行的当前目录切换为:E:\a\b\,可直接执行phinx migrate,不需要指定配置文件。

可以看到执行成功了,但是由于迁移文件是个空的,所以数据库中没有任何变化,只是多了一个表:phinxlog。这就是配置文件中指定的表名,非必要时不需要特意去改。表里有了一条记录:

现在到迁移文件中添加表的定义:

<?phpdeclare(strict_types=1);use Phinx\Migration\AbstractMigration;final class SystemDict extends AbstractMigration
{/*** Change Method.** Write your reversible migrations using this method.** More information on writing migrations is available here:* https://book.cakephp.org/phinx/0/en/migrations.html#the-change-method** Remember to call "create()" or "update()" and NOT "save()" when working* with the Table class.*/public function change(): void{// 定义表$table = $this->table('__table_prefix__system_dict', ['id' => false, 'primary_key' => ['id'], 'comment' => '系统字典']);// 定义表字段和索引$table->addColumn('id', 'biginteger', ['limit' => 20, 'null' => false, 'signed' => false, 'identity' => true, 'comment' => '主键'])->addColumn('create_time', 'datetime', ['comment' => '创建时间'])->addColumn('update_time', 'datetime', ['comment' => '更新时间'])->addColumn('code', 'string', ['limit' => 100, 'comment' => '字典编码'])->addColumn('title', 'string', ['comment' => '字典标题,显示名'])->addIndex('code', ['unique' => true, 'name' => 'idx_dict_code'])->create();}
}

现在再去执行迁移命令,发现什么都没有变化。这是因为这个文件前一次已经执行过了,在phinxlog表中已经有了记录。要再次执行这个文件,需要先回滚掉前一次执行的记录。

为什么要在表定义设置 id=false?

phinx默认情况下会建一个名为id的int类型的主键字段,但有时候我们不想用int或是不想用id作为主键字段名。这时我们就要自已定义字段了。

回滚

phinx rollback -c E:\a\b\phinx.php

加了代码后执行,会得到一个错误:

这是因为之前执行时没有建表,现在回滚导致找不到表。先将代码中那表的代码注释掉,再执行回滚,回滚后再放开注释掉的代码。当然也可以手动删除迁移表中的记录,但不建议这么干。

每次执行回滚,只会回滚最后一次执行的迁移。如果想一次回滚多个记录,可以用-t参数指定回滚到的版本,具体可以查看回滚的帮助。

phinx rollback -c E:\a\b\phinx.php  -t 20250830084537 # 是回滚到这个版本(这个不会回滚,只回滚这个版本之后的所有版本)

phinx rollback -c E:\a\b\phinx.php  -t 0 # -t 参数指定为0时,将回滚所有版本!!

回滚后再执行下迁移,可以看到表建好了:

查看回滚的帮助

phinx rollback --help

支持的字段类型

以下是各种数据库都支持的类型

binary
boolean
char
date
datetime
decimal
float
double
smallinteger
integer
biginteger
string
text
time
timestamp
uuid

如果想用特殊类型,参考:Writing Migrations - 0.16,为了通用性,不建议使用特殊的类型。

问题

目前还没有发现如何统一定义表前缀。

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

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

从零开始学习单片机18

使用STM32CubeMX创建工程选择对应芯片后创建工程&#xff0c;首先设置时钟源内部时钟源包括LSI&#xff08;低速时钟&#xff09;和HSI&#xff08;高速时钟&#xff09;&#xff0c;使用内部时钟源就需要将图中的一二处勾选HCLK是芯片运行时的评率&#xff0c;虽然下面标的最大…

如何使用 DeepSeek 帮助自己的工作?

技术文章大纲&#xff1a;利用 DeepSeek 提升工作效率 了解 DeepSeek 的基本功能 DeepSeek 的核心能力&#xff1a;文本生成、代码辅助、数据分析支持的平台与访问方式&#xff08;网页端/API/集成工具&#xff09;适用场景&#xff1a;技术文档撰写、自动化流程设计、数据处理…

计算机毕设javayit商城 基于SSM框架的校园二手交易全流程管理系统设计与实现 Java+MySQL的校园二手商品交易与供需对接平台开发

计算机毕设 javayit 商城uwd1i9 &#xff08;配套有源码 程序 mysql数据库 论文&#xff09;本套源码可以先看具体功能演示视频领取&#xff0c;文末有联xi 可分享随着校园二手物品流通需求增长&#xff0c;传统校园二手交易依赖线下摆摊、社群发布的模式&#xff0c;存在信息分…

Java函数式编程之【流(Stream)性能优化】

Java函数式编程之【流&#xff08;Stream&#xff09;性能优化一、流&#xff08;Stream&#xff09;性能优化的预备知识&#xff08;一&#xff09;并行与并发的区别&#xff08;二&#xff09;Stream操作特性分类&#xff08;三&#xff09;Stream流管道的相关知识二、流&…

Cybero: 1靶场渗透

Cybero: 1 来自 <Cybero: 1 ~ VulnHub> 1&#xff0c;将两台虚拟机网络连接都改为NAT模式 2&#xff0c;攻击机上做namp局域网扫描发现靶机 nmap -sn 192.168.23.0/24 那么攻击机IP为192.168.23.128&#xff0c;靶场IP192.168.23.139 3&#xff0c;对靶机进行端口服务探…

【学习笔记】非异步安全函数(禁止在信号处理中调用)

非异步安全函数&#xff08;禁止在信号处理中调用&#xff09; 一、测试 在信号处理函数&#xff08;Signal Handler&#xff09;中&#xff0c;只有异步信号安全函数&#xff08;async-signal-safe functions&#xff09; 可以安全调用。这类函数的特点是&#xff1a;不使用全…

【K8s】整体认识K8s之K8s的控制器

作用&#xff1a;控制器的作用就是持续监控k8s集群的状态&#xff0c;让它处于我们期望的状态&#xff0c;常见的控制器有replicaset、deployment、daemonset、statefulset 、job 、cronjobReplicaset控制一组pod的副本数&#xff0c;始终与预设的值相同&#xff0c;会持续监视…

R ggplot2学习Nature子刊一张图,换数据即可用!

本次使用R语言复现Nature Communications上的1张组合图,这张图兼具颜值+节约版面! Fig. 1 b原图 ❤️复现效果图-b图❤️ ✅读入测试数据! ✅关键代码, # 关键代码 library(ggplot2) library(dplyr) library(cowplot)# --- 外圈图 --- p_outer <- ggplot(data_aug, aes…

迷你电脑用到什么型号的RJ45网口

迷你电脑常用的 RJ45 网口主要有标准 RJ45 网口和 Mini RJ45 网口两种。标准 RJ45 网口是最常见的类型&#xff0c;遵循 IEEE 802.3i 标准&#xff0c;采用 8P8C&#xff08;8 Position 8 Contact&#xff0c;8 位 8 触点&#xff09;连接器&#xff0c;有 T568A 和 T568B 两种…

网络安全 | 保护智能家居和企业IoT设备的安全策略

网络安全 | 保护智能家居和企业IoT设备的安全策略 一、前言 二、智能家居和企业 IoT 设备面临的安全威胁 2.1 设备自身安全缺陷 2.2 网络通信安全隐患 2.3 数据隐私风险 2.4 恶意软件和攻击手段 三、保护智能家居和企业 IoT 设备的安全策略 3.1 设备安全设计与制造环节的考量 3…

优化器全指南:从原理到调优实战

本文将带你轻松理解深度学习中的“导航系统”——优化器。我们会避开复杂的数学公式,用大量的比喻和图示,让你彻底明白 Adam、AdamW、LAMB 是怎么回事,并学会如何调节它们的关键参数。 第一部分:核心概念:优化器是什么? 一个简单的比喻: 想象你在一座大雾弥漫的山里(…

Notepad++使用技巧1

1.打开官方参考代码经常看到下图这种行尾很多空格的代码&#xff0c;一点都不合符华为的书写规范&#xff0c;阅读起来容易让人烦躁不安。初学者建议看看华为的代码书写规范&#xff0c;你将少走很多弯路&#xff0c;终生受益。2.快速去掉行尾很多空格方法点击顶部菜单栏“宏”…

AIoT云边协同方式

随着物联网&#xff08;IoT&#xff09;与人工智能&#xff08;AI&#xff09;的深度融合&#xff0c;AIoT&#xff08;人工智能物联网&#xff09;作为一种新兴技术范式&#xff0c;正在推动智能设备与产业的快速发展。AIoT通过云边协同的方式&#xff0c;将边缘侧的IoT设备、…

MIT 6.5840 (Spring, 2024) 通关指南——Lab 1: MapReduce

MIT 6.5840 (Spring, 2024) – Lab 1: MapReduce &#x1f468;‍&#x1f4bb; Charles &#x1f517; 实验手册&#xff1a; 6.5840 Lab 1: MapReduce &#x1f4c3; MapReduce 论文原文&#xff1a; mapreduce-osdi04.pdf ✍️ 本系列前文&#xff1a; MIT 6.5840 (Spring, …

吴恩达机器学习作业五:神经网络正向传播

数据集在作业一正向传播正向传播&#xff08;Forward Propagation&#xff09;是神经网络计算过程中的核心步骤&#xff0c;指的是将输入数据通过神经网络的各层依次传递&#xff0c;最终得到输出结果的过程。核心原理在神经网络中&#xff0c;信息从输入层流入&#xff0c;经过…

网络编程(4)

【0】复习 sockfdsocket(); //指定网络信息 bind(); listen(); //创建表 fd_set rfds,tempfds; FD_ZERO(); FD_SET(sockfd); max sockfd while(1) {tempfdsrfds;select(max1,&tempfds)if(FD_ISSET(scokfd,&tempfds)){acceptfdaccept();FD_SET(acceptfd,&rfds);if(m…

Windows系统提示“找不到文件‘javaw‘”

1. Java 未安装或安装不完整javaw.exe 是 Java 运行环境&#xff08;JRE&#xff09;的核心文件&#xff0c;用于运行 Java 程序&#xff08;如.jar 文件&#xff09;。如果你的电脑没有安装 Java&#xff0c;或安装过程中 javaw.exe 被误删&#xff0c;系统就会找不到它。2. J…

【PCIE系列】1---PCIE系统拓扑结构分析

架构由点对点链路&#xff08;Links&#xff09;组成&#xff0c;用于互连组成系统的一系列组件。下图展示了一个示例拓扑结构。该图描述了一个有层次的体系架构实例&#xff0c;其包含根复合体&#xff08;Root Complex, RC&#xff09;、多个端点&#xff08;I/O设备&#xf…

SpringBoot防止重复提交(2)

例如&#xff1a;多次点击提现按钮问题描述&#xff1a;在提现操作中&#xff0c;用户可能会多次点击提现按钮&#xff0c;导致多个相同的请求发送到服务器&#xff0c;从而引发重复提现的问题。为了解决这一问题&#xff0c;必须保证每个提现请求只能执行一次&#xff0c;防止…

mysql zip包安装步骤

下载地址 windows MSI Install 安装包程序。 这里下载zip包&#xff0c;执行安装过程 确认my.ini 配置的路径&#xff0c;创建mysql数据服务的data目录管理员身份cmd 进入bin目录&#xff0c;开始初始化服务 mysqld --initialize-insecure --usermysql mysqld -install#启动…