Linux에서 Mysql 데이터베이스의 C++ 작업을 구현하는 방법에 대한 자세한 소개
일 때문에 일주일 동안 다양한 데이터베이스에 액세스하는 C/C++ 방법을 공부하고 데이터베이스 작업 클래스 집합을 캡슐화할 계획입니다. 이제 가장 간단한 부분인 MySQL 데이터베이스에 액세스하는 방법을 소개하겠습니다. 리눅스 .
C++로 프로젝트를 작성하려면 데이터베이스가 필수이기 때문에 지난 이틀 동안 C++로 MySQL 데이터베이스를 조작하는 방법을 배웠습니다. 튜토리얼은 없고, 제가 온라인에서 검색한 지식만 요약해 놓았습니다.MySQL을 사용하여 자체 C APIfunction입니다. 데이터베이스에 연결하려면. 저는 Linux 플랫폼에서 개발하기 때문에 두 번째 방법을 사용합니다. API 함수는 많지만 일반적으로 사용되는 함수는 몇 가지 뿐이고 그 중 몇 가지만 사용합니다.
API 함수1.mysql_real_connect()mysql 서버 연결MYSQL *mysql_real_connect (MYSQL *mysql, const char *host, const char *user, const char *passwd, const char *db, unsigned int port, const char *unix_socket, unsigned long client_flag)
NULL을 반환합니다. 성공적인 연결의 경우 반환 값은 첫 번째 매개 변수
2.mysql_query()
"NULL로 끝나는string"을 지정하는 SQLquery
을 실행하고 결과 테이블을 반환합니다. 쿼리가 성공했다고 가정하면 mysql_num_rows()를 호출하여 SELECT 문에 따라 반환된 행 수를 확인하거나 mysql_affected_rows()를 호출하여 에 해당하는 영향을 받은 행 수를 확인할 수 있습니다. DELETE, INSERT, REPLACE 또는 UPDATE 문.
3.mysql_store_result()
MYSQL_RES *mysql_store_result(MYSQL *mysql)
클라이언트에 설정된 전체 결과를 검색합니다. 클라이언트가 결과 세트를 처리하는 가장 일반적인 방법은 전체 결과 세트를 한 번에 검색하는 mysql_store_result()를 호출하는 것입니다. 이 함수는 서버에서 쿼리에 의해 반환된 모든 행을 가져와 클라이언트에 저장합니다. 데이터를 성공적으로 검색하는 모든 쿼리(SELECT, SHOW, DESCRIBE, EXPLAIN, CHECK TABLE 등)에 대해 mysql_store_result() 또는 mysql_use_result()를 호출해야 합니다. 다른 쿼리의 경우에는 mysql_store_result()나 mysql_use_result()를 호출할 필요가 없지만, 어떠한 경우에도 mysql_store_result()를 호출하면 아무런 해를 끼치거나 성능 저하가 발생하지 않습니다.
4.mysql_num_rows()
결과 집합의 행 수를 반환합니다.
5.mysql_num_fields()
결과 세트의 필드 수를 반환하거나, 실패하면 false를 반환합니다.
MYSQL_FIELD* mysql_fetch_field(MYSQL_RES *result)
다음 테이블 필드의 유형을 가져오고 마지막에 NULL을 반환합니다.
7.mysql_fetch_row()
MYSQL_ROW mysql_fetch_row(MYSQL_RES *result);
결과 집합에서 다음 행을 가져오고 0보다 큰 값을 가진 array를 성공적으로 반환합니다.
8.mysql_fetch_field_direct()
MYSQL_FIELD* mysql_fetch_field_direct(MYSQL_RES *result, int i);
필드 번호가 주어지면 테이블 필드의 유형을 반환하고 마지막에 NULL을 반환합니다.
간단한 학생 정보 관리 코드
만 보면 기억이 안나서 이 기능을 이용해 학생 정보 관리 인터페이스를 작성했는데, 아아, 작년 이맘때쯤이면 C 언어 강좌 디자인을 하게 됐는데요. 그때는 데이터베이스 사용법을 몰랐어요. 다 문서에 적혀 있었거든요. 뒤늦게 후회했어요. . . . 다음은 코드입니다.
/************************************************************************* > File Name: student.cpp > Author: Tanswer_ > Mail: 98duxm@gmail.com > Created Time: 2017年05月28日 星期日 16时50分34秒 ************************************************************************/ #include <iostream> #include <string> #include <stack> #include <algorithm> #include <sstream> #include <mysql/mysql.h> #include <unistd.h> using namespace std; MYSQL mysql; MYSQL_ROW row; MYSQL_FIELD* field = NULL; MYSQL_RES* result; string IntToStr(int num) { stringstream ss; ss.clear(); ss << num; return ss.str(); } void Add() { string fname,fsex,ftel,faddr; int fage; char choice; do { ┊ cout << "请依次输入以下信息:" << endl; ┊ cout << "\nName: ";cin >> fname; ┊ cout << "\nSex: ";cin >> fsex; ┊ cout << "\nAge: "; cin >> fage; ┊ cout << "\nTel: "; cin >> ftel; ┊ cout << "\nAddr: "; cin >> faddr; ┊ string sql = "INSERT INTO Infor (name,sex,tel,addr,age) values('"+fname+"','"+fsex+"','"+ftel+"','"+faddr+"', "+IntToStr(fage)+");"; ┊ //string sql = "INSERT INTO Infor (name,sex,age,tel,addr) values('小红','女',18,'13333333333', '陕西省西安市雁塔区');"; ┊ mysql_query(&mysql,sql.c_str()); ┊ ┊ ┊ cout << "是否继续添加(y/n)?: "; ┊ cin >> choice; }while(choice == 'y'); } void Select() { int id; cout << "请输入要查询学生的学号: "; cin >> id; string sql = "SELECT * FROM Infor WHERE id = "+IntToStr(id)+";"; mysql_query(&mysql,sql.c_str()); result = mysql_store_result(&mysql); if(result == NULL) ┊ cout << "fail\n"; for(int i=0; i<mysql_num_fields(result); i++) { ┊ field = mysql_fetch_field_direct(result,i); ┊ cout << field->name << "\t\t"; } cout << endl; row = mysql_fetch_row(result); while(row != NULL) { ┊ for(int i=0; i<mysql_num_fields(result); i++) ┊ { ┊ ┊ cout << row[i] << "\t\t"; ┊ } ┊ cout << endl; ┊ row = mysql_fetch_row(result); } } void Update() { int id; char choice; string newaddr; ┊ cout << "请输入要修改同学的学号: "; ┊ cin >> id; ┊ cout << endl << "请输入修改后的地址: "; ┊ cin >> newaddr; ┊ string sql = "UPDATE Infor SET addr = '"+newaddr+"'WHERE id= "+IntToStr(id)+"; "; ┊ mysql_query(&mysql,sql.c_str()); ┊ } int main() { char choice[5]; mysql_init(&mysql); /*连接数据库*/ if(!mysql_real_connect(&mysql,"localhost","root","dxm242012","Student",0,NULL,0)) { ┊ cout << "connect fial\n"; ┊ return -1; } while(atoi(choice) != 'q') { ┊ sleep(4); ┊ system("clear"); ┊ cout << "1.添加学生信息" << endl; ┊ cout << "2.查询学生信息" << endl; ┊ cout << "3.修改学生信息" << endl; ┊ cin >> choice; ┊ cout << choice << endl; ┊ switch(atoi(choice)) ┊ { ┊ ┊ case 1: ┊ ┊ ┊ Add(); ┊ ┊ ┊ break; ┊ ┊ case 2: ┊ ┊ ┊ Select(); ┊ ┊ ┊ break; ┊ ┊ case 3: ┊ ┊ ┊ Update(); ┊ ┊ ┊ break; ┊ ┊ default: ┊ ┊ ┊ break; ┊ } } mysql_close(&mysql); return 0; }
MyDB 클래스의 C++ 캡슐화
나중에 이러한 함수는 나중에 쉽게 사용할 수 있도록 간단히 캡슐화되었습니다.
/************************************************************************* > File Name: myDB.h > Author: Tanswer_ > Mail: 98duxm@gmail.com > Created Time: 2017年05月28日 星期日 22时26分22秒 ************************************************************************/ #ifndef _MYDB_H #define _MYDB_H #include <string> #include <iostream> #include <mysql/mysql.h> using namespace std; class MyDB { public: MyDB(); ~MyDB(); bool InitDB(string host,string user,string pwd,string dbname); bool ExeSQL(string sql); private: MYSQL* mysql; MYSQL* mysql; MYSQL_ROW row; MYSQL_RES* result; MYSQL_FIELD* field; }; #endif /************************************************************************* > File Name: myDB.cpp > Author: Tanswer_ > Mail: 98duxm@gmail.com > Created Time: 2017年05月28日 星期日 22时27分18秒 ************************************************************************/ #include <iostream> #include <string> #include <stack> #include <algorithm> #include <mysql/mysql.h> #include "myDB.h" using namespace std; MyDB::MyDB() { mysql = mysql_init(NULL); if(mysql == NULL) { ┊ cout << "Error: " << mysql_error(mysql); ┊ exit(-1); } } MyDB::~MyDB() { if(!mysql) { ┊ mysql_close(mysql); } } bool MyDB::InitDB(string host,string user,string pwd,string dbname) { /*连接数据库*/ if(!mysql_real_connect(mysql,host.c_str(),user.c_str(),pwd.c_str(),dbname.c_str(),0,NULL,0)) { ┊ cout << "connect fial: " << mysql_error(mysql); ┊ exit(-1); } return true; } bool MyDB::ExeSQL(string sql) { /*执行失败*/ if(mysql_query(mysql,sql.c_str())) { ┊ cout << "query fail: " << mysql_error(mysql); ┊ exit(1); } else { ┊ /*获取结果集*/ ┊ result = mysql_store_result(mysql); ┊ int fieldnum = mysql_num_fields(result); ┊ for(int i=0; i<fieldnum; i++) ┊ { ┊ ┊ row = mysql_fetch_row(result); ┊ ┊ if(row <= 0) ┊ ┊ ┊ break; ┊ ┊ for(int j=0; j<fieldnum; j++) ┊ ┊ { ┊ ┊ ┊ cout << row[j] << "\t\t"; ┊ ┊ } ┊ ┊ cout << endl; ┊ } ┊ mysql_free_result(result); } return true; } /************************************************************************* > File Name: main.cpp > Author: Tanswer_ > Mail: 98duxm@gmail.com > Created Time: 2017年05月28日 星期日 22时53分43秒 ************************************************************************/ #include <iostream> #include <string> #include <stack> #include <algorithm> #include <mysql/mysql.h> #include "myDB.h" using namespace std; int main() { MyDB db; db.InitDB("localhost","root","xxxxxx","Student"); db.ExeSQL("SELECT * FROM Infor;"); return 0; }
실행 결과는 다음과 같습니다.
다음은 발생한 문제입니다.
1. 컴파일하는 동안 오류가 발생했습니다.
해당 파일이나 디렉터리가 없습니다.
#include<mysql/mysql.h> ^
컴파일이 중단되었습니다.
해결책: mysql-client 및 mysql-server 외에도 installmysql-devel을 설치하면 문제가 해결됩니다.
2. 사용자 정의 변수가 SQL 문에 전달되면 문제가 발생합니다
在网上查找到这样一种格式,
string sql = "INSERT INTO Infor (name,sex,tel,addr,age) values('"+fname+"','"+fsex+"','"+ftel+"','"+faddr+"', "+IntToStr(fage)+");";
然后string类型的可以成功,整型的变量还是不行,我又写了个函数把int转为string。
string IntToStr(int num) { stringstream ss; ss.clear(); ss << num; return ss.str(); }
위 내용은 Linux에서 Mysql 데이터베이스의 C++ 작업을 구현하는 방법에 대한 자세한 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

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

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

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

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

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

뜨거운 주제











다음 단계를 통해 phpmyadmin을 열 수 있습니다. 1. 웹 사이트 제어판에 로그인; 2. phpmyadmin 아이콘을 찾고 클릭하십시오. 3. MySQL 자격 증명을 입력하십시오. 4. "로그인"을 클릭하십시오.

C 지속적인 사용 이유에는 고성능, 광범위한 응용 및 진화 특성이 포함됩니다. 1) 고효율 성능 : C는 메모리 및 하드웨어를 직접 조작하여 시스템 프로그래밍 및 고성능 컴퓨팅에서 훌륭하게 수행합니다. 2) 널리 사용 : 게임 개발, 임베디드 시스템 등의 분야에서의 빛나기.

phpmyadmin을 사용하여 MySQL에 연결하는 방법? phpmyadmin에 액세스하기위한 URL은 일반적으로 http : // localhost/phpmyadmin 또는 http : // [서버 IP 주소]/phpmyadmin입니다. MySQL 사용자 이름 및 비밀번호를 입력하십시오. 연결하려는 데이터베이스를 선택하십시오. "연결"버튼을 클릭하여 연결을 설정하십시오.

Redis 서버를 시작하는 단계에는 다음이 포함됩니다. 운영 체제에 따라 Redis 설치. Redis-Server (Linux/MacOS) 또는 Redis-Server.exe (Windows)를 통해 Redis 서비스를 시작하십시오. Redis-Cli Ping (Linux/MacOS) 또는 Redis-Cli.exe Ping (Windows) 명령을 사용하여 서비스 상태를 확인하십시오. Redis-Cli, Python 또는 Node.js와 같은 Redis 클라이언트를 사용하여 서버에 액세스하십시오.

Phpmyadmin은 단순한 데이터베이스 관리 도구 일뿐 만 아니라 MySQL에 대한 깊은 이해를 제공하고 프로그래밍 기술을 향상시킬 수 있습니다. 핵심 기능에는 CRUD 및 SQL 쿼리 실행이 포함되며 SQL 문의 원칙을 이해하는 것이 중요합니다. 고급 팁에는 데이터 내보내기/가져 오기 및 권한 관리가 포함되며, 심층적 인 보안 이해가 필요합니다. 잠재적 인 문제에는 SQL 주입이 포함되며 솔루션은 매개 변수화 쿼리 및 백업입니다. 성능 최적화에는 SQL 명령문 최적화 및 인덱스 사용이 포함됩니다. 모범 사례는 코드 사양, 보안 관행 및 정기 백업을 강조합니다.

Phpmyadmin 보안 방어 전략의 핵심은 다음과 같습니다. 1. Phpmyadmin의 최신 버전을 사용하고 정기적으로 PHP 및 MySQL을 업데이트합니다. 2. 액세스 권한을 엄격하게 제어하고, .htaccess 또는 웹 서버 액세스 제어 사용; 3. 강력한 비밀번호와 2 단계 인증을 활성화합니다. 4. 데이터베이스를 정기적으로 백업하십시오. 5. 민감한 정보를 노출하지 않도록 구성 파일을주의 깊게 확인하십시오. 6. WAF (Web Application Firewall) 사용; 7. 보안 감사를 수행하십시오. 이러한 조치는 부적절한 구성, 이전 버전 또는 환경 보안 위험으로 인해 PhpmyAdmin으로 인한 보안 위험을 효과적으로 줄이고 데이터베이스의 보안을 보장 할 수 있습니다.

Redis는 단일 스레드 아키텍처를 사용하여 고성능, 단순성 및 일관성을 제공합니다. 동시성을 향상시키기 위해 I/O 멀티플렉싱, 이벤트 루프, 비 블로킹 I/O 및 공유 메모리를 사용하지만 동시성 제한 제한, 단일 고장 지점 및 쓰기 집약적 인 워크로드에 부적합한 제한이 있습니다.

Linux 시스템의 5 개의 기둥은 다음과 같습니다. 1. Kernel, 2. System Library, 3. Shell, 4. 파일 시스템, 5. 시스템 도구. 커널은 하드웨어 리소스를 관리하고 기본 서비스를 제공합니다. 시스템 라이브러리는 애플리케이션에 대한 사전 컴파일 된 기능을 제공합니다. 쉘은 사용자가 시스템과 상호 작용할 수있는 인터페이스입니다. 파일 시스템은 데이터를 구성하고 저장합니다. 시스템 도구는 시스템 관리 및 유지 보수에 사용됩니다.
