IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> Use migrate in Go project(golang-migrate/migrate) -> 正文阅读

[大数据]Use migrate in Go project(golang-migrate/migrate)

目录

? ? ? ? ?引言

测试postgre

1.启动数据库

2.创建migrations

3.目录树

4.运行go-migrations程序

4.测试结果

参数说明

1.postgres示例

golang-migrate 其他功能示例

1.index

2.functions

注意事项

1.命名规范

参考文章

引言

代码内集成的方式相对来说更加灵活,如果业务上需要在代码中进行数据库的维护作用,可以选择该方法。

测试postgre

1.启动数据库

?采用postgresSQL作为示例

进入postgres 容器内运行?

psql -h localhost -U postgres -w -c "create database pig;" 创建pig数据库。

2.创建migrations

migrate create -ext sql -dir ./migrations -seq create_books_table

3.目录树

000001 是某次修改的版本号,因为本次是第二次生成sql 脚本文件,create_books_tabel 前编号是000002

当前目录:

? golang project 目录文件

migrations 子级目录:

? ??000002_create_books_table.down.sql? ? 回滚本次操作的sql脚本
? ??000002_create_books_table.up.sql ?创建books表的sql脚本

代码文件示例:

000002_create_books_table.up.sql

CREATE TABLE books (

??user_id integer,

??name??? varchar(40),

??author? varchar(40)

);

000002_create_books_table.down.sql

DROP TABLE IF EXISTS books;

4.运行go-migrations程序

? go app 是main.go 示例如下:

package?main

import?(

????????"github.com/golang-migrate/migrate/v4"

????????_?"github.com/golang-migrate/migrate/v4/database/postgres"

????????_?"github.com/golang-migrate/migrate/v4/source/file"

)

func main()? {

????????m, err := migrate.New(

????????????????"file:///root/TEST/migrate/migratesql/migrations",

????????????????"postgres://postgres:123456@localhost:5432/pig?sslmode=disable")

????????if?err != nil {

????????????????log.Fatal(err)

????????}

????????if?err := m.Up(); err != nil {

????????????????log.Fatal(err)

????????}

}

4.测试结果

参数说明

1.postgres示例

postgres://user:password@host:port/dbname?query?(postgresql://?works, too)

URL Query

WithInstance Config

Description

x-migrations-tableMigrationsTableName of the migrations table
x-migrations-table-quotedMigrationsTableQuotedBy default, migrate quotes the migration table for SQL injection safety reasons. This option disable quoting and naively checks that you have quoted the migration table name. e.g.?"my_schema"."schema_migrations"
x-statement-timeoutStatementTimeoutAbort any statement that takes more than the specified number of milliseconds
x-multi-statementMultiStatementEnabledEnable multi-statement execution (default: false)
x-multi-statement-max-sizeMultiStatementMaxSizeMaximum size of single statement in bytes (default: 10MB)
dbnameDatabaseNameThe name of the database to connect to
search_pathThis variable specifies the order in which schemas are searched when an object is referenced by a simple name with no schema specified.
userThe user to sign in as
passwordThe user's password
hostThe host to connect to. Values that start with / are for unix domain sockets. (default is localhost)
portThe port to bind to. (default is 5432)
fallback_application_nameAn application_name to fall back to if one isn't provided.
connect_timeoutMaximum wait for connection, in seconds. Zero or not specified means wait indefinitely.
sslcertCert file location. The file must contain PEM encoded data.
sslkeyKey file location. The file must contain PEM encoded data.
sslrootcertThe location of the root certificate file. The file must contain PEM encoded data.
sslmodeWhether or not to use SSL (disable|require|verify-ca|verify-full)

golang-migrate 其他功能示例

1.index

2.functions

常用函数示例:?

func New(sourceUrl, databaseUrl string) (*Migrate, error)
New 从源 URL 和数据库 URL 返回一个新的 Migrate 实例。
func (m *Migrate) Version() (version uint, dirty bool, err error)
版本返回当前活动的迁移版本。
func (m *Migrate) Up() error
Up 查看当前活动的迁移版本,并将一直向上迁移(应用所有向上迁移)。
func (m *Migrate) Down() error
Down 查看当前活动的迁移版本,并将一直向下迁移(应用所有向下迁移)。
func (m *Migrate) Steps(n int) error
Steps 查看当前活动的迁移版本。如果 n > 0,它将向上迁移,如果 n < 0,它将向下迁移。

注意事项

1.命名规范

create_

create_为前缀的,是创建数据表脚本。

addcolumn

add_column_为前缀的,是向已经创建的数据表添加字段,修改数据表时使用。

addindex

add_index_为前缀的,是向已经创建的数据表添加索引,修改数据表时使用。

dropcolumn

drop_column_为前缀的,是向已经创建的数据表删除字段,修改数据表时使用。

dropindex

drop_index_为前缀的,是向已经创建的数据表删除索引,修改数据表时使用。

renamecolumn

rename_column_为前缀的,是向已经创建的数据表重命名字段,修改数据表时使用。

renameindex

rename_index_为前缀的,是向已经创建的数据表重命名索引,修改数据表时使用。

参考文章

1.migrate/database/postgres at master · golang-migrate/migrate · GitHub

2.migrate package - github.com/golang-migrate/migrate - pkg.go.dev

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-03-12 17:36:19  更:2022-03-12 17:38:50 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/16 18:53:32-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码