- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 Sequelize 5.21.7(在 next.js 应用程序中)尝试在 Image 和 Tag 模型之间建立多对多关系,但是在尝试使用 imageInstance.addTag()
和 imageInstance.getTags()
方法(以及与其他 _Tag[s]()
方法)。
// Tag.ts
import Sequelize, { DataTypes, Model } from 'sequelize';
import sequelize from '../instance';
class Tag extends Model {
id!: string;
title!: string;
}
Tag.init(
{
id: {
type: DataTypes.UUID,
defaultValue: Sequelize.UUIDV4,
primaryKey: true,
},
title: {
type: DataTypes.STRING,
unique: true,
},
},
{
sequelize,
modelName:'tag',
},
);
export default Tag;
// Image.ts
import Sequelize, {
DataTypes,
BelongsToManyAddAssociationMixin,
BelongsToManyCountAssociationsMixin,
BelongsToManyCreateAssociationMixin,
BelongsToManyGetAssociationsMixin,
BelongsToManyHasAssociationMixin,
BelongsToManyRemoveAssociationMixin,
BelongsToManySetAssociationsMixin,
Model,
Association,
} from 'sequelize';
import sequelize from '../instance';
import { Tag } from '../index';
class Image extends Model {
id!: string;
fileName!: string;
title: string;
Tags: Tag[];
public getTags!: BelongsToManyGetAssociationsMixin<Tag>;
public addTag!: BelongsToManyAddAssociationMixin<Tag, number>;
public setTags!: BelongsToManySetAssociationsMixin<Tag, number>;
public hasTag!: BelongsToManyHasAssociationMixin<Tag, number>;
public removeTag!: BelongsToManyRemoveAssociationMixin<Tag, number>;
public countTags!: BelongsToManyCountAssociationsMixin;
public createTag!: BelongsToManyCreateAssociationMixin<Tag>;
public static associations: {
tags: Association<Image, Tag>;
};
}
Image.init(
{
id: {
type: DataTypes.UUID,
defaultValue: Sequelize.UUIDV4,
primaryKey: true,
},
fileName: {
type: DataTypes.STRING,
},
title: {
type: DataTypes.STRING,
},
},
{
sequelize,
modelName: 'image',
},
);
export default Image;
// index.ts
import instance from './instance';
import Image from './models/Image';
import Tag from './models/Tag';
const ImageTags = Image.belongsToMany(Tag, {
through: 'ImageTags',
});
const TagImages = Tag.belongsToMany(Image, {
through: 'ImageTags',
});
instance.sync();
export default instance;
export { Image, ImageTags, Tag, TagImages };
// instance.ts
import { Sequelize } from 'sequelize';
import path from 'path';
import fs from 'fs';
const dbDirectory = path.resolve('data/db');
const storage = path.resolve(dbDirectory, 'gallery.sqlite');
if (!fs.existsSync(dbDirectory)) {
fs.mkdirSync(dbDirectory);
}
if (!fs.existsSync(storage)) {
fs.writeFileSync(storage, '');
}
const sequelize = new Sequelize({
dialect: 'sqlite',
storage,
});
export default sequelize;
import { Image as ImageModel, Tag as TagModel } from 'path/to/db';
async function createImage(file) {
const image = await ImageModel.create<ImageModel>(
{
fileName: file.name,
title: file.name.replace(/\.[a-z]*$/, ''),
},
);
const tag = await TagModel.findOrCreate({ title: 'Untagged' });
image.addTag(tag); // TypeError: image.addTag is not a function
}
async function getImage(id) {
const image = await ImageModel.findByPk(id, { include: [ TagModel ] });
const tags = image.getTags(); // TypeError: image.getTags is not a function
}
as
调用中找到使用
belongsToMany
的其他问题,但我的示例没有。
最佳答案
它按预期工作。例如。tag.ts
:
import { sequelize } from '../../db';
import Sequelize, { Model, DataTypes } from 'sequelize';
class Tag extends Model {
id!: string;
title!: string;
}
Tag.init(
{
id: {
type: DataTypes.UUID,
defaultValue: Sequelize.UUIDV4,
primaryKey: true,
},
title: {
type: DataTypes.STRING,
unique: true,
},
},
{ sequelize, modelName: 'tag' },
);
export default Tag;
image.ts
:
import { sequelize } from '../../db';
import Sequelize, {
Model,
DataTypes,
BelongsToManyGetAssociationsMixin,
BelongsToManyAddAssociationMixin,
BelongsToManySetAssociationsMixin,
BelongsToManyHasAssociationMixin,
BelongsToManyRemoveAssociationMixin,
BelongsToManyCountAssociationsMixin,
BelongsToManyCreateAssociationMixin,
Association,
} from 'sequelize';
import Tag from './tag';
class Image extends Model {
id!: string;
fileName!: string;
title!: string;
Tags!: Tag[];
public getTags!: BelongsToManyGetAssociationsMixin<Tag>;
public addTag!: BelongsToManyAddAssociationMixin<Tag, number>;
public setTags!: BelongsToManySetAssociationsMixin<Tag, number>;
public hasTag!: BelongsToManyHasAssociationMixin<Tag, number>;
public removeTag!: BelongsToManyRemoveAssociationMixin<Tag, number>;
public countTags!: BelongsToManyCountAssociationsMixin;
public createTag!: BelongsToManyCreateAssociationMixin<Tag>;
public static associations: {
tags: Association<Image, Tag>;
};
}
Image.init(
{
id: {
type: DataTypes.UUID,
defaultValue: Sequelize.UUIDV4,
primaryKey: true,
},
fileName: {
type: DataTypes.STRING,
},
title: {
type: DataTypes.STRING,
},
},
{ sequelize, modelName: 'image' },
);
export default Image;
index.ts
:
import Image from './image';
import Tag from './tag';
import { sequelize } from '../../db';
const ImageTags = Image.belongsToMany(Tag, {
through: 'ImageTags',
});
const TagImages = Tag.belongsToMany(Image, {
through: 'ImageTags',
});
export default sequelize;
export { Image, ImageTags, Tag, TagImages };
main.ts
:
import sequelize, { Image as ImageModel, Tag as TagModel } from './';
async function createImage(file) {
const image = await ImageModel.create<ImageModel>({
fileName: file.name,
title: file.name.replace(/\.[a-z]*$/, ''),
});
const [tag, created] = await TagModel.findOrCreate({ where: { title: 'Untagged' } });
await image.addTag(tag);
return image.id;
}
async function getImage(id) {
const image = await ImageModel.findByPk(id, { include: [TagModel] });
return image.getTags();
}
(async function test() {
try {
await sequelize.sync({ force: true });
const file = { name: 'avatar.jpg' };
const imageId = await createImage(file);
const tags = await getImage(imageId);
console.log('tags:', tags);
} catch (error) {
console.log(error);
} finally {
sequelize.close();
}
})();
Executing (default): DROP TABLE IF EXISTS "ImageTags" CASCADE;
Executing (default): DROP TABLE IF EXISTS "tag" CASCADE;
Executing (default): DROP TABLE IF EXISTS "image" CASCADE;
Executing (default): DROP TABLE IF EXISTS "image" CASCADE;
Executing (default): CREATE TABLE IF NOT EXISTS "image" ("id" UUID , "fileName" VARCHAR(255), "title" VARCHAR(255), PRIMARY KEY ("id"));
Executing (default): SELECT i.relname AS name, ix.indisprimary AS primary, ix.indisunique AS unique, ix.indkey AS indkey, array_agg(a.attnum) as column_indexes, array_agg(a.attname) AS column_names, pg_get_indexdef(ix.indexrelid) AS definition FROM pg_class t, pg_class i, pg_index ix, pg_attribute a WHERE t.oid = ix.indrelid AND i.oid = ix.indexrelid AND a.attrelid = t.oid AND t.relkind = 'r' and t.relname = 'image' GROUP BY i.relname, ix.indexrelid, ix.indisprimary, ix.indisunique, ix.indkey ORDER BY i.relname;
Executing (default): DROP TABLE IF EXISTS "tag" CASCADE;
Executing (default): CREATE TABLE IF NOT EXISTS "tag" ("id" UUID , "title" VARCHAR(255) UNIQUE, PRIMARY KEY ("id"));
Executing (default): SELECT i.relname AS name, ix.indisprimary AS primary, ix.indisunique AS unique, ix.indkey AS indkey, array_agg(a.attnum) as column_indexes, array_agg(a.attname) AS column_names, pg_get_indexdef(ix.indexrelid) AS definition FROM pg_class t, pg_class i, pg_index ix, pg_attribute a WHERE t.oid = ix.indrelid AND i.oid = ix.indexrelid AND a.attrelid = t.oid AND t.relkind = 'r' and t.relname = 'tag' GROUP BY i.relname, ix.indexrelid, ix.indisprimary, ix.indisunique, ix.indkey ORDER BY i.relname;
Executing (default): DROP TABLE IF EXISTS "ImageTags" CASCADE;
Executing (default): CREATE TABLE IF NOT EXISTS "ImageTags" ("imageId" UUID REFERENCES "image" ("id") ON DELETE CASCADE ON UPDATE CASCADE, "tagId" UUID REFERENCES "tag" ("id") ON DELETE CASCADE ON UPDATE CASCADE, PRIMARY KEY ("imageId","tagId"));
Executing (default): SELECT i.relname AS name, ix.indisprimary AS primary, ix.indisunique AS unique, ix.indkey AS indkey, array_agg(a.attnum) as column_indexes, array_agg(a.attname) AS column_names, pg_get_indexdef(ix.indexrelid) AS definition FROM pg_class t, pg_class i, pg_index ix, pg_attribute a WHERE t.oid = ix.indrelid AND i.oid = ix.indexrelid AND a.attrelid = t.oid AND t.relkind = 'r' and t.relname = 'ImageTags' GROUP BY i.relname, ix.indexrelid, ix.indisprimary, ix.indisunique, ix.indkey ORDER BY i.relname;
Executing (default): INSERT INTO "image" ("id","fileName","title") VALUES ($1,$2,$3) RETURNING *;
Executing (220d292c-0ca9-4346-a530-ec18f45ec494): START TRANSACTION;
Executing (220d292c-0ca9-4346-a530-ec18f45ec494): SELECT "id", "title" FROM "tag" AS "tag" WHERE "tag"."title" = 'Untagged';
Executing (220d292c-0ca9-4346-a530-ec18f45ec494): CREATE OR REPLACE FUNCTION pg_temp.testfunc(OUT response "tag", OUT sequelize_caught_exception text) RETURNS RECORD AS $func_ce264c0247834fcfabde8a9190c361c9$ BEGIN INSERT INTO "tag" ("id","title") VALUES ('2f081666-958d-4513-b566-3d791817492c','Untagged') RETURNING * INTO response; EXCEPTION WHEN unique_violation THEN GET STACKED DIAGNOSTICS sequelize_caught_exception = PG_EXCEPTION_DETAIL; END $func_ce264c0247834fcfabde8a9190c361c9$ LANGUAGE plpgsql; SELECT (testfunc.response).*, testfunc.sequelize_caught_exception FROM pg_temp.testfunc(); DROP FUNCTION IF EXISTS pg_temp.testfunc();
Executing (220d292c-0ca9-4346-a530-ec18f45ec494): COMMIT;
Executing (default): SELECT "imageId", "tagId" FROM "ImageTags" AS "ImageTags" WHERE "ImageTags"."imageId" = '1519daf9-42e2-4d39-bc84-d0869107bb72' AND "ImageTags"."tagId" IN ('2f081666-958d-4513-b566-3d791817492c');
Executing (default): INSERT INTO "ImageTags" ("imageId","tagId") VALUES ('1519daf9-42e2-4d39-bc84-d0869107bb72','2f081666-958d-4513-b566-3d791817492c') RETURNING *;
Executing (default): SELECT "image"."id", "image"."fileName", "image"."title", "tags"."id" AS "tags.id", "tags"."title" AS "tags.title", "tags->ImageTags"."imageId" AS "tags.ImageTags.imageId", "tags->ImageTags"."tagId" AS "tags.ImageTags.tagId" FROM "image" AS "image" LEFT OUTER JOIN ( "ImageTags" AS "tags->ImageTags" INNER JOIN "tag" AS "tags" ON "tags"."id" = "tags->ImageTags"."tagId") ON "image"."id" = "tags->ImageTags"."imageId" WHERE "image"."id" = '1519daf9-42e2-4d39-bc84-d0869107bb72';
Executing (default): SELECT "tag"."id", "tag"."title", "ImageTags"."imageId" AS "ImageTags.imageId", "ImageTags"."tagId" AS "ImageTags.tagId" FROM "tag" AS "tag" INNER JOIN "ImageTags" AS "ImageTags" ON "tag"."id" = "ImageTags"."tagId" AND "ImageTags"."imageId" = '1519daf9-42e2-4d39-bc84-d0869107bb72';
tags: [ tag {
dataValues:
{ id: '2f081666-958d-4513-b566-3d791817492c',
title: 'Untagged',
ImageTags: [ImageTags] },
_previousDataValues:
{ id: '2f081666-958d-4513-b566-3d791817492c',
title: 'Untagged',
ImageTags: [ImageTags] },
_changed: {},
_modelOptions:
{ timestamps: false,
validate: {},
freezeTableName: true,
underscored: false,
paranoid: false,
rejectOnEmpty: false,
whereCollection: [Object],
schema: null,
schemaDelimiter: '',
defaultScope: {},
scopes: {},
indexes: [],
name: [Object],
omitNull: false,
sequelize: [Sequelize],
hooks: {} },
_options:
{ isNewRecord: false,
_schema: null,
_schemaDelimiter: '',
include: [Array],
includeNames: [Array],
includeMap: [Object],
includeValidated: true,
attributes: [Array],
raw: true },
isNewRecord: false,
ImageTags:
ImageTags {
dataValues: [Object],
_previousDataValues: [Object],
_changed: {},
_modelOptions: [Object],
_options: [Object],
isNewRecord: false } } ]
node-sequelize-examples=# select * from "ImageTags";
imageId | tagId
--------------------------------------+--------------------------------------
1519daf9-42e2-4d39-bc84-d0869107bb72 | 2f081666-958d-4513-b566-3d791817492c
(1 row)
node-sequelize-examples=# select * from tag;
id | title
--------------------------------------+----------
2f081666-958d-4513-b566-3d791817492c | Untagged
(1 row)
node-sequelize-examples=# select * from image;
id | fileName | title
--------------------------------------+------------+--------
1519daf9-42e2-4d39-bc84-d0869107bb72 | avatar.jpg | avatar
(1 row)
关于node.js - Sequelize 5 : TypeError on many-to-many methods,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61625287/
这段代码无法编译: for(vector::iterator it = shapes.end(); it >= shapes.begin(); --it){ *it.update(1,1);
我一直在研究 Common Lisp 对象协议(protocol) (CLOS),我遇到了一个疑问。 有人知道 CLOS 中的“标准方法组合”和“简单方法组合”是什么意思吗? 在“简单方法组合”中,“
在Rust上对值调用方法之间是否有任何区别,如下所示: struct A { e: u32 } impl A { fn show(&self) { println!("{}",
我在一些 StackOverflow 答案中看到了术语抽象方法、具体方法和默认方法的“不同”定义。 Java 语言规范给出的真正定义是什么?请在您的答案中包含相关的支持 JLS 引用资料。 最佳答案
如果method = "post",如何使rest[method]扩展为rest.post(uri, body).then(. .? function proxyUrl() { return
这个问题在这里已经有了答案: Method cannot be translated into a store expression (1 个回答) 关闭 9 年前。 我有一个问题。我在 Visua
它们各自的优缺点是什么? 接口(interface)方法 虚方法 抽象方法 什么时候应该选择什么?做出这一决定时应牢记哪些要点? 最佳答案 虚拟和抽象几乎是一样的。虚方法在基类中有一个可以选择被覆盖的
我在 Meteor.js 上的那段代码出错: 客户端 : Meteor.call("logUser", function(myvar){ console.log("le c
运行代码时出现以下错误 Line: 18 illegal start of expression Line: 18 ';' expected 这意味着第 18 行中有代码写得不正确(public bo
如果可能的话,如何从另一个方法的返回中调用一个方法? 例如…… class Example { public static void main(String[] args) {
当遍历指针的 vector (或其他容器)时,使用以下优势和/或优势之间是否有任何区别: for (it = v.begin(); it != v.end(); ++it) { (*it)->
在从带有参数的 void 方法打印值或将值返回给方法调用者并在方法调用者中打印它之间,哪个被认为是更好的做法(如果有的话)?比如第一个代码摘录是前者,第二个代码摘录是后者: public static
考虑这个例子https://codesandbox.io/s/1yvp4zz5x7?module=%2Fsrc%2FApp.vue Greet1 Greet2
晚上好, 我刚开始使用 Microsoft.Contracts(最新版本)并将其插入示例界面之上,现在它看起来像这样: namespace iRMA2.Core.Interfaces { us
我是 Laravel 4 的新手,并试图弄清楚为什么我收到一个错误,说 Method [show] 不存在。 我没有名为“show”的方法,只能想象这是一个内部的 Laravel 方法,但我不知道如何
有人可以向我解释一下当我们进行下一次返回时“或”(||) 是什么意思吗? 我的意思是这行: 返回封面(值,金额 - 值 [索引],索引 + 1)||覆盖(值、金额、索引 + 1); public st
这个问题已经有答案了: Why doesn't the post increment operator work on a method that returns an int? (11 个回答) 已
我很难理解 jQuery 的 $.method() 和 $(selector).method 之间的区别。 $.method() 实际适用于 DOM 中的哪些元素?如果有人能帮助解释这两种说法之间的区
关闭。这个问题需要details or clarity .它目前不接受答案。 想改进这个问题吗? 通过 editing this post 添加细节并澄清问题. 关闭 5 年前。 Improve t
////////////////////////////////////////////////////////////////////////////// // 3 construct
我是一名优秀的程序员,十分优秀!