質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.46%
MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Node.js

Node.jsとはGoogleのV8 JavaScriptエンジンを使用しているサーバーサイドのイベント駆動型プログラムです。

TypeScript

TypeScriptは、マイクロソフトによって開発された フリーでオープンソースのプログラミング言語です。 TypeScriptは、JavaScriptの構文の拡張であるので、既存の JavaScriptのコードにわずかな修正を加えれば動作します。

React.js

Reactは、アプリケーションのインターフェースを構築するためのオープンソースJavaScriptライブラリです。

Q&A

0回答

778閲覧

node.jsを使ってSQL実行結果を画面に表示したいです

Mochikoko

総合スコア0

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Node.js

Node.jsとはGoogleのV8 JavaScriptエンジンを使用しているサーバーサイドのイベント駆動型プログラムです。

TypeScript

TypeScriptは、マイクロソフトによって開発された フリーでオープンソースのプログラミング言語です。 TypeScriptは、JavaScriptの構文の拡張であるので、既存の JavaScriptのコードにわずかな修正を加えれば動作します。

React.js

Reactは、アプリケーションのインターフェースを構築するためのオープンソースJavaScriptライブラリです。

0グッド

0クリップ

投稿2021/10/12 09:37

編集2021/10/12 17:50

前提・実現したいこと

SQL実行結果を受け取る方法がわからなくて困っています。

画面でボタンクリックし、SQL実行結果をレスポンスとして受け取りたいです

現状、ボタンクリック→SQL実行をしない関数の呼び出しの仕組みはできています。

発生している問題・エラーメッセージ

Uncaught (in promise) TypeError: Net.createConnection is not a function --------------------- Connection.js:74 Uncaught (in promise) TypeError: Net.createConnection is not a function at Connection.connect (http://localhost:8080/static/js/vendors~main.chunk.js:102522:96) at http://localhost:8080/static/js/vendors~main.chunk.js:112655:16 at connect (http://localhost:8080/static/js/vendors~main.chunk.js:112654:10) at http://localhost:8080/static/js/vendors~main.chunk.js:112576:23 From previous event: at new connection (http://localhost:8080/static/js/vendors~main.chunk.js:112572:71) at Object.push../node_modules/promise-mysql/index.js.exports.createConnection (http://localhost:8080/static/js/vendors~main.chunk.js:112509:10) at connection (http://localhost:8080/static/js/main.chunk.js:338:92) at exec (http://localhost:8080/static/js/main.chunk.js:349:3) at HTMLUnknownElement.callCallback (http://localhost:8080/static/js/vendors~main.chunk.js:122249:18) at Object.invokeGuardedCallbackDev (http://localhost:8080/static/js/vendors~main.chunk.js:122298:20) at invokeGuardedCallback (http://localhost:8080/static/js/vendors~main.chunk.js:122358:35) at invokeGuardedCallbackAndCatchFirstError (http://localhost:8080/static/js/vendors~main.chunk.js:122373:29) at executeDispatch (http://localhost:8080/static/js/vendors~main.chunk.js:126608:7) at processDispatchQueueItemsInOrder (http://localhost:8080/static/js/vendors~main.chunk.js:126640:11) at processDispatchQueue (http://localhost:8080/static/js/vendors~main.chunk.js:126653:9) at dispatchEventsForPlugins (http://localhost:8080/static/js/vendors~main.chunk.js:126664:7) at http://localhost:8080/static/js/vendors~main.chunk.js:126875:16 at batchedEventUpdates$1 (http://localhost:8080/static/js/vendors~main.chunk.js:140560:16) at batchedEventUpdates (http://localhost:8080/static/js/vendors~main.chunk.js:122047:16) at dispatchEventForPluginEventSystem (http://localhost:8080/static/js/vendors~main.chunk.js:126874:7) at attemptToDispatchEvent (http://localhost:8080/static/js/vendors~main.chunk.js:124357:7) at dispatchEvent (http://localhost:8080/static/js/vendors~main.chunk.js:124275:23) at unstable_runWithPriority (http://localhost:8080/static/js/vendors~main.chunk.js:159418:16) at runWithPriority$1 (http://localhost:8080/static/js/vendors~main.chunk.js:129655:14) at discreteUpdates$1 (http://localhost:8080/static/js/vendors~main.chunk.js:140577:18) at discreteUpdates (http://localhost:8080/static/js/vendors~main.chunk.js:122059:16) at dispatchDiscreteEvent (http://localhost:8080/static/js/vendors~main.chunk.js:124241:7)

該当のソースコード

######TestPage.tsx
import React from "react";
import * as mysql from 'promise-mysql';
import Stack from '@mui/material/Stack';
import Button from '@mui/material/Button';
import Box from '@mui/material/Box';
import Typography from '@mui/material/Typography';
import Modal from '@mui/material/Modal';
import TestTemplate from "../pages/templates/TestTemplate";

// SQL実行
const exec = function() {
async function connection() {
const connection = await mysql.createConnection({
host: 'XXXXXXXX',
port: XXXX,
user: 'XXXXXXXX',
password: 'XXXXXXXX',
database: 'XXXXXXXX',
multipleStatements: true
});

return connection;

}

connection().then(connection => {
console.log(connection);
const result = connection.query('SELECT * FROM test_table');
connection.end();

return result;

}).then(function(rows) {
console.log(rows);
});
}

const style = {
position: 'absolute' as 'absolute',
top: '50%',
left: '50%',
transform: 'translate(-50%, -50%)',
width: 400,
bgcolor: 'background.paper',
border: '2px solid #000',
boxShadow: 24,
p: 4,
};

const TestPage: React.FC = () => {
const [open, setOpen] = React.useState(false);
const handleOpen = () => setOpen(true);
const handleClose = () => setOpen(false);

return (
<TestTemplate title="TEST">
<Stack spacing={2} direction="row">
<Button variant="contained">Contained</Button>
<Button onClick={handleOpen}>Open modal</Button>
<Button onClick={exec}>query</Button>
<Modal open={open} onClose={handleClose} aria-labelledby="modal-modal-title" aria-describedby="modal-modal-description" >
<Box sx={style}>
<Typography id="modal-modal-title" variant="h6" component="h2">
Text in a modal
</Typography>
<Typography id="modal-modal-description" sx={{ mt: 2 }}>
Duis mollis, est non commodo luctus, nisi erat porttitor ligula.
</Typography>
</Box>
</Modal>

<Button variant="outlined">Outlined</Button> </Stack> <>内容作成中</> </TestTemplate>

);
};

export default TestPage;
ソースコード

### 試したこと SQL実行処理(const exec = function() {.... だけ抜き出した「Test.js」を作り、 コマンドにて"node Test.js"実行→正常に実行できました。 また、MySqlWorkbench上でもSQLそのものには問題がないことは確認できています。 ### 補足情報(FW/ツールのバージョンなど) node.js@v14.18.0 TypeScript@Version 4.4.3 npm@6.14.15 express@4.17.1 promise-mysql@4.1.4 react@17.0.2 react-dom@17.0.2 調べたところcreateConnectionはWebブラウザで実行すべきでないということはわかりましたが、他の方法を見つけられていない状態です。 https://stackoverflow.com/questions/38005968/error-in-mysql-library-for-node-js

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

hoshi-takanori

2021/10/13 08:31

express サーバー側で MySQL に接続し、データを JSON で返す API を用意して、ブラウザ側からはその API にアクセスする、というのが一般的ですね。
Mochikoko

2021/10/13 13:31

>ブラウザ側からはその API にアクセスする、というのが一般的 ありがとうございます、やり方そのものがあまりよくなかったのですね。 仕様自体を考え直してみます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.46%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問