短链接跳转到原始链接

892175
2021/11/26 04:39:08

我们继续实现功能,本章要实现的是通过短链接跳转到原始链接的功能。注意,跳转之前,我们需要将它的访问量加一。

handler

数据库

pub async fn goto_url(client: &Client, id: String) -> Result<UrlTarget> {
    let result = super::query_one(
        client,
        "UPDATE url SET visit=visit+1 WHERE id=$1 RETURNING url",
        &[&id],
    )
    .await?;
    Ok(result)
}

为什么不用事务

利益于 PostgreSQL 数据库的强大,我们可以使用单条 SQL 语句就实现既增加访问量,又返回原始链接。如果是其它数据库,则需要使用事务来分步操作:

// 1. 执行 UPDATE url SET visit=visit+1 WHERE id=?
// 2. 判断该 UPDATE 的结果,如果出错回滚事务
// 3. 执行 SELECT url FROM url WHERE id=?
// 4. 提交事务
// 5. 返回 SELECT 的结果