å¨ç»Â大å¤Âæ°çÂÂÃ¥ÂÂ端å¼ÂÃ¥ÂÂçÂÂèÂÂä¸ÂçÂÂ涯ä¸Âï¼Âæ¥常工ä½Âè¿Âæ¯主è¦Âå´ç»Âä¸Âå¡åÂÂæ°æ®åºÂCRUDç¸堳çÂÂæÂ¥å£ãÂÂæÂÂ们ä»Âèª身ä¸Âå¡å¼ÂÃ¥ÂÂå®Âé åºåÂÂï¼Âç»Âgo-doudou v2.1.4çÂÂæ¬å¢Âå äºÂä¸Â个æ°ç¹æ§ï¼ÂåºäºÂgormä»Âæ°æ®åºÂä¸Âé®çÂÂæÂÂRESTfulÃ¥ÂÂgRPCæÂÂå¡ï¼Âæ¥帮å©广大goè¯Âè¨Âå¼ÂÃ¥ÂÂè æ´快æ´好çÂÂå®Âç°éÂÂæ±Âï¼Âå¿«éÂÂä¸Â线ãÂÂè¿Âä¸Âç¹æ§ç®åÂÂ设计åÂÂæ¯æÂÂäºÂ以ä¸Â6ç±»æÂ¥å£ï¼Â
Post{{.ModelStructName}}(ctx context.Context, body dto.{{.ModelStructName}}) (data {{.PriKeyType}}, err error)
Post{{.ModelStructName}}s(ctx context.Context, body []dto.{{.ModelStructName}}) (data []{{.PriKeyType}}, err error)
Get{{.ModelStructName}}_Id(ctx context.Context, id {{.PriKeyType}}) (data dto.{{.ModelStructName}}, err error)
Put{{.ModelStructName}}(ctx context.Context, body dto.{{.ModelStructName}}) error
Delete{{.ModelStructName}}_Id(ctx context.Context, id {{.PriKeyType}}) error
Get{{.ModelStructName}}s(ctx context.Context, parameter dto.Parameter) (data dto.Page, err error)
Post{{.ModelStructName}}
ï¼ÂÃ¥ÂÂæ¡æ°æ®æ°å¢ÂæÂ¥å£Post{{.ModelStructName}}s
ï¼Âæ¹éÂÂæ°æ®æ°å¢ÂæÂ¥å£Get{{.ModelStructName}}_Id
ï¼Âæ ¹æ®主é®IDæ¥询åÂÂæ¡æ°æ®æÂ¥å£Put{{.ModelStructName}}
ï¼Âæ ¹æ®主é®IDæ´æ°åÂÂæ¡æ°æ®æÂ¥å£Delete{{.ModelStructName}}_Id
ï¼Âæ ¹æ®主é®IDå é¤åÂÂæ¡æ°æ®æÂ¥å£Get{{.ModelStructName}}s
ï¼ÂÃ¥ÂÂ页æ¥询æÂ¥å£
Ã¥ÂÂç»Âè¿Âä¼Âæ ¹æ®å®Âé éÂÂæ±Âæ°å¢Âæ´å¤ÂçÂÂ常ç¨æÂ¥å£ãÂÂä¸Âé¢çÂÂä¸Â个代ç ÂçÂÂæÂÂçÂÂå½令示ä¾Âï¼Â并ä»Âç»Âä¸Âä¸Âå½令è¡ÂÃ¥ÂÂæ°çÂÂå«ä¹Âï¼Â
go-doudou svc init myproject --db_driver mysql --db_dsn "root:1234@tcp(127.0.0.1:3306)/tutorial?charset=utf8mb4&parseTime=True&loc=Local" --db_soft delete_at --db_grpc
go-doudou svc init myproject
ï¼Â该å½令表示åÂÂå§ÂÃ¥ÂÂæÂÂè å¢ÂéÂÂæ´æ°myproject项ç®ï¼Âå¦ÂæÂÂmyprojectæÂÂ件夹ä¸ÂÃ¥ÂÂå¨ï¼Âä¼Âèªå¨åÂÂ建ãÂÂå¦ÂæÂÂgo-doudou svc init
Ã¥ÂÂé¢没æÂÂè·ÂæÂÂ件夹路å¾ÂæÂÂ项ç®åÂÂ称ï¼ÂÃ¥ÂÂä¼Âé»Â认ç´æÂ¥å°Â代ç ÂçÂÂæÂÂå¨å½ÂÃ¥ÂÂæÂÂ件夹路å¾Âä¸ÂãÂÂ该å½令æ¯两ç¨çÂÂï¼Âæ¢å¯以åÂÂå§ÂÃ¥ÂÂ并çÂÂæÂÂå ¨å¥Â代ç Âï¼Âä¹Âå¯以ç¨äºÂå¨åÂÂç»Â项ç®è¿Â代è¿Âç¨Âä¸Âå¢ÂéÂÂçÂÂæÂÂ代ç ÂãÂÂ--db_driver
ï¼Â设置æ°æ®åºÂdriverï¼Âæ¯æÂÂçÂÂÃ¥ÂÂæ°å¼æÂÂmysqlï¼Âpostgresï¼Âsqliteï¼ÂsqlserverÃ¥ÂÂtidbãÂÂ--db_dsn
ï¼Â设置æ°æ®åºÂè¿ÂæÂ¥å°åÂÂï¼Â注æÂÂéÂÂè¦ÂÃ¥ÂÂÃ¥ÂÂå åÂÂå¼Âå·--db_soft
ï¼Â设置表示软å é¤çÂÂÃ¥ÂÂ段ï¼Âé»Â认å¼æ¯deleted_at
ï¼Âå³æ°æ®åºÂ表ç»ÂæÂÂéÂÂå¿ é¡»æÂÂ--db_soft
æÂÂå®ÂçÂÂÃ¥ÂÂ段æÂÂä¼Âç¨ä¸ÂgormçÂÂ软å é¤æºå¶--db_grpc
ï¼Â设置æ¯å¦çÂÂæÂÂgRPCå ¨å¥ÂæÂÂå¡代ç Âï¼Âé»Â认å¼æ¯false
- å¦å¤Âè¿ÂæÂÂä¸Â个åÂÂæ°
--db_table_prefix
ï¼Â主è¦Âç¨äºÂPostgreSQLï¼ÂæÂÂå®ÂschemaÃ¥ÂÂ称
go-doudou svc init
å½令è¿ÂæÂÂä¸ÂäºÂÃ¥Â
¶ä»ÂÃ¥ÂÂè½åÂÂå½令è¡ÂÃ¥ÂÂæ°ï¼ÂæÂÂÃ¥Â
´è¶£çÂÂè¯Âå¯以æ§è¡Âå½令go-doudou svc init --help
æÂ¥çÂÂãÂÂ
æÂÂ们使ç¨è¿Âä¸Âç¹æ§çÂÂæµÂç¨Âä¸Â辯å ÂéÂÂè¿ÂnavicatçÂÂæ°æ®åºÂå¾形åÂÂ管çÂÂ工堷åÂÂ建模åÂÂï¼Âç¶åÂÂæ§è¡Âgo-doudouå½令çÂÂæÂÂå ¨å¥Â代ç Âï¼ÂéÂÂçÂÂéÂÂæ±ÂçÂÂå¢Âå åÂÂ项ç®çÂÂæÂÂç»Âè¿Â代å¢Âå æ°表ï¼ÂÃ¥ÂÂæ§è¡Âgo-doudouå½令å¢ÂéÂÂçÂÂæÂÂ代ç ÂãÂÂæ¤åÂÂè½ä¸Âä¼Âä¿®æ¹æÂÂè è¦ÂçÂÂä»»ä½ÂæÂÂå·¥èªå®Âä¹ÂçÂÂæÂ¥å£åÂÂ代ç Âï¼Âå®Âå ¨çÂÂå¢ÂéÂÂçÂÂæÂÂï¼Âå¯以æ¾å¿Â使ç¨ï¼Âä¸Âé¢æÂÂ们å¨æÂÂå®Âè·µä¸Âä¸Âå§ï¼Â
æÂÂ们以PostgreSQL为ä¾Âï¼ÂÃ¥Â
ÂÃ¥ÂÂ建ä¸Â个æ°æ®åºÂtestpgï¼Âcreate database testpg;
ï¼Âç¶åÂÂå°Âä¸Âé¢çÂÂDDLè¯Âå¥导åÂ
¥å³å¯ãÂÂ
-- Create "address" table
CREATE TABLE "address" ("id" bigserial NOT NULL, "uid" bigint NULL DEFAULT 0, "phone" character varying(30) NULL DEFAULT '', "name" character varying(30) NULL DEFAULT '', "zipcode" character varying(20) NULL DEFAULT '', "address" character varying(250) NULL DEFAULT '', "default_address" bigint NULL DEFAULT 0, "add_time" bigint NULL DEFAULT 0, PRIMARY KEY ("id"));
-- Set comment to table: "address"
COMMENT ON TABLE "address" IS 'å°åÂÂä¿¡æ¯';
-- Set comment to column: "id" on table: "address"
COMMENT ON COLUMN "address" ."id" IS '主é®';
-- Set comment to column: "uid" on table: "address"
COMMENT ON COLUMN "address" ."uid" IS 'ç¨æ·ç¼Âå·';
-- Set comment to column: "phone" on table: "address"
COMMENT ON COLUMN "address" ."phone" IS 'ç¨æ·æÂÂæº';
-- Set comment to column: "name" on table: "address"
COMMENT ON COLUMN "address" ."name" IS 'ç¨æ·åÂÂÃ¥ÂÂ';
-- Set comment to column: "zipcode" on table: "address"
COMMENT ON COLUMN "address" ."zipcode" IS 'é®æ¿ç¼Âç Â';
-- Set comment to column: "address" on table: "address"
COMMENT ON COLUMN "address" ."address" IS 'å°åÂÂ';
-- Set comment to column: "default_address" on table: "address"
COMMENT ON COLUMN "address" ."default_address" IS 'é»Â认å°åÂÂ';
-- Set comment to column: "add_time" on table: "address"
COMMENT ON COLUMN "address" ."add_time" IS 'æ·»å æ¶é´';
-- Create "administrator" table
CREATE TABLE "administrator" ("id" bigserial NOT NULL, "username" character varying(100) NULL DEFAULT '', "password" character varying(100) NULL DEFAULT '', "mobile" character varying(100) NULL, "email" character varying(50) NULL DEFAULT '', "status" smallint NULL DEFAULT 0, "role_id" bigint NULL DEFAULT 0, "add_time" bigint NULL DEFAULT 0, "is_super" smallint NULL DEFAULT 0, PRIMARY KEY ("id"));
-- Set comment to table: "administrator"
COMMENT ON TABLE "administrator" IS '管çÂÂÃ¥ÂÂ表';
-- Set comment to column: "username" on table: "administrator"
COMMENT ON COLUMN "administrator" ."username" IS 'ç¨æ·åÂÂ';
-- Set comment to column: "password" on table: "administrator"
COMMENT ON COLUMN "administrator" ."password" IS 'å¯Âç Â';
-- Set comment to column: "mobile" on table: "administrator"
COMMENT ON COLUMN "administrator" ."mobile" IS 'æÂÂæºå·';
-- Set comment to column: "email" on table: "administrator"
COMMENT ON COLUMN "administrator" ."email" IS 'é®箱';
-- Set comment to column: "status" on table: "administrator"
COMMENT ON COLUMN "administrator" ."status" IS 'ç¶æÂÂ';
-- Set comment to column: "role_id" on table: "administrator"
COMMENT ON COLUMN "administrator" ."role_id" IS 'è§Âè²ç¼Âå·';
-- Set comment to column: "add_time" on table: "administrator"
COMMENT ON COLUMN "administrator" ."add_time" IS 'æ·»å æ¶é´';
-- Set comment to column: "is_super" on table: "administrator"
COMMENT ON COLUMN "administrator" ."is_super" IS 'æ¯å¦è¶Â
级管çÂÂÃ¥ÂÂ';
-- Create "auth" table
CREATE TABLE "auth" ("id" bigserial NOT NULL, "module_name" character varying(80) NOT NULL DEFAULT '', "action_name" character varying(80) NULL DEFAULT '', "type" boolean NULL DEFAULT false, "url" character varying(250) NULL DEFAULT '', "module_id" bigint NULL DEFAULT 0, "sort" bigint NULL DEFAULT 0, "description" character varying(250) NULL DEFAULT '', "status" boolean NULL DEFAULT false, "add_time" bigint NULL DEFAULT 0, "checked" boolean NULL DEFAULT false, PRIMARY KEY ("id"));
-- Set comment to table: "auth"
COMMENT ON TABLE "auth" IS 'æÂÂéÂÂæ§å¶';
-- Set comment to column: "action_name" on table: "auth"
COMMENT ON COLUMN "auth" ."action_name" IS 'æÂÂä½ÂÃ¥ÂÂ称';
-- Set comment to column: "type" on table: "auth"
COMMENT ON COLUMN "auth" ."type" IS 'èÂÂç¹类åÂÂ';
-- Set comment to column: "url" on table: "auth"
COMMENT ON COLUMN "auth" ."url" IS '跳转å°åÂÂ';
-- Set comment to column: "module_id" on table: "auth"
COMMENT ON COLUMN "auth" ."module_id" IS '模åÂÂç¼Âå·';
-- Set comment to column: "sort" on table: "auth"
COMMENT ON COLUMN "auth" ."sort" IS 'æÂÂåºÂ';
-- Set comment to column: "description" on table: "auth"
COMMENT ON COLUMN "auth" ."description" IS 'æÂÂè¿°';
-- Set comment to column: "status" on table: "auth"
COMMENT ON COLUMN "auth" ."status" IS 'ç¶æÂÂ';
-- Set comment to column: "add_time" on table: "auth"
COMMENT ON COLUMN "auth" ."add_time" IS 'æ·»å æ¶é´';
-- Set comment to column: "checked" on table: "auth"
COMMENT ON COLUMN "auth" ."checked" IS 'æ¯å¦æ£ÂéªÂ';
-- Create "banner" table
CREATE TABLE "banner" ("id" bigserial NOT NULL, "title" character varying(50) NULL DEFAULT '', "banner_type" smallint NULL DEFAULT 0, "banner_img" character varying(100) NULL DEFAULT '', "link" character varying(200) NULL DEFAULT '', "sort" bigint NULL DEFAULT 0, "status" bigint NULL DEFAULT 0, "add_time" bigint NULL DEFAULT 0, PRIMARY KEY ("id"));
-- Set comment to table: "banner"
COMMENT ON TABLE "banner" IS 'ç¦ç¹å¾表';
-- Set comment to column: "id" on table: "banner"
COMMENT ON COLUMN "banner" ."id" IS '主é®';
-- Set comment to column: "title" on table: "banner"
COMMENT ON COLUMN "banner" ."title" IS 'æ Âé¢Â';
-- Set comment to column: "banner_type" on table: "banner"
COMMENT ON COLUMN "banner" ."banner_type" IS 'ç±»åÂÂ';
-- Set comment to column: "banner_img" on table: "banner"
COMMENT ON COLUMN "banner" ."banner_img" IS 'å¾çÂÂå°åÂÂ';
-- Set comment to column: "link" on table: "banner"
COMMENT ON COLUMN "banner" ."link" IS 'è¿ÂæÂÂ¥';
-- Set comment to column: "sort" on table: "banner"
COMMENT ON COLUMN "banner" ."sort" IS 'æÂÂåºÂ';
-- Set comment to column: "status" on table: "banner"
COMMENT ON COLUMN "banner" ."status" IS 'ç¶æÂÂ';
-- Set comment to column: "add_time" on table: "banner"
COMMENT ON COLUMN "banner" ."add_time" IS 'æ·»å æ¶é´';
-- Create "cart" table
CREATE TABLE "cart" ("id" bigserial NOT NULL, "title" character varying(250) NULL DEFAULT '', "price" numeric(10,2) NULL DEFAULT 0.00, "goods_version" character varying(50) NULL DEFAULT '', "num" bigint NULL DEFAULT 0, "product_gift" character varying(100) NULL DEFAULT '', "product_fitting" character varying(100) NULL DEFAULT '', "product_color" character varying(50) NULL DEFAULT '', "product_img" character varying(150) NULL DEFAULT '', "product_attr" character varying(100) NULL DEFAULT '', PRIMARY KEY ("id"));
-- Set comment to table: "cart"
COMMENT ON TABLE "cart" IS 'è´Âç©车';
-- Set comment to column: "id" on table: "cart"
COMMENT ON COLUMN "cart" ."id" IS '主é®';
-- Set comment to column: "title" on table: "cart"
COMMENT ON COLUMN "cart" ."title" IS 'æ Âé¢Â';
-- Set comment to column: "goods_version" on table: "cart"
COMMENT ON COLUMN "cart" ."goods_version" IS 'çÂÂæ¬';
-- Set comment to column: "num" on table: "cart"
COMMENT ON COLUMN "cart" ."num" IS 'æ°éÂÂ';
-- Set comment to column: "product_gift" on table: "cart"
COMMENT ON COLUMN "cart" ."product_gift" IS 'Ã¥ÂÂÃ¥ÂÂ礼ç©';
-- Set comment to column: "product_fitting" on table: "cart"
COMMENT ON COLUMN "cart" ."product_fitting" IS 'Ã¥ÂÂÃ¥ÂÂæÂÂéÂ
Â';
-- Set comment to column: "product_color" on table: "cart"
COMMENT ON COLUMN "cart" ."product_color" IS 'Ã¥ÂÂÃ¥ÂÂé¢Âè²';
-- Set comment to column: "product_img" on table: "cart"
COMMENT ON COLUMN "cart" ."product_img" IS 'Ã¥ÂÂÃ¥ÂÂå¾çÂÂ';
-- Set comment to column: "product_attr" on table: "cart"
COMMENT ON COLUMN "cart" ."product_attr" IS 'Ã¥ÂÂÃ¥ÂÂå±Âæ§';
-- Create "menu" table
CREATE TABLE "menu" ("id" bigserial NOT NULL, "title" character varying(100) NULL DEFAULT '', "link" character varying(250) NULL DEFAULT '', "position" bigint NULL DEFAULT 0, "is_opennew" bigint NULL DEFAULT 0, "relation" character varying(100) NULL DEFAULT '', "sort" bigint NULL DEFAULT 0, "status" bigint NULL DEFAULT 0, "add_time" bigint NULL DEFAULT 0, PRIMARY KEY ("id"));
-- Set comment to column: "id" on table: "menu"
COMMENT ON COLUMN "menu" ."id" IS 'ç¼Âå·';
-- Set comment to column: "title" on table: "menu"
COMMENT ON COLUMN "menu" ."title" IS 'æ Âé¢Â';
-- Set comment to column: "link" on table: "menu"
COMMENT ON COLUMN "menu" ."link" IS 'è¿ÂæÂÂ¥';
-- Set comment to column: "position" on table: "menu"
COMMENT ON COLUMN "menu" ."position" IS 'ä½Âç½®';
-- Set comment to column: "is_opennew" on table: "menu"
COMMENT ON COLUMN "menu" ."is_opennew" IS 'æ¯å¦æ°æÂÂå¼Â';
-- Set comment to column: "relation" on table: "menu"
COMMENT ON COLUMN "menu" ."relation" IS 'Ã¥Â
³ç³»';
-- Set comment to column: "sort" on table: "menu"
COMMENT ON COLUMN "menu" ."sort" IS 'æÂÂåºÂ';
-- Set comment to column: "status" on table: "menu"
COMMENT ON COLUMN "menu" ."status" IS 'ç¶æÂÂ';
-- Set comment to column: "add_time" on table: "menu"
COMMENT ON COLUMN "menu" ."add_time" IS 'æ·»å æ¶é´';
-- Create "order" table
CREATE TABLE "order" ("id" bigserial NOT NULL, "order_id" character varying(100) NULL DEFAULT '', "uid" bigint NULL DEFAULT 0, "all_price" numeric(10,2) NULL DEFAULT 0.00, "phone" character varying(30) NULL DEFAULT '', "name" character varying(100) NULL DEFAULT '', "address" character varying(250) NULL DEFAULT '', "zipcode" character varying(30) NULL DEFAULT '', "pay_status" smallint NULL DEFAULT 0, "pay_type" smallint NULL DEFAULT 0, "order_status" smallint NULL DEFAULT 0, "add_time" bigint NULL DEFAULT 0, PRIMARY KEY ("id"));
-- Set comment to column: "id" on table: "order"
COMMENT ON COLUMN "order" ."id" IS 'ç¼Âå·';
-- Set comment to column: "order_id" on table: "order"
COMMENT ON COLUMN "order" ."order_id" IS '订åÂÂç¼Âå·';
-- Set comment to column: "uid" on table: "order"
COMMENT ON COLUMN "order" ."uid" IS 'ç¨æ·ç¼Âå·';
-- Set comment to column: "all_price" on table: "order"
COMMENT ON COLUMN "order" ."all_price" IS 'ä»·æ ¼';
-- Set comment to column: "phone" on table: "order"
COMMENT ON COLUMN "order" ."phone" IS 'çµè¯Â';
-- Set comment to column: "name" on table: "order"
COMMENT ON COLUMN "order" ."name" IS 'Ã¥ÂÂÃ¥ÂÂ';
-- Set comment to column: "address" on table: "order"
COMMENT ON COLUMN "order" ."address" IS 'å°åÂÂ';
-- Set comment to column: "zipcode" on table: "order"
COMMENT ON COLUMN "order" ."zipcode" IS 'é®ç¼Â';
-- Set comment to column: "pay_status" on table: "order"
COMMENT ON COLUMN "order" ."pay_status" IS 'æ¯ä»Âç¶æÂÂ';
-- Set comment to column: "pay_type" on table: "order"
COMMENT ON COLUMN "order" ."pay_type" IS 'æ¯ä»Âç±»åÂÂ';
-- Set comment to column: "order_status" on table: "order"
COMMENT ON COLUMN "order" ."order_status" IS '订åÂÂç¶æÂÂ';
-- Set comment to column: "add_time" on table: "order"
COMMENT ON COLUMN "order" ."add_time" IS 'æ·»å æ¶é´';
-- Create "order_item" table
CREATE TABLE "order_item" ("id" bigserial NOT NULL, "order_id" bigint NULL DEFAULT 0, "uid" bigint NULL DEFAULT 0, "product_title" character varying(100) NULL DEFAULT '', "product_id" bigint NULL DEFAULT 0, "product_img" character varying(200) NULL DEFAULT '', "product_price" numeric(10,2) NULL DEFAULT 0.00, "product_num" bigint NULL DEFAULT 0, "goods_version" character varying(100) NULL DEFAULT '', "goods_color" character varying(100) NULL DEFAULT '', "add_time" bigint NULL DEFAULT 0, PRIMARY KEY ("id"));
-- Set comment to column: "id" on table: "order_item"
COMMENT ON COLUMN "order_item" ."id" IS '订åÂÂç¼Âå·';
-- Set comment to column: "order_id" on table: "order_item"
COMMENT ON COLUMN "order_item" ."order_id" IS '订åÂÂç¼Âå·';
-- Set comment to column: "uid" on table: "order_item"
COMMENT ON COLUMN "order_item" ."uid" IS 'ç¨æ·ç¼Âå·';
-- Set comment to column: "product_title" on table: "order_item"
COMMENT ON COLUMN "order_item" ."product_title" IS 'Ã¥ÂÂÃ¥ÂÂæ Âé¢Â';
-- Set comment to column: "product_id" on table: "order_item"
COMMENT ON COLUMN "order_item" ."product_id" IS 'Ã¥ÂÂÃ¥ÂÂç¼Âå·';
-- Set comment to column: "product_img" on table: "order_item"
COMMENT ON COLUMN "order_item" ."product_img" IS 'Ã¥ÂÂÃ¥ÂÂå¾çÂÂ';
-- Set comment to column: "product_price" on table: "order_item"
COMMENT ON COLUMN "order_item" ."product_price" IS 'Ã¥ÂÂÃ¥ÂÂä»·æ ¼';
-- Set comment to column: "product_num" on table: "order_item"
COMMENT ON COLUMN "order_item" ."product_num" IS 'Ã¥ÂÂÃ¥ÂÂæ°éÂÂ';
-- Set comment to column: "goods_version" on table: "order_item"
COMMENT ON COLUMN "order_item" ."goods_version" IS 'Ã¥ÂÂÃ¥ÂÂçÂÂæ¬';
-- Set comment to column: "goods_color" on table: "order_item"
COMMENT ON COLUMN "order_item" ."goods_color" IS 'Ã¥ÂÂÃ¥ÂÂé¢Âè²';
-- Set comment to column: "add_time" on table: "order_item"
COMMENT ON COLUMN "order_item" ."add_time" IS 'æ·»å æ¶é´';
-- Create "product" table
CREATE TABLE "product" ("id" bigserial NOT NULL, "title" character varying(100) NULL DEFAULT '', "sub_title" character varying(100) NULL DEFAULT '', "product_sn" character varying(50) NULL DEFAULT '', "cate_id" bigint NULL DEFAULT 0, "click_count" bigint NULL DEFAULT 0, "product_number" bigint NULL DEFAULT 0, "price" numeric(10,2) NULL DEFAULT 0.00, "market_price" numeric(10,2) NULL DEFAULT 0.00, "relation_product" character varying(100) NULL DEFAULT '', "product_attr" character varying(100) NULL DEFAULT '', "product_version" character varying(100) NULL DEFAULT '', "product_img" character varying(100) NULL DEFAULT '', "product_gift" character varying(100) NULL DEFAULT '', "product_fitting" character varying(100) NULL DEFAULT '', "product_color" character varying(100) NULL DEFAULT '', "product_keywords" character varying(100) NULL DEFAULT '', "product_desc" character varying(50) NULL DEFAULT '', "product_content" character varying(100) NULL DEFAULT '', "is_delete" smallint NULL DEFAULT 0, "is_hot" smallint NULL DEFAULT 0, "is_best" smallint NULL DEFAULT 0, "is_new" smallint NULL DEFAULT 0, "product_type_id" smallint NULL DEFAULT 0, "sort" bigint NULL DEFAULT 0, "status" smallint NULL DEFAULT 0, "add_time" bigint NULL DEFAULT 0, PRIMARY KEY ("id"));
-- Set comment to table: "product"
COMMENT ON TABLE "product" IS 'Ã¥ÂÂÃ¥ÂÂ';
-- Set comment to column: "title" on table: "product"
COMMENT ON COLUMN "product" ."title" IS 'æ Âé¢Â';
-- Set comment to column: "sub_title" on table: "product"
COMMENT ON COLUMN "product" ."sub_title" IS 'Ã¥ÂÂæ Âé¢Â';
-- Set comment to column: "cate_id" on table: "product"
COMMENT ON COLUMN "product" ."cate_id" IS 'Ã¥ÂÂç±»id';
-- Set comment to column: "click_count" on table: "product"
COMMENT ON COLUMN "product" ."click_count" IS 'ç¹åÂȾ°';
-- Set comment to column: "product_number" on table: "product"
COMMENT ON COLUMN "product" ."product_number" IS 'Ã¥ÂÂÃ¥ÂÂç¼Âå·';
-- Set comment to column: "price" on table: "product"
COMMENT ON COLUMN "product" ."price" IS 'ä»·æ ¼';
-- Set comment to column: "market_price" on table: "product"
COMMENT ON COLUMN "product" ."market_price" IS 'å¸Âåº价格';
-- Set comment to column: "relation_product" on table: "product"
COMMENT ON COLUMN "product" ."relation_product" IS 'Ã¥Â
³èÂÂÃ¥ÂÂÃ¥ÂÂ';
-- Set comment to column: "product_attr" on table: "product"
COMMENT ON COLUMN "product" ."product_attr" IS 'Ã¥ÂÂÃ¥ÂÂå±Âæ§';
-- Set comment to column: "product_version" on table: "product"
COMMENT ON COLUMN "product" ."product_version" IS 'Ã¥ÂÂÃ¥ÂÂçÂÂæ¬';
-- Set comment to column: "product_img" on table: "product"
COMMENT ON COLUMN "product" ."product_img" IS 'Ã¥ÂÂÃ¥ÂÂå¾çÂÂ';
-- Set comment to column: "product_color" on table: "product"
COMMENT ON COLUMN "product" ."product_color" IS 'Ã¥ÂÂÃ¥ÂÂé¢Âè²';
-- Set comment to column: "product_keywords" on table: "product"
COMMENT ON COLUMN "product" ."product_keywords" IS 'Ã¥Â
³é®è¯Â';
-- Set comment to column: "product_desc" on table: "product"
COMMENT ON COLUMN "product" ."product_desc" IS 'æÂÂè¿°';
-- Set comment to column: "product_content" on table: "product"
COMMENT ON COLUMN "product" ."product_content" IS 'Ã¥ÂÂ
容';
-- Set comment to column: "is_delete" on table: "product"
COMMENT ON COLUMN "product" ."is_delete" IS 'æ¯å¦å é¤';
-- Set comment to column: "is_hot" on table: "product"
COMMENT ON COLUMN "product" ."is_hot" IS 'æ¯å¦çÂÂé¨';
-- Set comment to column: "is_best" on table: "product"
COMMENT ON COLUMN "product" ."is_best" IS 'æ¯å¦çÂÂ
éÂÂ';
-- Set comment to column: "is_new" on table: "product"
COMMENT ON COLUMN "product" ."is_new" IS 'æ¯å¦æ°åÂÂ';
-- Set comment to column: "product_type_id" on table: "product"
COMMENT ON COLUMN "product" ."product_type_id" IS 'Ã¥ÂÂÃ¥ÂÂç±»åÂÂç¼Âå·';
-- Set comment to column: "sort" on table: "product"
COMMENT ON COLUMN "product" ."sort" IS 'Ã¥ÂÂÃ¥ÂÂÃ¥ÂÂç±»';
-- Set comment to column: "status" on table: "product"
COMMENT ON COLUMN "product" ."status" IS 'Ã¥ÂÂÃ¥ÂÂç¶æÂÂ';
-- Set comment to column: "add_time" on table: "product"
COMMENT ON COLUMN "product" ."add_time" IS 'æ·»å æ¶é´';
-- Create "product_attr" table
CREATE TABLE "product_attr" ("id" bigserial NOT NULL, "product_id" bigint NULL DEFAULT 0, "attribute_cate_id" bigint NULL DEFAULT 0, "attribute_id" bigint NULL DEFAULT 0, "attribute_title" character varying(100) NULL DEFAULT '', "attribute_type" bigint NULL DEFAULT 0, "attribute_value" character varying(100) NULL DEFAULT '', "sort" bigint NULL DEFAULT 0, "add_time" bigint NULL DEFAULT 0, "status" smallint NULL DEFAULT 0, PRIMARY KEY ("id"));
-- Set comment to table: "product_attr"
COMMENT ON TABLE "product_attr" IS 'Ã¥ÂÂÃ¥ÂÂå±Âæ§';
-- Set comment to column: "product_id" on table: "product_attr"
COMMENT ON COLUMN "product_attr" ."product_id" IS 'Ã¥ÂÂÃ¥ÂÂç¼Âå·';
-- Set comment to column: "attribute_cate_id" on table: "product_attr"
COMMENT ON COLUMN "product_attr" ."attribute_cate_id" IS 'å±Âæ§åÂÂç±»ç¼Âå·';
-- Set comment to column: "attribute_id" on table: "product_attr"
COMMENT ON COLUMN "product_attr" ."attribute_id" IS 'å±Âæ§ç¼Âå·';
-- Set comment to column: "attribute_title" on table: "product_attr"
COMMENT ON COLUMN "product_attr" ."attribute_title" IS 'å±Âæ§æ Âé¢Â';
-- Set comment to column: "attribute_type" on table: "product_attr"
COMMENT ON COLUMN "product_attr" ."attribute_type" IS 'å±Âæ§类åÂÂ';
-- Set comment to column: "attribute_value" on table: "product_attr"
COMMENT ON COLUMN "product_attr" ."attribute_value" IS 'å±Âæ§å¼';
-- Set comment to column: "sort" on table: "product_attr"
COMMENT ON COLUMN "product_attr" ."sort" IS 'æÂÂåºÂ';
-- Set comment to column: "add_time" on table: "product_attr"
COMMENT ON COLUMN "product_attr" ."add_time" IS 'æ·»å æ¶é´';
-- Set comment to column: "status" on table: "product_attr"
COMMENT ON COLUMN "product_attr" ."status" IS 'ç¶æÂÂ';
-- Create "product_cate" table
CREATE TABLE "product_cate" ("id" bigserial NOT NULL, "title" character varying(200) NULL DEFAULT '', "cate_img" character varying(200) NULL DEFAULT '', "link" character varying(250) NULL DEFAULT '', "template" text NULL, "pid" bigint NULL DEFAULT 0, "sub_title" character varying(100) NULL DEFAULT '', "keywords" character varying(250) NULL DEFAULT '', "description" text NULL, "sort" bigint NULL DEFAULT 0, "status" smallint NULL DEFAULT 0, "add_time" bigint NULL DEFAULT 0, PRIMARY KEY ("id"));
-- Set comment to table: "product_cate"
COMMENT ON TABLE "product_cate" IS 'Ã¥ÂÂÃ¥ÂÂÃ¥ÂÂç±»';
-- Set comment to column: "title" on table: "product_cate"
COMMENT ON COLUMN "product_cate" ."title" IS 'Ã¥ÂÂç±»åÂÂ称';
-- Set comment to column: "cate_img" on table: "product_cate"
COMMENT ON COLUMN "product_cate" ."cate_img" IS 'Ã¥ÂÂç±»å¾çÂÂ';
-- Set comment to column: "link" on table: "product_cate"
COMMENT ON COLUMN "product_cate" ."link" IS 'é¾æÂÂ¥';
-- Set comment to column: "template" on table: "product_cate"
COMMENT ON COLUMN "product_cate" ."template" IS '模çÂÂ';
-- Set comment to column: "pid" on table: "product_cate"
COMMENT ON COLUMN "product_cate" ."pid" IS 'ç¶ç¼Âå·';
-- Set comment to column: "sub_title" on table: "product_cate"
COMMENT ON COLUMN "product_cate" ."sub_title" IS 'Ã¥ÂÂæ Âé¢Â';
-- Set comment to column: "keywords" on table: "product_cate"
COMMENT ON COLUMN "product_cate" ."keywords" IS 'Ã¥Â
³é®åÂÂ';
-- Set comment to column: "description" on table: "product_cate"
COMMENT ON COLUMN "product_cate" ."description" IS 'æÂÂè¿°';
-- Set comment to column: "sort" on table: "product_cate"
COMMENT ON COLUMN "product_cate" ."sort" IS 'æÂÂåºÂ';
-- Set comment to column: "status" on table: "product_cate"
COMMENT ON COLUMN "product_cate" ."status" IS 'ç¶æÂÂ';
-- Set comment to column: "add_time" on table: "product_cate"
COMMENT ON COLUMN "product_cate" ."add_time" IS 'æ·»å æ¶é´';
-- Create "product_color" table
CREATE TABLE "product_color" ("id" bigserial NOT NULL, "color_name" character varying(100) NULL DEFAULT '', "color_value" character varying(100) NULL DEFAULT '', "status" smallint NULL DEFAULT 0, "checked" smallint NULL DEFAULT 0, PRIMARY KEY ("id"));
-- Set comment to column: "color_name" on table: "product_color"
COMMENT ON COLUMN "product_color" ."color_name" IS 'é¢Âè²åÂÂÃ¥ÂÂ';
-- Set comment to column: "color_value" on table: "product_color"
COMMENT ON COLUMN "product_color" ."color_value" IS 'é¢Âè²å¼';
-- Set comment to column: "status" on table: "product_color"
COMMENT ON COLUMN "product_color" ."status" IS 'ç¶æÂÂ';
-- Set comment to column: "checked" on table: "product_color"
COMMENT ON COLUMN "product_color" ."checked" IS 'æ¯å¦æ£ÂéªÂ';
-- Create "product_image" table
CREATE TABLE "product_image" ("id" bigserial NOT NULL, "product_id" bigint NULL DEFAULT 0, "img_url" character varying(250) NULL DEFAULT '', "color_id" bigint NULL DEFAULT 0, "sort" bigint NULL DEFAULT 0, "add_time" bigint NULL DEFAULT 0, "status" smallint NULL DEFAULT 0, PRIMARY KEY ("id"));
-- Set comment to column: "product_id" on table: "product_image"
COMMENT ON COLUMN "product_image" ."product_id" IS 'Ã¥ÂÂÃ¥ÂÂç¼Âå·';
-- Set comment to column: "img_url" on table: "product_image"
COMMENT ON COLUMN "product_image" ."img_url" IS 'å¾çÂÂå°åÂÂ';
-- Set comment to column: "color_id" on table: "product_image"
COMMENT ON COLUMN "product_image" ."color_id" IS 'é¢Âè²ç¼Âå·';
-- Set comment to column: "sort" on table: "product_image"
COMMENT ON COLUMN "product_image" ."sort" IS 'æÂÂåºÂ';
-- Set comment to column: "add_time" on table: "product_image"
COMMENT ON COLUMN "product_image" ."add_time" IS 'æ·»å æ¶é´';
-- Set comment to column: "status" on table: "product_image"
COMMENT ON COLUMN "product_image" ."status" IS 'ç¶æÂÂ';
-- Create "product_type" table
CREATE TABLE "product_type" ("id" bigserial NOT NULL, "title" character varying(100) NULL DEFAULT '', "description" character varying(500) NULL DEFAULT '', "status" smallint NULL DEFAULT 0, "add_time" bigint NULL DEFAULT 0, PRIMARY KEY ("id"));
-- Set comment to column: "title" on table: "product_type"
COMMENT ON COLUMN "product_type" ."title" IS 'æ Âé¢Â';
-- Set comment to column: "description" on table: "product_type"
COMMENT ON COLUMN "product_type" ."description" IS 'æÂÂè¿°';
-- Set comment to column: "status" on table: "product_type"
COMMENT ON COLUMN "product_type" ."status" IS 'ç¶æÂÂ';
-- Set comment to column: "add_time" on table: "product_type"
COMMENT ON COLUMN "product_type" ."add_time" IS 'æ·»å æ¶é´';
-- Create "product_type_attribute" table
CREATE TABLE "product_type_attribute" ("id" bigserial NOT NULL, "cate_id" bigint NULL DEFAULT 0, "title" character varying(100) NULL DEFAULT '', "attr_type" smallint NULL DEFAULT 0, "attr_value" character varying(100) NULL DEFAULT '', "status" smallint NULL DEFAULT 0, "sort" bigint NULL DEFAULT 0, "add_time" bigint NULL DEFAULT 0, PRIMARY KEY ("id"));
-- Set comment to column: "cate_id" on table: "product_type_attribute"
COMMENT ON COLUMN "product_type_attribute" ."cate_id" IS 'Ã¥ÂÂç±»ç¼Âå·';
-- Set comment to column: "title" on table: "product_type_attribute"
COMMENT ON COLUMN "product_type_attribute" ."title" IS 'æ Âé¢Â';
-- Set comment to column: "attr_type" on table: "product_type_attribute"
COMMENT ON COLUMN "product_type_attribute" ."attr_type" IS 'å±Âæ§类åÂÂ';
-- Set comment to column: "attr_value" on table: "product_type_attribute"
COMMENT ON COLUMN "product_type_attribute" ."attr_value" IS 'å±Âæ§å¼';
-- Set comment to column: "status" on table: "product_type_attribute"
COMMENT ON COLUMN "product_type_attribute" ."status" IS 'ç¶æÂÂ';
-- Set comment to column: "sort" on table: "product_type_attribute"
COMMENT ON COLUMN "product_type_attribute" ."sort" IS 'æÂÂåºÂ';
-- Set comment to column: "add_time" on table: "product_type_attribute"
COMMENT ON COLUMN "product_type_attribute" ."add_time" IS 'æ·»å æ¶é´';
-- Create "role" table
CREATE TABLE "role" ("id" bigserial NOT NULL, "title" character varying(100) NULL DEFAULT '', "description" character varying(500) NULL DEFAULT '', "status" smallint NULL DEFAULT 0, "add_time" bigint NULL DEFAULT 0, PRIMARY KEY ("id"));
-- Set comment to column: "title" on table: "role"
COMMENT ON COLUMN "role" ."title" IS 'æ Âé¢ÂÃ¥ÂÂ称';
-- Set comment to column: "description" on table: "role"
COMMENT ON COLUMN "role" ."description" IS 'æÂÂè¿°';
-- Set comment to column: "status" on table: "role"
COMMENT ON COLUMN "role" ."status" IS 'ç¶æÂÂ';
-- Set comment to column: "add_time" on table: "role"
COMMENT ON COLUMN "role" ."add_time" IS 'æ·»å æ¶é´';
-- Create "role_auth" table
CREATE TABLE "role_auth" ("auth_id" bigserial NOT NULL, "role_id" bigint NULL DEFAULT 0, "id" bigserial NOT NULL, PRIMARY KEY ("id"));
-- Set comment to column: "auth_id" on table: "role_auth"
COMMENT ON COLUMN "role_auth" ."auth_id" IS 'æÂÂéÂÂç¼Âå·';
-- Set comment to column: "role_id" on table: "role_auth"
COMMENT ON COLUMN "role_auth" ."role_id" IS 'è§Âè²ç¼Âå·';
-- Create "setting" table
CREATE TABLE "setting" ("id" bigserial NOT NULL, "site_title" character varying(100) NULL DEFAULT '', "site_logo" character varying(250) NULL DEFAULT '', "site_keywords" character varying(100) NULL DEFAULT '', "site_description" character varying(500) NULL DEFAULT '', "no_picture" character varying(100) NULL DEFAULT '', "site_icp" character varying(50) NULL DEFAULT '', "site_tel" character varying(50) NULL DEFAULT '', "search_keywords" character varying(250) NULL DEFAULT '', "tongji_code" character varying(500) NULL DEFAULT '', "appid" character varying(50) NULL DEFAULT '', "app_secret" character varying(80) NULL DEFAULT '', "end_point" character varying(200) NULL DEFAULT '', "bucket_name" character varying(200) NULL DEFAULT '', "oss_status" smallint NULL DEFAULT 0, PRIMARY KEY ("id"));
-- Set comment to column: "site_title" on table: "setting"
COMMENT ON COLUMN "setting" ."site_title" IS 'Ã¥ÂÂÃ¥ÂÂÃ¥ÂÂ称';
-- Set comment to column: "site_logo" on table: "setting"
COMMENT ON COLUMN "setting" ."site_logo" IS 'Ã¥ÂÂÃ¥ÂÂå¾æ Â';
-- Set comment to column: "site_keywords" on table: "setting"
COMMENT ON COLUMN "setting" ."site_keywords" IS 'Ã¥ÂÂÃ¥ÂÂÃ¥Â
³é®åÂÂ';
-- Set comment to column: "site_description" on table: "setting"
COMMENT ON COLUMN "setting" ."site_description" IS 'Ã¥ÂÂÃ¥ÂÂæÂÂè¿°';
-- Set comment to column: "no_picture" on table: "setting"
COMMENT ON COLUMN "setting" ."no_picture" IS '没æÂÂå¾çÂÂæ¾示';
-- Set comment to column: "site_icp" on table: "setting"
COMMENT ON COLUMN "setting" ."site_icp" IS 'Ã¥ÂÂÃ¥ÂÂICP';
-- Set comment to column: "site_tel" on table: "setting"
COMMENT ON COLUMN "setting" ."site_tel" IS 'Ã¥ÂÂÃ¥ÂÂæÂÂæºå·';
-- Set comment to column: "search_keywords" on table: "setting"
COMMENT ON COLUMN "setting" ."search_keywords" IS 'æÂÂç´¢åÂ
³é®åÂÂ';
-- Set comment to column: "tongji_code" on table: "setting"
COMMENT ON COLUMN "setting" ."tongji_code" IS 'ç»Â计ç¼Âç Â';
-- Set comment to column: "appid" on table: "setting"
COMMENT ON COLUMN "setting" ."appid" IS 'oss appid';
-- Set comment to column: "app_secret" on table: "setting"
COMMENT ON COLUMN "setting" ."app_secret" IS 'oss app_secret';
-- Set comment to column: "end_point" on table: "setting"
COMMENT ON COLUMN "setting" ."end_point" IS 'oss ç»Â端ç¹';
-- Set comment to column: "bucket_name" on table: "setting"
COMMENT ON COLUMN "setting" ."bucket_name" IS 'oss 桶åÂÂ称';
-- Set comment to column: "oss_status" on table: "setting"
COMMENT ON COLUMN "setting" ."oss_status" IS 'oss ç¶æÂÂ';
-- Create "user" table
CREATE TABLE "user" ("id" bigserial NOT NULL, "phone" character varying(30) NULL DEFAULT '', "password" character varying(80) NULL DEFAULT '', "add_time" bigint NULL DEFAULT 0, "last_ip" character varying(50) NULL DEFAULT '', "email" character varying(80) NULL DEFAULT '', "status" smallint NULL DEFAULT 0, PRIMARY KEY ("id"));
-- Set comment to column: "phone" on table: "user"
COMMENT ON COLUMN "user" ."phone" IS 'æÂÂæºå·';
-- Set comment to column: "password" on table: "user"
COMMENT ON COLUMN "user" ."password" IS 'å¯Âç Â';
-- Set comment to column: "add_time" on table: "user"
COMMENT ON COLUMN "user" ."add_time" IS 'æ·»å æ¶é´';
-- Set comment to column: "last_ip" on table: "user"
COMMENT ON COLUMN "user" ."last_ip" IS 'æÂÂè¿Âip';
-- Set comment to column: "email" on table: "user"
COMMENT ON COLUMN "user" ."email" IS 'é®ç¼Â';
-- Set comment to column: "status" on table: "user"
COMMENT ON COLUMN "user" ."status" IS 'ç¶æÂÂ';
-- Create "user_sms" table
CREATE TABLE "user_sms" ("id" bigserial NOT NULL, "ip" character varying(50) NULL DEFAULT '', "phone" character varying(50) NULL DEFAULT '', "send_count" bigint NULL DEFAULT 0, "add_day" character varying(200) NULL DEFAULT '', "add_time" bigint NULL DEFAULT 0, "sign" character varying(80) NULL DEFAULT '', PRIMARY KEY ("id"));
-- Set comment to column: "ip" on table: "user_sms"
COMMENT ON COLUMN "user_sms" ."ip" IS 'ipå°åÂÂ';
-- Set comment to column: "phone" on table: "user_sms"
COMMENT ON COLUMN "user_sms" ."phone" IS 'æÂÂæºå·';
-- Set comment to column: "send_count" on table: "user_sms"
COMMENT ON COLUMN "user_sms" ."send_count" IS 'Ã¥ÂÂéÂÂç»Â计';
-- Set comment to column: "add_day" on table: "user_sms"
COMMENT ON COLUMN "user_sms" ."add_day" IS 'æ·»å æÂ¥æÂÂ';
-- Set comment to column: "add_time" on table: "user_sms"
COMMENT ON COLUMN "user_sms" ."add_time" IS 'æ·»å æ¶é´';
-- Set comment to column: "sign" on table: "user_sms"
COMMENT ON COLUMN "user_sms" ."sign" IS 'ç¾åÂÂ';
ç¶åÂÂæÂÂ们æ§è¡Âgo-doudouå½令å³å¯çÂÂæÂÂ代ç Â
go-doudou svc init testpg --db_driver postgres --db_dsn "host=localhost user=corteza password=corteza dbname=testpg port=5432 sslmode=disable TimeZone=Asia/Shanghai" --db_soft deleted_at --db_grpc
æ§è¡Âgo run cmd/main.go
æÂÂå¡å³å¯å¯å¨ãÂÂ代ç ÂéÂÂæÂÂOpenAPI3.0çÂÂæÂ¥å£æÂÂè¿°æÂÂ件testpg_openapi3.jsonï¼Âå¯以ç´æ¥导åÂ
Â¥postmanéÂÂè°Âè¯ÂæÂ¥å£ãÂÂ
Ã¥ÂÂ页æ¥询æÂ¥å£
æ¤å¤ÂéÂÂè¦ÂéÂÂç¹è¦Â说æÂÂä¸Âä¸ÂÃ¥ÂÂ页æ¥询类çÂÂæÂ¥å£ãÂÂ以GetUsers(ctx context.Context, parameter dto.Parameter) (data dto.Page, err error)
è¿Â个æÂ¥å£æ¹æ³Â为ä¾Âï¼Âä¼ÂçÂÂæ”get /users”Ã¥ÂÂ页æ¥询æÂ¥å£ãÂÂ导åÂ
Â¥postmanéÂÂæÂÂ们å¯以çÂÂå°å¦Âä¸ÂçÂÂé¢
éÂÂé¢é»Â认填è¿ÂÃ¥ÂȍÂÂqueryÃ¥ÂÂæ°åÂÂæ¯ä¸Â对çÂÂï¼ÂéÂÂè¦ÂæÂÂç §ä¸Â表è¿Âè¡Âä¿®æ¹ï¼ÂæÂÂè½è°ÂéÂÂæÂ¥å£
postmané»Â认åÂÂæ°å | æ£确çÂÂÃ¥ÂÂæ°å | Ã¥ÂÂæ°说æ |
---|---|---|
page | parameter[page] | 页ç Âï¼Â第1页传0 |
size | parameter[size] | æ¯Â页æ°é |
sort | parameter[sort] | æÂÂåºÂï¼Âå¤Â个æÂÂåºÂæ¡件ç¨è±æÂÂéÂÂå·æ¼æÂ¥ï¼ÂÃ¥ÂÂ个æÂÂåºÂæ¡件é»Â认åÂÂåºÂï¼Âé¦ÂÃ¥ÂÂ符å¦ÂæÂÂæ¯âÂÂ-âÂÂÃ¥ÂÂéÂÂ庠|
order | parameter[order] | Ã¥ÂÂéÂÂåºÂï¼Âé»Â认åÂÂåºÂï¼Âå¯以ä¸Âä¼ ãÂÂå¦ÂæÂÂä¼ äºÂDESC表示éÂÂåºÂãÂÂä¸Âèλç¨sortÃ¥ÂÂæ°å³å¯ |
fields | parameter[fields] | æÂÂå®Âè¿ÂÃ¥ÂÂåªäºÂÃ¥ÂÂ段ï¼Â注æÂÂè¦Âä¼ æ°æ®åºÂä¸ÂçÂÂÃ¥ÂÂ段åÂÂï¼Âå¤Â个åÂÂ段ç¨è±æÂÂéÂÂå·æ¼æÂÂ¥ |
filters | parameter[filters] | çÂÂéÂÂè¿Â滤æ¡件ï¼Âæ¯æÂÂå¤Âç»´æ°ç»ÂÃ¥ÂÂåµÂå¥ÂçÂÂéÂÂï¼Âä¸ÂæÂÂ详ç»Â说æ |
Ã¥ÂÂ页æ¥询æÂ¥å£çÂÂè°Âç¨æÂÂæÂÂå¦Âä¸Âå¾
为æ¹便è°Âè¯Âï¼Âè¿ÂéÂÂè´´åºæÂÂ¥curlå½令
curl --location --globoff 'http://localhost:6060/users?parameter[page]=0¶meter[size]=10¶meter[sort]=-phone%2Cid¶meter[fields]=id%2Cphone%2Cemail¶meter[filters][0]=email¶meter[filters][1]=like¶meter[filters][2]=com' \
--header 'Accept: application/json'
çÂÂéÂÂè¿Â滤æ¡件éÂÂè¦Âä¼ ä¸Âç»´æÂÂè å¤Âç»´æ°ç»Âï¼Âæ°ç»ÂæÂÂå¤Âå å«ä¸Â个å Âç´ ï¼Â第ä¸Â个æ¯æ°æ®åºÂÃ¥ÂÂ段åÂÂï¼Â第äºÂ个æ¯æÂÂä½Â符ï¼Â第ä¸Â个æ¯æ¡件å¼ï¼Âæ¡件å¼å¯以传æ°ç»ÂãÂÂ
// è¯Âæ³Â:
["column_name", "operator", "values"]
// ä¾ÂÃ¥ÂÂ:
["age", "=", 20]
// ç®ÂÃ¥ÂÂ:
["age", 20]
// çÂÂæÂÂçÂÂSQL:
// WHERE age = 20
åªå å«ä¸Â个å Âç´ çÂÂæ°ç»Â表示é»è¾Âè¿Âç®Â符
// ä¾ÂÃ¥ÂÂ
[["age", "=", 20],["or"],["age", "=", 25]]
// çÂÂæÂÂçÂÂSQL:
// WHERE age = 20 OR age = 25
æ¡件å¼å¯以传æ°ç»Â
["age", "between", [20, 30] ]
// çÂÂæÂÂçÂÂSQL:
// WHERE age BETWEEN 20 AND 30
["age", "not in", [20, 21, 22, 23, 24, 25, 26, 26] ]
// çÂÂæÂÂçÂÂSQL:
// WHERE age NOT IN(20, 21, 22, 23, 24, 25, 26, 26)
æ¯æÂÂåµÂå¥ÂçÂÂéÂÂæ¡件
[
[
["age", ">", 20],
["and"]
["age", "<", 30]
],
["and"],
["name", "like", "john"],
["and"],
["name", "like", "doe"]
]
// çÂÂæÂÂçÂÂSQL:
// WHERE ( (age > 20 AND age < 20) and name like '%john%' and name like '%doe%' )
å¦ÂæÂÂéÂÂè¦Âä¼ null
å¼ï¼Âå¯以传"null"
æÂÂå°ÂÃ¥ÂÂçÂÂnull
// éÂÂçÂÂ
[ "age", "is", NULL ]
[ "age", "is", Null ]
[ "age", "is not", NULL ]
[ "age", "is not", Null ]
// 对çÂÂ
[ "age", "is", "NULL" ]
[ "age", "is", "Null" ]
[ "age", "is", "null" ]
[ "age", "is", null ]
[ "age", null ]
[ "age", "is not", "NULL" ]
[ "age", "is not", "Null" ]
[ "age", "is not", "null" ]
[ "age", "is not", null ]
表堳èÂÂ
æ¤å¤Âè¿ÂéÂÂè¦Â说æÂÂä¸Âä¸Â表åÂ
³èÂÂè¿Âç§ÂæÂÂ
åµãÂÂè¿Â个åÂÂè½æÂÂæ¶è¿Âä¸Âæ¯æÂÂçÂÂæÂÂ表åÂ
³èÂÂç¸åÂ
³çÂÂ代ç Âï¼Âä½ÂæÂÂ们æÂÂä¾ÂäºÂåºäºÂgormçÂÂäºÂå¡æ¯æÂÂï¼Âå¼ÂÃ¥ÂÂèÂÂ
å¯以æÂÂå¨å®Âç°ç¸åÂ
³çÂÂé»è¾Âï¼Âæ¯Âå¦Âå¨ä¸Â个æ°æ®åºÂäºÂå¡éÂÂæÂÂÃ¥Â
¥ç¶åÂÂ表æ°æ®ãÂÂå¨çÂÂæÂÂçÂÂsvcimpl.goæÂÂ件éÂÂçÂÂæÂ¥å£å®Âç°ç»ÂæÂÂä½Âä¸ÂæÂÂä¸Â个clone
æ¹æ³Â
func (receiver XXXImpl) clone(q *query.Query) *TestpgImpl {
receiver.q = q
return &receiver
}
å¯以传åÂ
¥ä¸Â个åºÂå±Âå°Âè£Â
äºÂ*sql.Tx
çÂÂ*query.Query
Ã¥ÂÂæ°åÂ
ÂéÂÂåºä¸Â个æÂ¥å£å®Âç°ç»ÂæÂÂä½Âå®Âä¾Âï¼Âç¨äºÂæ§è¡Âæ°æ®åºÂäºÂå¡æÂÂä½ÂãÂÂ
func (receiver *XXXImpl) TAuthorPosts(ctx context.Context, body dto.SaveAuthorReqDTO) (err error) {
return errors.WithStack(receiver.q.Transaction(func(tx *query.Query) error {
instance := receiver.clone(tx)
_, err1 := instance.PostTAuthor(ctx, body.TAuthor)
if err1 != nil {
return err1
}
_, err1 = instance.PostTPosts(ctx, body.Posts)
if err1 != nil {
return err1
}
return nil
}))
}
å ¶ä»Âä¼ÂÃ¥ÂÂ
è¿Âä¸ÂÃ¥ÂÂè½æ¯åºäºÂgorm/genè¿Â个åºÂÃ¥ÂÂçÂÂäºÂå¼Âï¼ÂÃ¥ÂÂäºÂå ç¹ä¼ÂÃ¥ÂÂï¼Â
- éÂÂ对PostgreSQLï¼Âæ¯æÂÂä¼ åÂ
Â¥
--db_table_prefix
Ã¥ÂÂæ°æÂÂå®Âschema - éÂÂ对PostgreSQLï¼Â解å³äºÂé»Â认å¼带
::character varying
Ã¥ÂÂ符串çÂÂé®颠- æ¯æÂÂä¼ åÂ
Â¥
--db_soft
Ã¥ÂÂæ°èªå®Âä¹Â软å é¤çÂÂæ°æ®åºÂÃ¥ÂÂ段åÂÂ
以ä¸Âå°±æ¯堳äºÂgo-doudouä»Âæ°æ®åºÂä¸Âé®çÂÂæÂÂå ¨å¥ÂæÂÂå¡代ç Âè¿Âä¸ÂÃ¥ÂÂè½çÂÂä»Âç»ÂãÂÂ