0

所以我有一个logging在我的数据库中调用的表,其架构为guildid & channel

我需要得到匹配的内容,我跑去channel看看实际发生了什么,它说guildidconsole.log(logs){ channel: '495602952778678274' }

我选择留下完整的代码,这样你就可以清楚地看到我想要完成的事情。

client.on('messageDelete', async (message) => {
  const logs = sql.prepare(`SELECT channel FROM logging WHERE guildid = ${message.guild.id};`).get();
  console.log(logs);
  if (!logs) return;
  const entry = await message.guild.fetchAuditLogs({
    type: 'MESSAGE_DELETE'
  }).then(audit => audit.entries.first());
  let user = "";
  if (entry.extra.channel.id === message.channel.id &&
    (entry.target.id === message.author.id) &&
    (entry.createdTimestamp > (Date.now() - 5000)) &&
    (entry.extra.count >= 1)) {
    user = entry.executor.username;
  } else {
    user = message.author.username;
  }
  client.channels.get(logs).send(`A message was deleted in ${message.channel.name} by ${user}`);
});

我也试过了logs.send...,最后我试过了

const id = sql.prepare(`SELECT channel FROM logging WHERE guildid = ${message.guild.id};`).get();
const logs = client.channels.get(id);
client.channels.get(logs).send('Send a message');
4

1 回答 1

0

If you did console.log(logs) and it gave { channel: '495602952778678274' } then you should do:

const result = sql.prepare(`SELECT channel FROM logging WHERE guildid = ${message.guild.id};`).get();
const logs = client.channels.get(result.channel);
logs.send('Send a message');
于 2019-01-15T18:24:30.890 回答