1

用户可以将文章添加到我的网站,当有人点击文章时,他们会得到如下链接:

www.example.com/article/cars

“汽车”是文章的标题。

然后我正在使用查询从数据库中读取文章的内容:

SELECT * FROM Article WHERE Title = 'Cars'

但其他用户也可以添加标题为“汽车”的文章。然后就出错了......因为关于“汽车”的第二篇文章也会得到链接:www.example.com/article/cars然后查询将返回2篇文章,而我只想在该页面上显示一篇文章数据。

所以我需要以这样的方式解决这个问题:

SELECT * FROM Article WHERE Title = 'Cars' AND Id = '1';

对于另一个:

SELECT * FROM Article WHERE Title = 'Cars' AND Id = '2';

但我不想有这样的链接来阅读带有标题和 ID 的文章(我希望它隐藏,而不是在 URL 中):

www.example.com/article/cars/1
www.example.com/article/cars/2

你们知道有什么方法可以解决这个问题吗?允许用户添加同名文章,但是当有人点击链接时,从数据库中读取的内容必须是正确的文章,而不是在 URL 中显示文章 ID。

4

4 回答 4

0

您可以制作一个页面来消除结果的歧义。如果您键入 www.url.com/article/car 之类的 url,请在数据库中搜索标题为“car”的文章,并以唯一的 URL 显示两个结果。

于 2013-07-18T19:11:26.693 回答
0

你有一个 user_article 表吗?您只能允许每个用户使用唯一的文章名称

SELECT * FROM Article WHERE Title = 'Cars' AND UserId = '123456789';

我假设当他们点击链接时你会知道是谁的文章

于 2013-07-18T18:35:21.693 回答
0

如果有人访问 /article/cars,您只需向他们展示所有标题为“汽车”的文章列表,然后让他们选择他们想要的文章。

您始终可以通过将唯一约束或非聚集索引添加到表的标题字段来强制用户创建具有唯一名称的文章。

于 2013-07-18T18:36:01.323 回答
0

你们知道有什么方法可以解决这个问题吗?

是的,我想到了一对。首先,在 URL 中包含 ID。我知道,你已经说过你不想要这样的东西,但考虑一下这样的 URL:

www.example.com/article/cars-1
www.example.com/article/cars-2

你可以使用它。但是你必须对路由做一些真正的花哨的工作。

想到的第二个可能是答案,将永久链接存储在数据库中。这将允许您在创建文章时创建永久链接,从而在某种计数器或新颖的想法上大头针,让用户知道他们需要指定自定义永久链接,因为它已经被使用。

现在,您无需拉取文章标题来构建 URL,而是拉取实际的永久链接。

注意:我认为值得注意的事情。由于确切原因,Stack Overflow 实际上将 ID 包含在 URL 中。可读 URL 是为 Google 构建的。例如,这篇文章的链接我的回答是:

http://stackoverflow.com/questions/17731295/two-articles-with-same-title-reading-from-database/17731397#17731397
于 2013-07-18T18:38:16.273 回答