gpt4 book ai didi

mysql - 访问数据库时保持代码模块化

转载 作者:可可西里 更新时间:2023-11-01 08:53:15 25 4
gpt4 key购买 nike

我一直在为一个非常基本的社交网站开发数据库:您所能做的就是注册一个帐户并发送/接受好友请求。服务器是用 Javascript (NodeJS) 编写的

我有一个方法 getUser(username) 访问数据库以获取代表给定用户名的特定用户的 JSON 对象,以及一个列出特定用户的 friend 的方法。从 listFriends(username) 函数中,我想返回用户 对象 的数组,而不仅仅是他们的用户名,理想情况下我想利用我自己的 get() 函数而不是改变 SQL 查询listFriends() 使用

举个例子可能更容易理解。如果我有三个表:

TABLE: UsersName
username (unique) | firstName | lastName |
------------------|-----------|------------|
pjfry | Phillip | Fry |
proff | Professor | Farnsworth |
bender | Bender | Rodriguez |

TABLE: UsersProfile (their profile description)
username (unique) | description |
------------------|------------------------|
pjfry | I went to the future |
proff | I am very old |
bender | Destroy all humans |

TABLE: Friendships (for simplicity assume that if (a,b) is an entry then so is (b,a))
user1 | user2
-----------|---------------
bender | pjfry
pjfry | bender
pjfry | proff
proff | pjfry

还有一个获取用户对象的函数:

//the callback accepts the user object
function get (username, callback) {
db.query(
'select * from (UsersName n, UsersProfile p) where n.username=p.username and n.username=\'' + username + '\'',
function (rows) {
//for simplicity assume that this call always succeeds
//the user object is altered a bit:
callback({
username: rows[0].username,
name: {
first: rows[0].firstName,
last: rows[0].lastName,
full: rows[0].firstName + ' ' + rows[0].lastName
},
profile: {
description: rows[0].description
}
});
}
}

这里是列出给定用户的好友的函数

//callback accepts the array of friends
function listFriends(username, callback) {
db.query(
'select user2 from Friendships where user1=\'' + username + '\'',
function(rows) {
//assume this call always succeeds
callback(rows)
}
)
}

这里的问题是 listFriends() 将只返回用户名 数组而不是用户对象。我如何修改 listFriends() 函数,以便它通过使用 get() 函数返回用户对象?

这可以通过修改 listFriends() 中的 SQL 语句来完成,但使用 get() 方法会更简洁,这样如果用户对象的结构发生变化,它只需要更改一个地方。

最佳答案

尽量保持干燥,像这样的东西应该符合您的要求:

// Disclaimer: I have not run tested this code myself

//the callback accepts the user object
function get(username, callback) {
getFriendsWithConditions('n.username=\'' + username + '\'', function(rows){
// returns only a single object to the input callback
callback(rows[0]);
});
}

//callback accepts the array of friends
function listFriends(username, callback) {
getFriendsWithConditions('n.username in (select user2 from Friendships where user1=\'' + username + '\')', callback);
}

function getFriendsWithConditions(whereCondition, callback) {
db.query(
'select * from (UsersName n, UsersProfile p) where n.username=p.username and (' + whereCondition + ')',
function(rows) {
// Using ECMAScript 5 Array.map
callback(rows.map(rowToUserObject));
}
);
}

function rowToUserObject(row)
{
return {
username: row.username,
name: {
first: row.firstName,
last: row.lastName,
full: row.firstName + ' ' + row.lastName
},
profile: {
description: row.description
}
};
}

写这篇文章时想到的一些事情:

  1. UserName 和 UserProfile 感觉它们应该只是一个表,但据我所知,这是您实际数据库的简化版本,所以我将它们保持原样。

  2. 我使用了 Array.map如 ECMAScript 5 中所定义,它应该在 Node 中可用。

  3. 每个表的 SQL 别名在每个函数中都是硬编码的,这意味着您还需要 a) 设置某种常量或采用约定来使所有别名在所有函数中保持一致(这随着项目的增长,维护起来可能会很痛苦)或 b) 研究使用可以为您做这些事情的 ORM(以及更多!)这将帮助您避免在如何构建查询,让您担心更重要的事情,例如您实际需要的数据。我不是很熟悉 NodeJS 在 ORM 方面的可用功能,但是官方 NodeJS wiki应该是一个好的开始。

关于mysql - 访问数据库时保持代码模块化,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9457446/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com