Geben Sie die Ergebnisse der MySQL2-Abfrage stark in Typescript ein
P粉342101652
P粉342101652 2023-12-31 13:46:28
0
1
395

Ich entwickle eine Anwendung mit NextJS und Typescript und versuche herauszufinden, wie MySQL-Antworten am besten korrekt eingegeben werden können. Hier ist der API-Endpunkt:

import { hash } from "bcrypt";
import type { NextApiRequest, NextApiResponse } from "next";
import randomstring from "randomstring";

import { executeQuery } from "../../../lib/db";

const Test = async (req: NextApiRequest, res: NextApiResponse) => {
  // Manage password generation
  const password = randomstring.generate(16);
  const hashedPassword = hash(password, 10);

  // Create new auth using email and password
  const auth = await executeQuery(
    "INSERT INTO auth (email, password) VALUES (?, ?)",
    ["test@test.com", (await hashedPassword).toString()]
  );

  res.statusCode = 200;
  res.json(auth.insertId);
};

export default Test;

Ich möchte dringend insertId über ESLint tippen, um alle Warnungen und Fehler zu entfernen, aber leider waren alle meine Bemühungen erfolglos. Die Fehlermeldung, die ich erhalte, ist:

Property 'insertId' does not exist on type 'RowDataPacket[] | RowDataPacket[][] | OkPacket | OkPacket[] | ResultSetHeader | { error: unknown; }'.
  Property 'insertId' does not exist on type 'RowDataPacket[]'.ts(2339)

Meine executeQuery Funktion ist definiert als:

import mysql from "mysql2/promise";

export const executeQuery = async (query: string, params: unknown[] = []) => {
  try {
    const db = await mysql.createConnection({
      host: process.env.MYSQL_HOST,
      database: process.env.MYSQL_DATABASE,
      user: process.env.MYSQL_USER,
      password: process.env.MYSQL_PASSWORD,
    });

    const [results] = await db.execute(query, params);
    db.end();

    return results;
  } catch (error) {
    return { error };
  }
};

Einer meiner Implementierungsversuche ist diese SO-Antwort, aber ich schaffe es nicht, sie zum Laufen zu bringen...

Jede Hilfe ist uns sehr dankbar!

P粉342101652
P粉342101652

Antworte allen(1)
P粉489081732

我也遇到了和你一样的问题,在查找mysql2类型文件后,我发现你可以传递查询的结果类型。

例如:

connection.query('INSERT INTO posts SET ?', {title: 'test'},
function (error, results, fields) {
  if (error) throw error;
  console.log(results.insertId);
});

对于插入和更新,您可以使用 OkPacket 类型,对于选择,您可以使用 RowDataPacket 类型。您可以通过将 RowDataPacket 实现为查询的预期响应类型并将其传递到查询函数中来进一步键入它。

例如:

export interface Post {
  title: string;
}

export interface PostRow extends RowDataPacket, Post {}

那么在查询的时候就可以这样传递:

connection.query('SELECT * FROM posts WHERE id = 1',
function (error, results, fields) {
  if (error) throw error;
  // ...
});

这是我的 2 美分,希望它对将来的人有所帮助。

Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage