使用Node.js连接和操作数据库(node.js访问数据库)

Node.js是一个基于事件驱动、非阻塞式I/O的服务器端JavaScript运行环境。它的出现解决了一些问题,例如服务器连接的实时性,实现了服务器端JavaScript,减少了代码复杂度等等。同时,它也让连接和操作数据库更加容易。在这篇文章中,我们将了解如何使用Node.js连接和操作SQL数据库。

1. 连接数据库

要连接SQL数据库,我们需要使用Node.js模块。在Node.js中最常使用的模块是’ mysql ‘。我们将安装此模块并创建一个连接。

创建一个新的文件夹并初始化npm:

“`

$ mkdir node-mysql

$ cd node-mysql

$ npm init -y

“`

在此之后任意命名文件,例如 ‘ app.js ‘。以下是连接步骤:

“`

/*1. 引入mysql模块*/

const mysql = require(‘mysql’);

/*2. 创建连接*/

const connection = mysql.createConnection({

host: ‘localhost’,

user: ‘root’,

password: ‘password’,

database: ‘database_name’

});

/*3. 开始连接*/

connection.connect((error) => {

if (error) throw error;

console.log(‘Connected to the database successfully!’);

});

/*4. 关闭连接*/

connection.end((error) => {

if (error) throw error;

console.log(‘Database connection closed successfully!’);

});

“`

在这段代码中,我们首先引入了’ mysql ‘模块,然后使用 ‘ createConnection() ‘方法创建一个新的连接实例。它接受一个对象,其中包含要连接的数据库的详细信息,例如主机名称、用户名称、密码和数据库名称。

然后,在我们可以开始进行其他任何数据库操作之前,我们必须先打开连接,这可以使用 ‘ connect() ‘方法完成。在连接成功后,我们简单地在控制台上输出消息。我们可以使用 ‘ end() ‘方法关闭连接并在控制台上输出消息。

2. 验证连接是否成功

连接到数据库之后,我们可以使用查询来验证连接是否成功。让我们将一个简单的查询添加到’ app.js ‘文件中。

“`

/*1. 引入mysql模块*/

const mysql = require(‘mysql’);

/*2. 创建连接*/

const connection = mysql.createConnection({

host: ‘localhost’,

user: ‘root’,

password: ‘password’,

database: ‘database_name’

});

/*3. 查询数据*/

connection.query(‘SELECT * FROM table_name’, (error, result) => {

if (error) throw error;

console.log(result);

});

/*4. 关闭连接*/

connection.end((error) => {

if (error) throw error;

console.log(‘Database connection closed successfully!’);

});

“`

在这段代码中,我们使用 ‘ query() ‘方法执行一个简单的SQL查询,它会从’ table_name ‘中检索所有数据。然后将结果输出到控制台。

3. 插入数据

在此之后,我们将看一个例子,演示如何使用’ INSERT ‘语句向数据库中插入数据。

“`

/*1. 引入mysql模块*/

const mysql = require(‘mysql’);

/*2. 创建连接*/

const connection = mysql.createConnection({

host: ‘localhost’,

user: ‘root’,

password: ‘password’,

database: ‘database_name’

});

/*3. 插入数据*/

const data = {username: ‘test_user’, eml: ‘test@test.com’};

connection.query(‘INSERT INTO users SET ?’, data, (error, result) => {

if (error) throw error;

console.log(‘Data inserted successfully!’);

});

/*4. 关闭连接*/

connection.end((error) => {

if (error) throw error;

console.log(‘Database connection closed successfully!’);

});

“`

在这段代码中,我们使用 ‘ INSERT ‘语句将数据插入到名为 ‘ users ‘的表中。我们还创建了一个包含用户名和电子邮件的对象,并在’ query() ‘方法的第二个参数中将其传递给插入查询。

4. 更新数据

类似于插入数据,我们还可以使用’ UPDATE ‘语句更新表中的数据。以下代码将演示如何使用’ UPDATE ‘语句。

“`

/*1. 引入mysql模块*/

const mysql = require(‘mysql’);

/*2. 创建连接*/

const connection = mysql.createConnection({

host: ‘localhost’,

user: ‘root’,

password: ‘password’,

database: ‘database_name’

});

/*3. 更新数据*/

const data = {eml: ‘test_update@test.com’};

const { eml } = data;

connection.query(‘UPDATE users SET eml = ? WHERE username = ?’, [eml, ‘test_user’], (error, result) => {

if (error) throw error;

console.log(`Data updated successfully! ${result.affectedRows} rows affected`);

});

/*4. 关闭连接*/

connection.end((error) => {

if (error) throw error;

console.log(‘Database connection closed successfully!’);

});

“`

在这段代码中,我们使用’ UPDATE ‘语句将表中 ‘ username ‘为 ‘ test_user ‘的行更新为包含新电子邮件的新行。

5. 删除数据

除了更新和插入数据外,我们还可以使用’ DELETE ‘语句从表中删除数据。

“`

/*1. 引入mysql模块*/

const mysql = require(‘mysql’);

/*2. 创建连接*/

const connection = mysql.createConnection({

host: ‘localhost’,

user: ‘root’,

password: ‘password’,

database: ‘database_name’

});

/*3. 删除数据*/

connection.query(‘DELETE FROM users WHERE username = ?’, ‘test_user’, (error, result) => {

if (error) throw error;

console.log(`Data deleted successfully! ${result.affectedRows} rows affected`);

});

/*4. 关闭连接*/

connection.end((error) => {

if (error) throw error;

console.log(‘Database connection closed successfully!’);

});

“`

在这段代码中,我们使用’ DELETE ‘语句从表中删除 ‘ test_user ‘的行。

结论

Node.js模块可以帮助我们轻松连接和操纵SQL数据库。使用MySQL模块,您可以插入、更新、删除数据和查询数据,并创建复杂的SQL查询语句来满足您的需求。

相关问题拓展阅读:

  • nodejs 连接mysql数据库进行增删改查操作,是进行一次操作就要 connnect 一次数据库 然后关闭吗?

nodejs 连接mysql数据库进行增删改查操作,是进行一次操作就要 connnect 一次数据库 然后关闭吗?

设置为可和敏派以执行多条语句:

var connection = mysql.createConnection({

host : constant.DB_HOST_NAME,

user : constant.DB_USER,

password : constant.DB_PWD,

database : constant.DB_NAME,

multipleStatements: true // 支持拿旁执行多条 sql 语唤贺句

});

原则上就是这样的。因为网络数据库是要注重并发性兆郑的,如果你长时间占用一个连接,那么你这个连接所涉及的族困颂记录就会被长时间锁定,其他所有用户都会无法访问,如果有多个用户尺销同时操作数据库,那网站基本上就瘫痪了。所以原则上都要求数据库的查询要做到随用随关闭。

node.js访问数据库的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于node.js访问数据库,使用Node.js连接和操作数据库,nodejs 连接mysql数据库进行增删改查操作,是进行一次操作就要 connnect 一次数据库 然后关闭吗?的信息别忘了在本站进行查找喔。

香港服务器选创新互联,2H2G首月10元开通。
创新互联(www.cdcxhl.com)互联网服务提供商,拥有超过10年的服务器租用、服务器托管、云服务器、虚拟主机、网站系统开发经验。专业提供云主机、虚拟主机、域名注册、VPS主机、云服务器、香港云服务器、免备案服务器等。

名称栏目:使用Node.js连接和操作数据库(node.js访问数据库)
文章网址:http://www.csdahua.cn/qtweb/news37/372237.html

网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网