《MySQL 权限与访问进阶:普通用户搭建、跨端登录及 C/C++ 开发对接教程》

《MySQL 权限与访问进阶:普通用户搭建、跨端登录及 C/C++ 开发对接教程》
前引:在 MySQL 开发与运维中,普通用户的创建与权限管控是保障数据库安全的基础,而本地连接、远程访问的配置,以及 C/C++ 程序的对接调用,则是打通 “数据库 - 应用” 链路的核心环节。很多开发者在实际操作中会遇到 “用户创建后登录失败”“远程连接被拒绝”“C/C++ 接口调用报错” 等问题,本文将从实战出发,一步步拆解 MySQL 普通用户的创建配置、本地 / 远程登录的关键步骤,以及 C/C++ 访问 MySQL 的完整流程(含环境搭建、代码实现、常见问题排查),帮助开发者快速搞定多场景下的 MySQL 访问需求!

目录

【一】普通用户的创建

(1)查看user表

(2)创建普通用户

(3)删除普通用户

(4)修改密码

(5)数据库权限

(6)回收权限

【二】使用C语言链接访问库

(1)下载库文件

(2)查看库文件

(3)语言检验

【三】语言操作库(接口学习)

(1)初始化

(2)设置字符集

(3)连接MySQL

(4)关闭连接

(5)操作指令

(1)增删

(2)获取输出内容

(6)完整代码


【一】普通用户的创建

(1)查看user表

user表属于mysql数据库,需先切换到该库:

use mysql; -- 切换到mysql数据库

再在 user 表查看账户:

select host,user,authentication_string from user;
(2)创建普通用户
注意:本地登录,‘登录主机/ip’填 localhost 即可,想简单的公网登录填 %
create user '用户名'@'登陆主机/ip' identified by '密码'; 
(3)删除普通用户

主机名可以用上面的 localhost 或者 % 替换,也可以用真实的主机IP

drop user '用户名'@'主机名';
(4)修改密码
自己改自己的密码:
drop user '用户名'@'主机名';
root 账号改指定普通用户的密码:
set password for '用户名'@'主机名'=password('新的密码');
(5)数据库权限
权限列表如下,基本就是任务指令关键字:

给用户添加权限:

grant 权限列表 on 库.对象名 to '用户名'@'登陆位置';
* . * : 代表本系统中的所有数据库的所有对象(表,视图,存储过程等)

库 . * : 表示某个数据库中的所有数据对象(表,视图,存储过程等)

例如:

刷新权限:

flush privileges;

然后使用 newuser 普通用户登入访问授权的数据库和表:

(6)回收权限
revoke 权限列表 on 库.对象名 from '用户名'@'登陆位置';

【二】使用C语言链接访问库

如果是C++语言,原理相同!
(1)下载库文件

如果你想要挑战自己,可以去官网下载,再导入:

https://dev.mysql.com/downloads/

如果你是 Ubuntu ,可以终端直接执行下面指令安装库:

sudo apt update && sudo apt install libmysqlclient-dev
(2)查看库文件
# 列出包对应的所有文件(包括头文件、库文件) dpkg -L libmysqlclient-dev

库文件被放在 /usr/include/mysql 目录下:可以看到有 mysql.h

(3)语言检验

利用下面的函数来检验库文件是否导入成功:

mysql_get_client_info()
注意:编译需要告诉编译器头文件和库文件的位置,先找头文件再链接库文件

          

【三】语言操作库(接口学习)

(1)初始化
mysql_init(null);

例如:

(2)设置字符集
mysql_options(初始化的mysql指针, MYSQL_SET_CHARSET_NAME, "utf8mb4");

例如:

(3)连接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);
参数含义场景取值
mysql已初始化的MYSQL句柄指针mysql_init()返回的指针
hostMySQL 服务器地址本地连接填"localhost""127.0.0.1"或具体IP
userMySQL 登录用户名你的"newuser"
passwd登录密码newuser的实际密码(如"123456"
db要默认连接的数据库名你需要访问的数据库(如"testdb",填NULL则不指定)
portMySQL 服务端口默认3306
unix_socket本地套接字文件(仅 Unix/Linux)本地连接填NULL(使用默认套接字)
client_flag连接标志(如压缩、SSL 等)默认填0即可

例如:

(4)关闭连接
//关闭连接,释放资源 mysql_close(mysql_init返回的指针);
(5)操作指令
(1)增删
int mysql_query(MYSQL *mysql, const char *stmt_str);
  • 参数:mysql为连接句柄,stmt_str为要执行的 SQL 字符串
  • 返回值:成功返回0,失败返回非0

例如:现在有一个表,我用语言执行插入

重新编译+执行:

结果:

(2)获取输出内容
解决问题:如果利用mysql__query执行打印相关的语句,比如select是无法显示的

其实它是将输出的内容信息放在一个二维矩阵里面,二级指针的形式,返回给我们行和列,只要遍历它返回的行和列也就遍历了整个二维字符串数组,拿到了输出内容,下面是接口:

//获取结果集,有了这个函数才可以继续 MYSQL_RES *result = mysql_store_result(mysql_init的返回值);
//关闭文件接口 mysql_free_result(result);

注意:上面这个result相当于就是文件接口,使用完需要及时关闭

//获取结果行数 my_ulonglong mysql_num_rows(MYSQL_RES *res);
  • 参数resmysql_store_result()返回的结果集指针
  • 返回值:结果集的行数(my_ulonglong是无符号长整型,可通过%llu格式化输出)
//获取结果列数 unsigned int mysql_num_fields(MYSQL_RES *res);
  • 参数res是结果集指针
  • 返回值:结果集的列数(无符号整数)
//获取列名称 MYSQL_FIELD *mysql_fetch_fields(MYSQL_RES *res);
  • 参数res是结果集指针。
  • 返回值MYSQL_FIELD结构体数组,数组长度等于mysql_num_fields(res)的返回值。每个MYSQL_FIELD结构体的核心成员包括:
    • name:列名(字符串);
    • type:列的数据类型(如MYSQL_TYPE_INT对应 INT 类型);
    • length:列的定义长度。

例如:

(6)完整代码
#include<stdio.h> #include<mysql.h> int main() { //初始化 MYSQL* my =mysql_init(NULL); if(my==NULL) { printf("sorry,mysql_init is errno"); } //设置字符集 mysql_options(my, MYSQL_SET_CHARSET_NAME, "utf8mb4"); //连接MySQL mysql_real_connect(my, "localhost", "newuser", "123456", "hello", (unsigned int)3306, NULL, (unsigned long) 0); //操作 const char* ptr="select * from student"; mysql_query(my,ptr); //获取结果集 MYSQL_RES *result = mysql_store_result(my); //获取行数 my_ulonglong row_count = mysql_num_rows(result); //获取列数 unsigned int col_count = mysql_num_fields(result); //获取列名称 MYSQL_FIELD *fields = mysql_fetch_fields(result); //打印列名称 for(unsigned int i=0;i<col_count;i++) { printf("%s\t",fields[i].name); } printf("\n"); //打印数据(row用来读取每一行的数据) MYSQL_ROW row; while (row = mysql_fetch_row(result)) { //逐列打印每行数据 for (unsigned int i = 0; i < col_count; i++) { printf("%s\t", row[i]); } printf("\n"); // 每一行打印完换行 } //闭连接,释放资源 mysql_free_result(result); mysql_close(my); return 0; }

Read more

告别复杂配置!Z-Image-Turbo镜像一键启动AI绘画

告别复杂配置!Z-Image-Turbo镜像一键启动AI绘画 你是不是也经历过—— 想试试最新的AI绘画工具,结果卡在第一步:下载模型要等两小时、装依赖报错十七次、配CUDA版本像解谜、最后连WebUI的端口都映射不成功? 别折腾了。今天介绍一个真正“开箱即用”的解决方案:Z-Image-Turbo镜像——阿里通义实验室开源的极速文生图模型,不用编译、不需联网、不改代码,三步启动,直接出图。 这不是概念演示,也不是简化版Demo,而是一个完整封装、生产级稳定的本地AI绘画服务。它把原本需要半天才能跑通的流程,压缩成不到两分钟的操作。下面我就带你从零开始,亲手点亮这个“即插即画”的AI画板。 1. 为什么Z-Image-Turbo值得你立刻试试? 1.1 它不是又一个“参数很大、速度很慢”的模型 Z-Image-Turbo是Z-Image的蒸馏版本,核心突破在于:用更少的计算,换更高的质量。 官方实测数据很直观: * 仅需8步采样(NFEs) 就能生成一张1024×1024高清图——主流SDXL模型通常需要30步以上; * 在H800上单图推理耗时低于0.8秒,

By Ne0inhk
海康机器人3D激光轮廓仪快速调试一

海康机器人3D激光轮廓仪快速调试一

3D轮廓仪相机物料准备 DP系列轮廓仪 24V开关电源 8pin转RJ45千兆网线 12pin转open电源线 直线运动平台 海康3D授权加密狗 软件下载 机器视觉立体相机客户端 —— 3DMVS客户端 3DMVS客户端是专为海康机器人立体相机开发的软件应用程序。适用于MV-DP系列3D激光轮廓传感器、MV-DL系列线 激光立体相机。客户端支持实时预览、参数配置、标定、数据保存、升级固件等功能。 用于3D轮廓仪图像效果调试;并集成相机SDK二次开发包供客户开发; 软件获取方式:海康机器人官网->服务支持->下 载中心,找到3DMVS最新版本下载即可 海康机器人-机器视觉-下载中心 (hikrobotics.com) 安装完成3DMVS后,SDK二次开发包路径: 默认装C盘,安装过程一直单击下一步即可 打开3DMVS后显示效果;“设备列表”里会显示当前网络里的3D相机 电脑环境配置 • 环境配置 • 关闭防火墙和杀毒软件(若安装有360、火绒、腾讯管家等杀毒软件,请关闭退出杀毒软件) • 电源选型设置为高性能模式:通过“控制面板>

By Ne0inhk
小鹏VLA 2.0的“神秘涌现”:从痛苦到突破,自动驾驶与机器人如何突然“开窍”?

小鹏VLA 2.0的“神秘涌现”:从痛苦到突破,自动驾驶与机器人如何突然“开窍”?

大家好,我是数据与算法架构提升之路,专注于AI、自动驾驶和机器人领域的最新动态。今天,我们来聊聊小鹏汽车在2025科技日上爆出的重磅消息:VLA 2.0和人形机器人IRON的“涌现”过程。这不仅仅是技术迭代,更是像科幻小说一样的突然“觉醒”。如果你对自动驾驶的未来感兴趣,这篇文章绝对值得一读!我们将基于小鹏自动驾驶负责人刘先明和机器人副总裁米良川的独家对话,揭秘背后的故事。 * 刘先明 | 小鹏汽车自动驾驶负责人 他于2016年博士毕业于伊利诺伊大学厄巴纳-香槟分校(UIUC),曾在Facebook(现Meta)、Cruise任职,从事机器学习与计算机视觉领域的前沿研究工作。现全面负责小鹏汽车自动驾驶中心业务和组织管理工作。 * 米良川 | 小鹏汽车机器人副总裁及AI技术委员会负责人 他是机器人与AI领域的资深专家。曾在NVIDIA任职十余年,有深厚的GPU并行计算、移动计算、深度学习及自动驾驶技术功底;并曾于CMU机器人研究所深造,且拥有创办机器人公司的实践经验。 涌现的奇迹:从失败边缘到全新大陆 想象一下:一个项目经历了数月的失败,团队内部甚至多次讨论是否要停掉它

By Ne0inhk

VL-JEPA: Joint Embedding Predictive Architecture for Vision-language

架构图1. 不再是学习Y跟Yhat,而是\(S_Y和\hat{S_Y}\).思路跟stable diffusion一样.不在真实Y空间学习,而是在Y编码之后的隐空间学习.所以维度更低.效果更好. 2 方法论 我们提出了VL-JEPA(图1),这是一种用于视觉语言任务的具有联合嵌入预测架构(JEPA)的模型。 VL-JEPA 使用三元组\((X_V,X_Q,Y)\) 进行训练,其中\(X_V\) 表示视觉输入(单个图像或视频帧序列),\(X_Q\) 是文本查询(即问题), Y 是文本目标 (即答案)要预测。 VL-JEPA 由四个组件组成: 1. X-Encoder ( X V ↦ S V

By Ne0inhk