데이터베이스 MySQL을 위한 node.js의 기본 작업 방법은 무엇입니까?
데이터베이스 MySQL의 기본 작업(추가, 삭제, 수정, 확인)
전체 블로그의 통합 테이블 구조는 다음과 같습니다.
사용자 테이블에는 ID 사용자 이름 비밀번호 상태라는 4개의 필드가 있으며, 4개의 필드는 4개의 열을 나타냅니다. 자동 증가 열, 상태의 기본값은 0, 선택적 값 0, 1
id 자동 증가, 사용자 이름은 zs, ls, wu 비밀번호: 123456 abcdef 123abc 상태는 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 프로젝트 추가, 삭제, 수정 및 체크인
먼저 명령을 실행하여 package.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" //指定要操作哪个数据库 })
모듈이 정상적으로 작동하는지 테스트합니다(실행 실행) 명령 노드 파일 이름 또는 nodemon 파일 이름)
db.query()
함수를 호출하고 실행할 SQL 문을 지정합니다. 실행 결과는 콜백 함수를 통해 가져옵니다
db.query("select 1", function (err, results) { //模块报错返回错误信息 if (err) return console.log(err.message); //运行成功 console.log(results); })
성공한 테스트의 반환 결과는 다음과 같습니다. [ RowDataPacket { ‘1’: 1 } ]
쿼리 테이블의 SQL 코드(테이블 이름 및 구조 참조) 첫 번째 줄)
查询数据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가지 메소드)
//插入数据 //向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,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 문
//在删除数据时,推荐根据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 문을 사용하여 필드를 연결하고 직접 실행했습니다. 결과적으로 서식 있는 텍스트 데이터를 처리할 때 오류가 보고되었습니다. 문자 이스케이프가 필요합니다. ? 자리 표시자를 사용하면 이런 일이 발생하지 않습니다.
위 내용은 데이터베이스 MySQL을 위한 node.js의 기본 작업 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

PHP에서 환경 변수를 설정하는 세 가지 주요 방법이 있습니다. 1. php.ini를 통한 글로벌 구성; 2. 웹 서버 (예 : Apache의 Setenv 또는 nginx의 FastCGI_Param)를 통과했습니다. 3. PHP 스크립트에서 putenv () 함수를 사용하십시오. 그 중에서 Php.ini는 전역적이고 드물게 변화하는 구성에 적합하며 웹 서버 구성은 분리 해야하는 시나리오에 적합하며 Putenv ()는 임시 변수에 적합합니다. 영구 정책에는 구성 파일 (예 : php.ini 또는 웹 서버 구성)이 포함되어 있습니다. 보안 관리 민감한 정보는 하드 코딩을 피해야하며 사용하는 것이 좋습니다.

PHP는 프론트 엔드 입력, 데이터베이스 스토리지 및 외부 AI 서비스를 연결하는 데 책임이있는 지능형 고객 서비스에서 커넥터 및 브레인 센터의 역할을 수행합니다. 2.이를 구현할 때는 멀티 레이어 아키텍처를 구축해야합니다. 프론트 엔드는 사용자 메시지, PHP 백엔드 전처리 및 경로 요청을 수신하고 먼저 로컬 지식 기반과 일치하며 놓치고 OpenAI 또는 DialogFlow와 같은 외부 AI 서비스를 호출하여 지능적인 답장을 얻습니다. 3. 세션 관리는 컨텍스트 연속성을 보장하기 위해 PHP에 의해 MySQL 및 기타 데이터베이스에 기록됩니다. 4. 통합 AI 서비스는 guzzle을 사용하여 HTTP 요청을 보내고 Apikeys를 안전하게 저장하며 오류 처리 및 응답 분석을 잘 수행해야합니다. 5. 데이터베이스 디자인에는 세션, 메시지, 지식 기반 및 사용자 테이블이 포함되어야하며, 인덱스를 합리적으로 빌드하고 보안 및 성능을 보장하며 로봇 메모리를 지원해야합니다.

PHP 컨테이너가 자동 구성을 지원할 수 있도록 핵심은 CI (Continuous Integration) 프로세스를 구성하는 데 있습니다. 1. DockerFile을 사용하여 기본 이미지, 확장 설치, 종속성 관리 및 권한 설정을 포함하여 PHP 환경을 정의합니다. 2. Gitlabci와 같은 CI/CD 도구를 구성하고 .gitlab-ci.yml 파일을 통해 빌드, 테스트 및 배포 단계를 정의하여 자동 구성, 테스트 및 배포를 달성합니다. 3. PHPUNIT와 같은 테스트 프레임 워크를 통합하여 코드 변경 후 테스트가 자동으로 실행되도록합니다. 4. Kubernetes와 같은 자동 배포 전략을 사용하여 배포 .yaml 파일을 통해 배포 구성을 정의합니다. 5. Dockerfile 최적화 및 다단계 구조를 채택하십시오

비디오 컨텐츠 분석을 위해 AI를 결합한 PHP의 핵심 아이디어는 PHP가 백엔드 "접착제"역할을하고, 먼저 클라우드 스토리지에 비디오를 업로드 한 다음, ASYNCHRONOUS 분석을 위해 AI 서비스 (예 : Google CloudVideoAi 등)를 호출하도록하는 것입니다. 2. PHP는 JSON 결과를 구문 분석하고, 사람, 객체, 장면, 음성 및 기타 정보를 추출하여 지능형 태그를 생성하고 데이터베이스에 저장합니다. 3. 장점은 PHP의 성숙한 웹 생태계를 사용하여 기존 PHP 시스템이있는 프로젝트에 효율적으로 구현하는 데 적합한 AI 기능을 신속하게 통합하는 것입니다. 4. 일반적인 문제에는 대규모 파일 처리 (사전 서명 된 URL이있는 클라우드 스토리지로 직접 전송), 비동기 작업 (메시지 대기열 소개), 비용 제어 (주문형 분석, 예산 모니터링) 및 결과 최적화 (라벨 표준화)가 포함됩니다. 5. 스마트 태그는 시각적으로 크게 향상됩니다

독립적 인 PHP 작업 컨테이너 환경 구축은 Docker를 통해 구현할 수 있습니다. 특정 단계는 다음과 같습니다. 1. Docker 및 DockerCompose를 기초로 설치하십시오. 2. DockerFile 및 Crontab 파일을 저장하기위한 독립 디렉토리를 만듭니다. 3. PHPCLI 환경을 정의하고 CRON 및 필요한 확장을 설치하려면 dockerfile을 작성하십시오. 4. 타이밍 작업을 정의하기 위해 Crontab 파일을 작성하십시오. 5. docker-compose.yml 마운트 스크립트 디렉토리를 작성하고 환경 변수를 구성하십시오. 6. 컨테이너를 시작하고 로그를 확인하십시오. 웹 컨테이너에서 타이밍 작업을 수행하는 것과 비교할 때 독립 컨테이너는 자원 격리, 순수한 환경, 강력한 안정성 및 쉬운 확장의 장점이 있습니다. 로깅 및 오류 캡처를 보장합니다

로깅 방법 선택 : 초기 단계에서는 PHP에 내장 Error_Log ()를 사용할 수 있습니다. 프로젝트가 확장되면 독백과 같은 성숙한 라이브러리로 전환하고 여러 처리기 및 로그 레벨을 지원하며 로그에 타임 스탬프, 레벨, 파일 줄 번호 및 오류 세부 정보가 포함되어 있는지 확인하십시오. 2. 디자인 저장 구조 : 소량의 로그를 파일에 저장할 수 있으며 많은 로그가 있으면 많은 분석이 있으면 데이터베이스를 선택하십시오. MySQL/PostgreSQL을 사용하여 구조화 된 데이터에 사용하십시오. Elasticsearch Kibana는 반 구조화/비 구조화에 권장됩니다. 동시에, 그것은 백업 및 정기적 인 청소 전략을 위해 공식화됩니다. 3. 개발 및 분석 인터페이스 : 검색, 필터링, 집계 및 시각화 기능이 있어야합니다. Kibana에 직접 통합되거나 PHP 프레임 워크 차트 라이브러리를 사용하여 단순성과 인터페이스의 용이성에 중점을 둔 자체 개발을 개발할 수 있습니다.

PHP 환경과 생산 사이의 불일치 문제를 해결하기 위해 핵심은 Kubernetes의 컨테이너화 및 오케스트레이션 기능을 사용하여 환경 일관성을 달성하는 것입니다. 특정 단계는 다음과 같습니다. 1. 모든 PHP 버전, 확장, 종속성 및 웹 서버 구성을 포함하여 통합 된 Docker 이미지를 구축하여 동일한 이미지가 개발 및 생산에 사용되도록합니다. 2. Kubernetes의 구성 및 비밀을 사용하여 비 민감하고 민감한 구성을 관리하고 볼륨 마운트 또는 환경 가변 주입을 통해 다양한 환경 구성의 유연한 스위칭을 달성합니다. 3. Unified Kubernetes 배포 정의 파일 (배포 및 서비스 등)을 통한 응용 프로그램 동작 일관성을 보장하고 버전 제어에 포함시킵니다. 4.

1. PHP 전자 상거래 백엔드의 주류 프레임 워크에는 Laravel (빠른 개발, 강력한 생태학), Symfony (엔터프라이즈 수준, 안정적인 구조), YII (우수한 성능, 표준화 된 모듈에 적합); 2. 기술 스택에는 MySQL Redis 캐시, Rabbitmq/Kafka 메시지 대기열, Nginx PHP-FPM 및 프론트 엔드 분리가 장착되어 있어야합니다. 3. 높은 동시성 아키텍처는 계층화되고 모듈화되어야하며 데이터베이스는 분리/분산 데이터베이스를 읽고 쓰고, 캐시 및 CDN으로 가속화되고, 작업의 비동기 처리,로드 밸런싱 및 세션 공유, 점차 마이크로 서비스 및 모니터링 및 경보 시스템을 설정해야합니다. 4. 다중 수익 창출 경로에는 제품 가격 차이 또는 플랫폼 커미션, 사이트 광고, SAAS 구독, 맞춤형 개발 및 플러그인 시장, API 연결이 포함됩니다.
