データベースMySQLのnode.jsの基本的な操作方法は何ですか?
データベース MySQL の基本操作 (追加、削除、変更、クエリ)
ブログ全体の統一されたテーブル構造は次のとおりです:
users テーブルには、id、ユーザー名、パスワード、ステータスの 4 つのフィールドがあります。 4 つのフィールドは 4 つの列を表します。そのうちの id は自動インクリメント列で、ステータスのデフォルト値は 0、オプションの値は 0、1
id 自動インクリメント、ユーザー名はそれぞれ zs、ls、wu パスワードです。 123456 abcdef 123abc status is 0, 1, 1
#查询整张表的所有数据 select * from users #查询指定列的所有数据 select username,password from users #指定某列添加数据 insert into users(username,password) values('萧寂','1234') #指定某列修改数据 update users set username="你好a",password="1234567",status=1 where id=2 #根据id删除行 delete from users where id=4 #查询status为1的所有用户 SELECT *FROM users WHERE status=1 #查询id 大于2的所有用户 SELECT *FROM users WHERE id>2 #查询username不等于admin的所有用户 SELECT *FROM users WHERE username<>'admin' #使用AND来显示所有status为0,并且id 小于3的用户: SELECT * FROM users WHERE status=0 AND id<3 #使用OR来显示所有status为1,或者username为zs的用户 SELECT* FROM users WHERE status=1 OR username='zs' #对users表中的数据,按照status字段进行升序排序 SELECT * FROM users ORDER BY status;(升序排序在status后加上ASC效果等同) select * from users order by status asc #根据id降序排序,降序排序使用desc关键字 select * from users order by id desc #多重排序 对users 表中的数据,先按照status字段进行降序排序,再按照username的字母顺序,进行升序排序 SELECT * FROM users ORDER BY status DESC,username asc #查询id为1的数据返回的总条数 select count(*) from users where id=1 #将列名称从COUNT(*)修改为total SELECT COUNT(*) AS total FROM users WHERE id=1 #给username列添加uname别名,给password列添加upwd别名 select username as uname,password as upwd from users
node.js プロジェクトの追加、削除、変更、チェックイン
最初にコマンドを実行してパッケージを初期化します。 json パッケージ
npm init -y (文件名为英文,不能有空格、特殊字符或中文,否则报错)
mysql モジュールは npm で管理されるサードパーティ モジュールです。 Node.js プロジェクトで MySQL データベースに接続して操作する機能を提供します。
プロジェクトで使用したい場合は、まず次のコマンドを実行して、mysql をプロジェクトの依存関係パッケージとしてインストールする必要があります:
npm install mysql 或者 npm i mysql
上記の操作が完了したら、 MySQL モジュールの構成
MySQL モジュールの構成
mysql モジュールを使用して MySQL データベースを操作する前に、まず mysql モジュールで必要な構成を実行する必要があります。
//导入MySQL模块 const mysql = require("mysql") //建立与MySQL数据库的连接 const db = mysql.createPool({ host: "127.0.0.1", //数据库的IP地址 user: "root", //登录数据库的账号 password: "admin", //登录数据库的密码 database: "xiaoji" //指定要操作哪个数据库 })
モジュールが接続が正常に機能するかどうかをテストします (実行コマンドのノード ファイル名またはノードモン ファイル名を実行します)
## を呼び出します#db.query()
関数で、実行する SQL ステートメントを指定し、コールバック関数を通じて取得します。実行結果
db.query("select 1", function (err, results) { //模块报错返回错误信息 if (err) return console.log(err.message); //运行成功 console.log(results); })ログイン後にコピー
テストが成功した場合の戻り結果は次のとおりです。 : [ RowDataPacket { ‘1’: 1 } ]クエリ テーブルの SQL コード (テーブル名と構造については 1 行目を参照)
查询数据user表中所有的用户数据
const sqlStr = "select * from users"
db.query(sqlStr, function (err, results) {
//查询失败
if (err) return console.log(err.message);
//查询成功
//注意如果执行的是select查询语句,则执行的结果是数组
console.log(results);
})
ログイン後にコピー
追加する SQL ステートメントデータ (2 つの方法)查询数据user表中所有的用户数据 const sqlStr = "select * from users" db.query(sqlStr, function (err, results) { //查询失败 if (err) return console.log(err.message); //查询成功 //注意如果执行的是select查询语句,则执行的结果是数组 console.log(results); })
//插入数据
//向users表中新增数据,其中username为Spider-Man,password为pcc321
//要插入到users表中的数据对象
const user = { username: "Spider-Man", password: "pcc321" }
//待执行的SQL语句,其中的?表示占位符
const sqlStr = "insert into student(student,card) values(?,?)"
//使用数组的形式,依次为?占位符具体的值(result.affectedRows为影响的行数)
db.query(sqlStr, [user.username, user.password], function (err, results) {
if (err) return console.log(err.message);
if (results.affectedRows == 1) {
console.log("插入成功");
}
})
//向表中新增数据时,如果数据对象的每个属性和数据表的字段一一对应,则可以通过如下方式快速插入数据:
//要插入到users表中的数据对象
const user = { username: "Spider2-Man", password: "pcc321" }
//待执行的SQL语句,其中的?表示占位符
const sqlStr = "insert into users set ?"
db.query(sqlStr, user, function (err, results) {
if (err) return console.log(err.message);
if (results.affectedRows == 1) {
console.log("插入成功");
}
})
ログイン後にコピー
データを変更する SQL ステートメント (2 つの方法)//插入数据 //向users表中新增数据,其中username为Spider-Man,password为pcc321 //要插入到users表中的数据对象 const user = { username: "Spider-Man", password: "pcc321" } //待执行的SQL语句,其中的?表示占位符 const sqlStr = "insert into student(student,card) values(?,?)" //使用数组的形式,依次为?占位符具体的值(result.affectedRows为影响的行数) db.query(sqlStr, [user.username, user.password], function (err, results) { if (err) return console.log(err.message); if (results.affectedRows == 1) { console.log("插入成功"); } }) //向表中新增数据时,如果数据对象的每个属性和数据表的字段一一对应,则可以通过如下方式快速插入数据: //要插入到users表中的数据对象 const user = { username: "Spider2-Man", password: "pcc321" } //待执行的SQL语句,其中的?表示占位符 const sqlStr = "insert into users set ?" db.query(sqlStr, user, function (err, results) { if (err) return console.log(err.message); if (results.affectedRows == 1) { console.log("插入成功"); } })
//修改表中的数据
//向users表中更新的数据,其中username为Spider-Man,password为pcc321,id为5
const user = { id: 7, username: "xiao1jiao", password: "111222" }
//待执行的sql语句,其中的?表示占位符
const sqlStr = "update users set username=?,password=? where id=?"
//使用数组的形式,依次为?占位符具体的值(result.affectedRows为影响的行数)
db.query(sqlStr, [user.username, user.password, user.id], function (err, results) {
if (err) return console.log(err.message);
if (results.affectedRows == 1) {
console.log("修改", user.id, "列成功");
}
})
//修改表数据时,如果数据对象的每个属性和数据表的字段一一对应,则可以通过如下方式快速修改表数据
//向users表中更新的数据,其中username为aaaa,password为1111,id为5
const user = { id: 5, username: "aaaa", password: "1111" }
//待执行的sql语句,其中的?表示占位符
const sqlStr = "update users set ? where id=?"
//使用数组的形式,依次为?占位符具体的值(result.affectedRows为影响的行数)
db.query(sqlStr, [user, user.id], function (err, results) {
if (err) return console.log(err.message);
if (results.affectedRows == 1) {
console.log("修改", user.id, "列成功");
}
})
ログイン後にコピー
データの SQL ステートメントを削除//修改表中的数据 //向users表中更新的数据,其中username为Spider-Man,password为pcc321,id为5 const user = { id: 7, username: "xiao1jiao", password: "111222" } //待执行的sql语句,其中的?表示占位符 const sqlStr = "update users set username=?,password=? where id=?" //使用数组的形式,依次为?占位符具体的值(result.affectedRows为影响的行数) db.query(sqlStr, [user.username, user.password, user.id], function (err, results) { if (err) return console.log(err.message); if (results.affectedRows == 1) { console.log("修改", user.id, "列成功"); } }) //修改表数据时,如果数据对象的每个属性和数据表的字段一一对应,则可以通过如下方式快速修改表数据 //向users表中更新的数据,其中username为aaaa,password为1111,id为5 const user = { id: 5, username: "aaaa", password: "1111" } //待执行的sql语句,其中的?表示占位符 const sqlStr = "update users set ? where id=?" //使用数组的形式,依次为?占位符具体的值(result.affectedRows为影响的行数) db.query(sqlStr, [user, user.id], function (err, results) { if (err) return console.log(err.message); if (results.affectedRows == 1) { console.log("修改", user.id, "列成功"); } })
//在删除数据时,推荐根据id这样的唯一标识,来删除对应的数据。示例如下:
const sqlStr = "delete from users where id=?"
//调用db.query(O)执行SQL语句的同时,为占位符指定具体的值
//注意:如果SQL语句中有多个占位符,则必须使用数组为每个占位符指定具体的值
//如果SQL语句中只有一个占位符,则可以省略数组
db.query(sqlStr, 5, function (err, results) {
if (err) return console.log(err.message);
//注意:执行 delete语句之后,结果也是一个对象,也会包含 affectedRows属性
if (results.affectedRows == 1) {
console.log("删除成功");
}
})
ログイン後にコピー
削除状況をマークする//在删除数据时,推荐根据id这样的唯一标识,来删除对应的数据。示例如下: const sqlStr = "delete from users where id=?" //调用db.query(O)执行SQL语句的同时,为占位符指定具体的值 //注意:如果SQL语句中有多个占位符,则必须使用数组为每个占位符指定具体的值 //如果SQL语句中只有一个占位符,则可以省略数组 db.query(sqlStr, 5, function (err, results) { if (err) return console.log(err.message); //注意:执行 delete语句之后,结果也是一个对象,也会包含 affectedRows属性 if (results.affectedRows == 1) { console.log("删除成功"); } })
//标记删除
//使用DELETE语句,会把真正的把数据从表中删除掉。为了保险起见,推荐使用标记删除的形式,来模拟删除的动作。
//所谓的标记删除,就是在表中设置类似于status这样的状态字段,来标记当前这条数据是否被删除。
//当用户执行了删除的动作时,我们并没有执行DELETE语句把数据删除掉,而是执行了UPDATE语句,将这条数据对应的status字段标记为删除即可。
//标记删除:使用 UPDATE语句替代 DELETE语句;只更新数据的状态,并没有真正删除
const sqlStr = "update users set status=? where id=?"
db.query(sqlStr, [0, 7], function (err, results) {
if (err) return console.log(err.message);
if (results.affectedRows == 1) {
console.log("标记删除成功");
}
})
ログイン後にコピー注: 記事で言及されているプレースホルダー マーキング方法は互換性が高く、作成者はテストを実行し、ネイティブ SQL を使用しました ステートメントがフィールドに結合された後、db.query ステートメントを使用して直接実行されます。その結果、エラーが発生しますリッチ テキスト データを処理するときに報告され、文字エスケープが必要です。 ? プレースホルダーを使用する場合、これは発生しません。
//标记删除 //使用DELETE语句,会把真正的把数据从表中删除掉。为了保险起见,推荐使用标记删除的形式,来模拟删除的动作。 //所谓的标记删除,就是在表中设置类似于status这样的状态字段,来标记当前这条数据是否被删除。 //当用户执行了删除的动作时,我们并没有执行DELETE语句把数据删除掉,而是执行了UPDATE语句,将这条数据对应的status字段标记为删除即可。 //标记删除:使用 UPDATE语句替代 DELETE语句;只更新数据的状态,并没有真正删除 const sqlStr = "update users set status=? where id=?" db.query(sqlStr, [0, 7], function (err, results) { if (err) return console.log(err.message); if (results.affectedRows == 1) { console.log("标记删除成功"); } })
以上がデータベースMySQLのnode.jsの基本的な操作方法は何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









MySQLデータベースでは、ユーザーとデータベースの関係は、アクセス許可と表によって定義されます。ユーザーには、データベースにアクセスするためのユーザー名とパスワードがあります。許可は助成金コマンドを通じて付与され、テーブルはCreate Tableコマンドによって作成されます。ユーザーとデータベースの関係を確立するには、データベースを作成し、ユーザーを作成してから許可を付与する必要があります。

MySQLがテーブル構造を変更すると、メタデータロックが通常使用され、テーブルがロックされる可能性があります。ロックの影響を減らすために、次の測定値をとることができます。1。オンラインDDLでテーブルを使用できます。 2。バッチで複雑な変更を実行します。 3.小規模またはオフピーク期間中に操作します。 4. PT-OSCツールを使用して、より細かい制御を実現します。

MySQLには、無料のコミュニティバージョンと有料エンタープライズバージョンがあります。コミュニティバージョンは無料で使用および変更できますが、サポートは制限されており、安定性要件が低く、技術的な能力が強いアプリケーションに適しています。 Enterprise Editionは、安定した信頼性の高い高性能データベースを必要とするアプリケーションに対する包括的な商業サポートを提供し、サポートの支払いを喜んでいます。バージョンを選択する際に考慮される要因には、アプリケーションの重要性、予算編成、技術スキルが含まれます。完璧なオプションはなく、最も適切なオプションのみであり、特定の状況に応じて慎重に選択する必要があります。

MySQLデータベースパフォーマンス最適化ガイドリソース集約型アプリケーションでは、MySQLデータベースが重要な役割を果たし、大規模なトランザクションの管理を担当しています。ただし、アプリケーションのスケールが拡大すると、データベースパフォーマンスのボトルネックが制約になることがよくあります。この記事では、一連の効果的なMySQLパフォーマンス最適化戦略を検討して、アプリケーションが高負荷の下で効率的で応答性の高いままであることを保証します。実際のケースを組み合わせて、インデックス作成、クエリ最適化、データベース設計、キャッシュなどの詳細な主要なテクノロジーを説明します。 1.データベースアーキテクチャの設計と最適化されたデータベースアーキテクチャは、MySQLパフォーマンスの最適化の基礎です。いくつかのコア原則は次のとおりです。適切なデータ型を選択し、ニーズを満たす最小のデータ型を選択すると、ストレージスペースを節約するだけでなく、データ処理速度を向上させることもできます。

1.正しいインデックスを使用して、データの量を削減してデータ検索をスピードアップしました。テーブルの列を複数回検索する場合は、その列のインデックスを作成します。あなたまたはあなたのアプリが基準に従って複数の列からのデータが必要な場合、複合インデックス2を作成します2。選択した列のみを避けます。必要な列のすべてを選択すると、より多くのサーバーメモリを使用する場合にのみサーバーが遅くなり、たとえばテーブルにはcreated_atやupdated_atやupdated_atなどの列が含まれます。

データ統合の簡素化:AmazonrdsmysqlとRedshiftのゼロETL統合効率的なデータ統合は、データ駆動型組織の中心にあります。従来のETL(抽出、変換、負荷)プロセスは、特にデータベース(AmazonrdsmysQlなど)をデータウェアハウス(Redshiftなど)と統合する場合、複雑で時間がかかります。ただし、AWSは、この状況を完全に変えたゼロETL統合ソリューションを提供し、RDSMYSQLからRedshiftへのデータ移行のための簡略化されたほぼリアルタイムソリューションを提供します。この記事では、RDSMysQl Zero ETLのRedshiftとの統合に飛び込み、それがどのように機能するか、それがデータエンジニアと開発者にもたらす利点を説明します。

MySQLのユーザー名とパスワードを入力するには:1。ユーザー名とパスワードを決定します。 2。データベースに接続します。 3.ユーザー名とパスワードを使用して、クエリとコマンドを実行します。

MySQLは、インストールが簡単で、強力で管理しやすいため、初心者に適しています。 1.さまざまなオペレーティングシステムに適した、単純なインストールと構成。 2。データベースとテーブルの作成、挿入、クエリ、更新、削除などの基本操作をサポートします。 3.参加オペレーションやサブクエリなどの高度な機能を提供します。 4.インデックス、クエリの最適化、テーブルパーティション化により、パフォーマンスを改善できます。 5。データのセキュリティと一貫性を確保するために、バックアップ、リカバリ、セキュリティ対策をサポートします。
