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

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

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

PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

Node.js

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

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Q&A

解決済

1回答

1623閲覧

Node.js 非同期関数をラッピングして同期関数にしたい

Weapon

総合スコア106

PostgreSQL

PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

Node.js

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

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

0グッド

0クリップ

投稿2021/05/03 07:55

前提・実現したいこと

Node.jsにおいてpgを使いPostgreSQLでサーバーにレコードを投げています。
その関数を同期的にしようとラッピングしたつもりですが同期的に実行できません。
実際に以下のコードでSQLは投げれているのですが
メインプロセスのcreate_record()内で
Sent -> Finish
で呼び出してほしいものの
Finish -> Sent
となってしまいます。

awaitな関数をasyncな関数にラッピングしても
その関数を実行するときは(そのasync-awaitした関数を呼び出す関数自身も)常にawait演算子が付きまとうものなのでしょうか?

何か書き方がまずいのでしょうか?

その他変なところやjsらしからぬ記述がある場合もご指摘ください。

該当のソースコード

js

1'use strict'; 2const pg = require('pg'); 3const config = require('_DATABASE_CONFIG_FILE_');//such as port and address 4const sample_query = require('_SEND_QUERY_FILE_'); 5const pass = require('_PASSWORD_FILE_'); 6 7const database_init = { 8 user: config.USER, 9 host: config.HOST, 10 database: config.DATABASE, 11 password: pass.POSTGRES, 12 port: config.PORT 13}; 14 15/* Execute */ 16create_record(); 17return; 18/* END Execute */ 19 20function create_record() 21{ 22 InsertRecord(sample_query.QUERY); 23 console.log('Finish'); 24} 25 26async function InsertRecord(query_string) 27{ 28 function _InsertRecord() 29 { 30 function _async_InsertRecord(resolve, reject) 31 { 32 const insert_connection = new pg.Client(database_init); 33 insert_connection.connect(); 34 insert_connection.query(query_string, 35 (err, res) => 36 { 37 insert_connection.end(); 38 console.log('Sent'); 39 resolve(); 40 } 41 ); 42 } 43 return new Promise(_async_InsertRecord); 44 } 45 await _InsertRecord(); 46} 47

環境

Windows10 Pro 20H2
VisualStudio 2019 Community
Node.js v12.16.1

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

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

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

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

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

guest

回答1

0

ベストアンサー

awaitな関数をasyncな関数にラッピングしても

その関数を実行するときは(そのasync-awaitした関数を呼び出す関数自身も)常にawait演算子が付きまとうものなのでしょうか?

はい。async関数は、本質的には「Promiseを返す関数」です。返り値をawaitしなければ同期的にPromiseを返すだけになります。

その関数を同期的にしようとラッピングしたつもりですが同期的に実行できません。

JavaScriptの言語枠内では不可能です。

投稿2021/05/03 07:58

maisumakun

総合スコア146018

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問