노드는 MySQL 데이터베이스를 어떻게 운영하나요? 다음 문서에서는 노드 프로젝트에서 MySQL 데이터베이스를 추가, 삭제, 수정 및 쿼리하는 방법을 안내합니다. 도움이 되기를 바랍니다.
mysql을 다운로드하여 설치하고 설치가 성공했는지 확인하세요
net start mysql
- MySQL 시작
- 바탕화면에서 내 컴퓨터를 마우스 오른쪽 버튼으로 클릭하여 컴퓨터 관리에 들어가 mysql이 설치되었는지 확인할 수 있습니다. [관련 튜토리얼 권장 사항: nodejs 비디오 튜토리얼]
navicat 다운로드 및 설치
기능: mysql 데이터베이스 연결 및 운영 기능 제공
Download
www.navicat.com.cn/products# na...
Install
더블클릭하여 다음 단계까지
을 사용하여 애플리케이션을 찾고, 시작을 클릭하세요
연결 테스트에 성공하면 확인 버튼을 클릭하여 공식적으로 mysql에 연결할 수 있습니다.
연결 후 효과는 다음과 같습니다.
데이터베이스 소개
데이터베이스란 무엇입니까
English: database
데이터를 저장하고 관리하는 것이 바로 데이터베이스입니다. database
保存和管理数据的仓库就是数据库。
什么是数据? 文件,图片,视频,订单,用户名,密码等等。
这些数据都需要有专门的地方来保存和管理。
在我们没有学习数据库技术之前,我们使用的数据都是以文件系统(db.json)的方式保存的。我们需要一个专门的软件来管理我们的数据, 这就是数据库。
两大阵营-数据库分类
-
关系型数据库,代表产品:
- MySQL
- Oracle
- Sql server
- DB2
-
非关系型数据库
- redis 键值存储数据库
- HBaise列存储数据库
- mongodb 面向文档数据库
- neo4j 图形数据库
- Elasticsearch 搜索引擎存储
参考:数据库使用排名 db-engines.com/en/ranking
理解关系型数据库
在关系型数据库中,存在三级关系:
- 数据库
- 数据表
- 字段
类比excel:
- 每一列都是一类数据 ---
字段
- 每一行代表一条数据 ---
记录
데이터란 무엇인가요? 파일, 사진, 비디오, 주문, 사용자 이름, 비밀번호 등.
전문 소프트웨어 | 가 필요합니다. 이것이 바로 데이터베이스입니다.|
---|---|
관계형 데이터베이스, 대표제품 : | |
MySQL | Oracle |
DB2 |

🎜관계형 데이터베이스 이해🎜🎜🎜관계형 데이터베이스에는 세 가지 수준의 관계가 있습니다. 🎜🎜🎜Database🎜🎜데이터 테이블🎜🎜필드 🎜🎜 🎜Analogy🎜excel🎜:🎜🎜
🎜🎜🎜각 열은 데이터 유형입니다--- 필드
🎜🎜각 행은 데이터 조각을 나타냅니다--- 레코드
🎜🎜🎜🎜 🎜🎜Database🎜 🎜excel 파일🎜🎜🎜🎜🎜🎜database🎜🎜excel 파일🎜🎜🎜🎜데이터 테이블🎜🎜Excel 파일의 특정 시트🎜🎜🎜🎜테이블 구조: 필드🎜🎜헤더 시트: 열🎜🎜 🎜🎜MySQL简介
MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目前属于 Oracle 旗下产品 。MySQL所使用的 SQL 语言是用于访问数据库的最常用标准化语言。
3p技术:php,asp,jsp
操作数据库-用navicat
新建数据库
在弹出的窗口中填写数据库名即可。
点击确定之后,会在左侧的数据库列中看到上面创建成功的数据库。
新建数据表
点击 "新建表", 然后在开始设置字段
主键: 作用是区别一条数据和其它数据。(它相当于人的身份证号)
设置字段完成之后,点击上图左上角所示的保存按钮,就会进一步弹出对话框,让填写表的名字。
我们填入user
编辑字段
添加数据
一条内容输入完成后,按下tab,会自动进入下一条记录的输入
学习使用SQL语句
结构化查询语言(Structured Query Language)简称SQL,用来操作关系型数据库:
- 是一种数据库查询和程序设计语言,用来存取数据以及查询、更新、和管理关系型数据库。
- .sql是数据库脚本文件的扩展名。
最常用的用于数据操作的sql语句有四类,分别对应对数据的四种操作:
- 增(create)(例如:用户注册)
- 删(delete) (例如:删除订单)
- 改(update) (例如:修改密码)
- 查(select , read) (例如:信息搜索)
在navicat中运行sql - 添加数据
打开sql编辑区
然后:
学习 sql中的insert into 命令
格式:
insert into 表名(字段名1,字段名2,....) values (值1,值2,....)
注意:
字段的顺序要和值的顺序是完全匹配的
-
字段列表可以不与真实数据表中的字段完全相等,
- 可以省略一些不必要的字段
- 顺序与不需要与定义表时的顺序一致
如果是字符串类型的字段,其值要加"",如果是数值类型的字符串,其值不需要加“”
示例:
insert into stu (sex, weight, name) values ('男', 60, '庞凯')
sql-delete语句-删除数据
格式
delete from 表名 where 删除条件复制代码
注意:不指定条件将删除所有数据
示例
-- 删除id为14的同学 delete from stu where id=14 -- 删除的时候,不加条件,将删除stu表中的全部记录 delete from stu
sql-update语句-修改数据
格式
update 表名 set 字段1=值1, 字段2=值2,... where 修改条件
注意:
- 要修改的值使用键值对来表示 - 多个字段用,分隔 - 不指定条件,将修改当前表中全部的记录
示例
-- 修改id为1的同学的年龄为53 update stu set age=53 where id = 1 -- 修改id为1的同学的年龄为35,身高为160 update stu set age=35,height=160 where id = 1 -- 如果修改的时候,不加条件,则会修改全部的数据 update stu set weight = 60
sql-select-语句-数据查询
作用
把数据从数据库查出来
格式
SELECT 字段名1, 字段名2, ..... FROM 表名 WHERE <条件表达式>
示例
# 查询部分字段SELECT id,name,age FROM stu # 查询所有字段SELECT * FROM stu # 带条件的查询SELECT * FROM 表名 WHERE 条件1 and 条件2
where子句
select field1, field2... from 表名 查询表中的所有数据
where 可以使用条件来筛选查询出的结果
-- 查询所有的学生 select * from stu -- 查询所有学生的id,name,height select id,name,height from stu -- 带条件的查询 select * from stu where 条件 -- 查询所有的男同学 select * from stu where sex='男' -- 查询id为2的男同学 select * from stu where id=2 -- 查询年龄大于50的同学 select * from stu where age > 50 -- 查询年龄大于50岁的男同学 select * from stu where age>50 and sex='男' -- 查询年龄在30~60之间的同学,包括30和60 select * from stu where age>=30 and age<=60 select * from stu where age between 30 and 60
node.js操作mysql
通过mysql这个包来操作mysql数据库。
安装包
mysql模块是一个第三方模块,专门用来操作MySQL数据库。
# 安装 npm i mysql
使用步骤
要想用这个包连接数据库,首先要确保在电脑有mysql(phpstudy 还要启动mysql服务)
一共需要4个步骤:
加载 MySQL 模块
创建 MySQL 连接对象
连接 MySQL 服务器
执行SQL语句
var mysql = require('mysql'); var connection = mysql.createConnection({ host : 'localhost', // 你要连接的数据库服务器的地址 port : 3306,// 端口号 user : 'root', // 连接数据库服务器需要的用户名 password : 'root', // 连接数据库服务器需要的密码 database : 'gz61' //你要连接的数据库的名字 }); connection.connect((err) => { // 如果有错误对象,表示连接失败 if (err) return console.log('数据库连接失败') // 没有错误对象提示连接成功 console.log('mysql数据库连接成功') });
参考地址: www.npmjs.com/package/mys…
node操作mysql-查询操作
执行查询类型的SQL语句,查询结果(result)是一个数组,每个单元是对象,对象的属性是数据表的字段名。
// 1. 加载mysql const mysql = require('mysql'); // 2. 创建连接对象 const conn = mysql.createConnection({ // 对象的属性名字不能改变 host: 'localhost', port: 3306, user: 'root', password: 'root', database: 'gz61' }); // 3. 连接到MySQL服务器 connection.connect((err) => { // 如果有错误对象,表示连接失败 if (err) return console.log('数据库连接失败') // 没有错误对象提示连接成功 console.log('mysql数据库连接成功') }); // 4. 执行SQL语句 let sql = 'select id,name,age from stu'; connection.query(sql, (err, result, fields) => { if (err) throw err; // throw err 相当于 return console.log(err); console.log(result); // result就是查询结果 });
node操作mysql-添加操作
执行添加类型的SQL语句,查询结果(result)是一个对象,该对象中有两个属性要关注:
- affectedRows: 受影响行数
- insertID: 查询数据的主键值
// 1. 加载mysql const mysql = require('mysql'); // 2. 创建连接对象 const conn = mysql.createConnection({ // 对象的属性名字不能改变 host: 'localhost', port: 3306, user: 'root', password: 'root', database: 'gz61' }); // 3. 连接到MySQL服务器 connection.connect((err) => { // 如果有错误对象,表示连接失败 if (err) return console.log('数据库连接失败') // 没有错误对象提示连接成功 console.log('mysql数据库连接成功') }); let sql = 'insert into users (name,password) values("小王","snv")' connection.query(sql, (err, result) => { if (result.affectedRows > 0) { console.log('添加成功,新数据的id为:' + result.insertId); } else { console.log('添加失败'); } });
node操作mysql-修改操作
执行修改类型的SQL语句,查询结果(result)是一个对象,该对象中有 affectedRows 属性,表示本次修改操作影响到的行数。
// 1. 加载mysql const mysql = require('mysql'); // 2. 创建连接对象 const conn = mysql.createConnection({ // 对象的属性名字不能改变 host: 'localhost', port: 3306, user: 'root', password: 'root', database: 'gz61' }); // 3. 连接到MySQL服务器 connection.connect((err) => { // 如果有错误对象,表示连接失败 if (err) return console.log('数据库连接失败') // 没有错误对象提示连接成功 console.log('mysql数据库连接成功') }); // 更新 // update stu set 字段=值,字段=值 where id=11 let sql = 'update users set password="123" where name="小王"'; conn.query(sql, (err, result) => { if (err) throw err; if (result.affectedRows > 0) { console.log('修改成功'); } else { console.log('修改失败'); } })
node操作mysql-删除操作
执行删除类型的SQL语句,查询结果(result)是一个对象,该对象中有 affectedRows 属性
// 1. 加载mysql const mysql = require('mysql'); // 2. 创建连接对象 const conn = mysql.createConnection({ // 对象的属性名字不能改变 host: 'localhost', port: 3306, user: 'root', password: 'root', database: 'gz61' }); // 3. 连接到MySQL服务器 connection.connect((err) => { // 如果有错误对象,表示连接失败 if (err) return console.log('数据库连接失败') // 没有错误对象提示连接成功 console.log('mysql数据库连接成功') }); // 删除 let sql = 'delete from stu where id=1'; connection.query(sql,(err, result) => { if (err) throw err; if (result.affectedRows > 0) { console.log('删除成功'); } else { console.log('删除失败'); } });
了解一下软删除
做删除 : delete from 表名 条件
会把数据直接从数据库中删除掉!
思路:
- 不是真的删除,而是设置一个特殊的字段表示当前的状态:正常还是已经删除
# 目标:把id=16的软删除掉 update stu set isDelete=1 where id=16
模块化封装
分析上面几个单独的功能点,它们基本的语法格式是一致的,只是要执行的sql语句不同而已,所以,我们可以对它们进行一个简单的封装。然后再写测试文件对其进行测试。
涉及两个文件:
- sql.js
- sqltest.js
封装模块
模块名:sql.js
// 由于四项(insert,delete,update,select)操作只是sql语句不同 // 1. 加载mysql const mysql = require('mysql'); // 2. 创建连接对象 const conn = mysql.createConnection({ // 对象的属性名字不能改变 host: 'localhost', port: 3306, user: 'root', password: 'root', database: 'gz61' }); // 3. 连接到MySQL服务器 connection.connect((err) => { // 如果有错误对象,表示连接失败 if (err) return console.log('数据库连接失败') // 没有错误对象提示连接成功 console.log('mysql数据库连接成功') }); module.exports = connection
测试
sqltest.js
const conn = require('./sql'); conn.query('select * from users where username="小美1" and userpassword="666"', (err, data) => { console.log(err); console.log(data); if (data.length > 0) { console.log('用户名密码Ok'); } else { console.log('用户名密码error'); } });
更多node相关知识,请访问:nodejs 教程!
위 내용은 노드가 MySQL 데이터베이스를 운영하는 방법(추가, 삭제, 수정, 확인)에 대해 이야기해보겠습니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

각각의 엔진의 구현 원리 및 최적화 전략이 다르기 때문에 JavaScript 엔진은 JavaScript 코드를 구문 분석하고 실행할 때 다른 영향을 미칩니다. 1. 어휘 분석 : 소스 코드를 어휘 단위로 변환합니다. 2. 문법 분석 : 추상 구문 트리를 생성합니다. 3. 최적화 및 컴파일 : JIT 컴파일러를 통해 기계 코드를 생성합니다. 4. 실행 : 기계 코드를 실행하십시오. V8 엔진은 즉각적인 컴파일 및 숨겨진 클래스를 통해 최적화하여 Spidermonkey는 유형 추론 시스템을 사용하여 동일한 코드에서 성능이 다른 성능을 제공합니다.

실제 세계에서 JavaScript의 응용 프로그램에는 서버 측 프로그래밍, 모바일 애플리케이션 개발 및 사물 인터넷 제어가 포함됩니다. 1. 서버 측 프로그래밍은 Node.js를 통해 실현되며 동시 요청 처리에 적합합니다. 2. 모바일 애플리케이션 개발은 재교육을 통해 수행되며 크로스 플랫폼 배포를 지원합니다. 3. Johnny-Five 라이브러리를 통한 IoT 장치 제어에 사용되며 하드웨어 상호 작용에 적합합니다.

일상적인 기술 도구를 사용하여 기능적 다중 테넌트 SaaS 응용 프로그램 (Edtech 앱)을 구축했으며 동일한 작업을 수행 할 수 있습니다. 먼저, 다중 테넌트 SaaS 응용 프로그램은 무엇입니까? 멀티 테넌트 SAAS 응용 프로그램은 노래에서 여러 고객에게 서비스를 제공 할 수 있습니다.

이 기사에서는 Contrim에 의해 확보 된 백엔드와의 프론트 엔드 통합을 보여 주며 Next.js를 사용하여 기능적인 Edtech SaaS 응용 프로그램을 구축합니다. Frontend는 UI 가시성을 제어하기 위해 사용자 권한을 가져오고 API가 역할 기반을 준수하도록합니다.

JavaScript는 현대 웹 개발의 핵심 언어이며 다양성과 유연성에 널리 사용됩니다. 1) 프론트 엔드 개발 : DOM 운영 및 최신 프레임 워크 (예 : React, Vue.js, Angular)를 통해 동적 웹 페이지 및 단일 페이지 응용 프로그램을 구축합니다. 2) 서버 측 개발 : Node.js는 비 차단 I/O 모델을 사용하여 높은 동시성 및 실시간 응용 프로그램을 처리합니다. 3) 모바일 및 데스크탑 애플리케이션 개발 : 크로스 플랫폼 개발은 개발 효율을 향상시키기 위해 반응 및 전자를 통해 실현됩니다.

JavaScript의 최신 트렌드에는 Typescript의 Rise, 현대 프레임 워크 및 라이브러리의 인기 및 WebAssembly의 적용이 포함됩니다. 향후 전망은보다 강력한 유형 시스템, 서버 측 JavaScript 개발, 인공 지능 및 기계 학습의 확장, IoT 및 Edge 컴퓨팅의 잠재력을 포함합니다.

JavaScript는 현대 웹 개발의 초석이며 주요 기능에는 이벤트 중심 프로그래밍, 동적 컨텐츠 생성 및 비동기 프로그래밍이 포함됩니다. 1) 이벤트 중심 프로그래밍을 사용하면 사용자 작업에 따라 웹 페이지가 동적으로 변경 될 수 있습니다. 2) 동적 컨텐츠 생성을 사용하면 조건에 따라 페이지 컨텐츠를 조정할 수 있습니다. 3) 비동기 프로그래밍은 사용자 인터페이스가 차단되지 않도록합니다. JavaScript는 웹 상호 작용, 단일 페이지 응용 프로그램 및 서버 측 개발에 널리 사용되며 사용자 경험 및 크로스 플랫폼 개발의 유연성을 크게 향상시킵니다.

Python은 데이터 과학 및 기계 학습에 더 적합한 반면 JavaScript는 프론트 엔드 및 풀 스택 개발에 더 적합합니다. 1. Python은 간결한 구문 및 풍부한 라이브러리 생태계로 유명하며 데이터 분석 및 웹 개발에 적합합니다. 2. JavaScript는 프론트 엔드 개발의 핵심입니다. Node.js는 서버 측 프로그래밍을 지원하며 풀 스택 개발에 적합합니다.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

VSCode Windows 64비트 다운로드
Microsoft에서 출시한 강력한 무료 IDE 편집기

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경

SublimeText3 영어 버전
권장 사항: Win 버전, 코드 프롬프트 지원!

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기
