当前位置: 首页 > news >正文

Ubuntu c++ MySQL数据库操作

mysql安装

sudo apt-get install update

sudo apt-get install mysql-server libmysqlclient-dev mysql-workbench

mysql启动/重启/停止

sudo service mysql start/restart/stop

登录mysql命令:mysql -uroot -p

错误异常:

解决办法:

修改mysqld.cnf配置文件

在ubuntu的terminal(也即终端)上输入sudo nano /etc/mysql/mysql.conf.d/mysqld.cnf,进入到这个配置文件,然后在这个配置文件中的[mysqld]这一块中加入skip-grant-tables这句话。

[mysqld]

#

# * Basic Settings

#

user = mysql

pid-file = /var/run/mysqld/mysqld.pid

socket = /var/run/mysqld/mysqld.sock

port = 3306

basedir = /usr

datadir = /var/lib/mysql

tmpdir = /tmp

lc-messages-dir = /usr/share/mysql

skip-external-locking

skip-grant-tables

作用:就是让你可以不用密码登录进去mysql。

保存,退出。输入:service mysql restart,重新启动mysql。

重新登录设置密码。

代码

#include <iostream>
#include <mysql/mysql.h>using namespace std;
///
/// \brief sql_create 创建数据库
///
void sql_create()
{MYSQL mysql;mysql_init(&mysql);if(!mysql_real_connect(&mysql, "localhost", "root", "root", "mysql", 3306, NULL, 0)) {cout<<"mysql connect error: "<<mysql_error(&mysql)<<" "<<mysql_errno(&mysql)<<endl;}string str = "create database school;";mysql_real_query(&mysql, str.c_str(), str.size());str = "alter database school charset=utf8;";mysql_real_query(&mysql, str.c_str(), str.size());
// 自动生成id add数据时去掉id
//    str = "create table school.students(id int(10) primary key auto_increment, name varchar(20) not null, age int(3) not null);";
//手动添加idstr = "create table school.students(id int(10) primary key , name varchar(20) not null, age int(3) not null);";mysql_real_query(&mysql, str.c_str(), str.size());mysql_close(&mysql);
}
///
/// \brief sql_add 增加数据
///
void sql_add()
{MYSQL mysql;mysql_init(&mysql);mysql_options(&mysql, MYSQL_SET_CHARSET_NAME, "utf8");mysql_options(&mysql, MYSQL_INIT_COMMAND, "SET NAMES utf8");if(!mysql_real_connect(&mysql, "localhost", "root", "root", "school", 3306, NULL, 0)) {cout<<"mysql connect error: "<<mysql_error(&mysql)<<" "<<mysql_errno(&mysql);}string str = "insert into students(id, name, age) values(1, \'张三\', 20)";mysql_real_query(&mysql, str.c_str(), str.size());str = "insert into students(id, name, age) values(2, \'李四\', 18)";mysql_real_query(&mysql, str.c_str(), str.size());str = "insert into students(id, name, age) values(3, \'王五\', 19)";mysql_real_query(&mysql, str.c_str(), str.size());str = "insert into students(id, name, age) values(4, \'赵六\', 21)";mysql_real_query(&mysql, str.c_str(), str.size());str = "insert into students(id, name, age) values(5, \'马七\', 20)";mysql_real_query(&mysql, str.c_str(), str.size());mysql_close(&mysql);
}
///
/// \brief sql_modify 修改数据
///
void sql_modify()
{MYSQL mysql;mysql_init(&mysql);mysql_options(&mysql, MYSQL_SET_CHARSET_NAME, "utf8");mysql_options(&mysql, MYSQL_INIT_COMMAND, "SET NAMES utf8");if(!mysql_real_connect(&mysql, "localhost", "root", "root", "school", 3306, NULL, 0)) {cout<<"mysql connect error: "<<mysql_error(&mysql)<<" "<<mysql_errno(&mysql);}string str = "update students set age = 30 where name = \'王五\'";mysql_real_query(&mysql, str.c_str(), str.size());mysql_close(&mysql);
}
///
/// \brief sql_delete 删除数据
///
void sql_delete()
{MYSQL mysql;mysql_init(&mysql);mysql_options(&mysql, MYSQL_SET_CHARSET_NAME, "utf8");mysql_options(&mysql, MYSQL_INIT_COMMAND, "SET NAMES utf8");if(!mysql_real_connect(&mysql, "localhost", "root", "root", "school", 3306, NULL, 0)) {cout<<"mysql connect error: "<<mysql_error(&mysql)<<" "<<mysql_errno(&mysql);}string str = "delete from students where name = \'赵六\'";mysql_real_query(&mysql, str.c_str(), str.size());mysql_close(&mysql);
}
///
/// \brief sql_query 查询数据
///
void sql_query()
{MYSQL mysql;mysql_init(&mysql);mysql_options(&mysql, MYSQL_SET_CHARSET_NAME, "utf8");mysql_options(&mysql, MYSQL_INIT_COMMAND, "SET NAMES utf8");if(!mysql_real_connect(&mysql, "localhost", "root", "root", "school", 3306, NULL, 0)) {cout<<"mysql connect error: "<<mysql_error(&mysql)<<" "<<mysql_errno(&mysql);}string str = "select * from students;";mysql_real_query(&mysql, str.c_str(), str.size());MYSQL_RES *result = mysql_store_result(&mysql);MYSQL_ROW row;while (row = mysql_fetch_row(result)) {cout<<"id: "<<row[0]<<" name: "<<row[1]<<" age: "<<row[2]<<endl;}mysql_free_result(result);mysql_close(&mysql);
}int main()
{cout << "Hello World!111" << endl;sql_create();cout << "Hello World!222" << endl;sql_add();cout << "Hello World!333" << endl;sql_query();cout << "Hello World!444" << endl;sql_modify();cout << "Hello World!555" << endl;sql_query();cout << "Hello World!666" << endl;sql_delete();cout << "Hello World!777" << endl;sql_query();return 0;
}

编译:

g++ main.cpp -lmysqlclient

运行结果:

http://www.lryc.cn/news/36423.html

相关文章:

  • C++11:lambda表达式
  • 【Android -- 开源库】表格 SmartTable 的基本使用
  • 自动化测试实战篇(9),jmeter常用断言方法,一文搞懂9种测试字段与JSON断言
  • vue-virtual-scroll-list虚拟列表
  • C++学习笔记(以供复习查阅)
  • 备份时间缩短为原来 1/4,西安交大云数据中心的软件定义存储实践
  • 我国近视眼的人数已经超过了六亿,国老花眼人数超过三亿人
  • 设计模式(十八)----行为型模式之策略模式
  • VUE3入门基础:input元素的type属性值说明
  • 关于供应链,一文教你全面了解什么是供应链
  • Scope作用域简单记录分析
  • ChatGPT创作恋爱甜文
  • 贝叶斯优化及其python实现
  • Lombok使用@Builder无法build父类属性
  • Pixhawk RPi CM4 Baseboard 树莓派CM4安装Ubuntu20.04 server 配置ros mavros mavsdk
  • 后端开发过程中的安全问题
  • 基于Hyperledger Fabric的学位学历认证管理系统
  • jq条件判断验证,正则表达式
  • 23.3.9打卡 AtCoder Beginner Contest 259
  • JS - this指向
  • 低代码有哪些典型应用场景?
  • Substrate 基础教程(Tutorials) -- 监控节点指标
  • lua table 详解
  • Element表单嵌套树形表格的校验问题
  • 1.webpack的基本使用
  • 面试必看:谈谈你所了解的JVM调优,JVM性能调优总结
  • Pytorch优化器Optimizer
  • 如何在MySQL 8中实现数据迁移?这里有一个简单易用的方案
  • java多线程(二三)并发编程:Callable、Future和FutureTask
  • day4分支和循环作业