当前位置: 首页 > 编程日记 > 正文

Linux C连接Mysql

首先确定系统上安装了GCC和MYSQL了没有,

如果没有先安装.CentOS用

yum -y install gcc

yum -y install mysql-server

此外还必须安装mysql-devel

安装成功检测:

[root@liu mysql]# rpm -qa | grep 'gcc'  
libgcc-4.4.7-4.el6.x86_64
gcc-4.4.7-4.el6.x86_64
[root@liu mysql]# rpm -qa | grep 'mysql'
mysql-5.1.73-3.el6_5.x86_64
mysql-devel-5.1.73-3.el6_5.x86_64
mysql-libs-5.1.73-3.el6_5.x86_64
mysql-server-5.1.73-3.el6_5.x86_64

然后启动mysql

service mysqld start

进入Mysql创建数据库和表

mysql> create database c_test;
mysql> use c_test
CREATE TABLE `user` (
`id`  int(11) NOT NULL AUTO_INCREMENT ,
`name`  varchar(30) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' ,
PRIMARY KEY (`id`)
)
ENGINE=InnoDB
DEFAULT CHARACTER SET=utf8 COLLATE=utf8_general_ci
;
mysql> insert into user(name) values('张三'),('李四'),('王五');
mysql> select * from user;
+----+--------+
| id | name   |
+----+--------+
|  1 | 张三 |
|  2 | 李四 |
|  3 | 王五 |
+----+--------+
3 rows in set (0.00 sec)

创建mysql.c

/*============================================================================Name        : connect.cAuthor      : 风飘无痕Version     :Copyright   : Your copyright noticeDescription : Connect Mysql============================================================================*/#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <mysql/mysql.h>MYSQL *g_conn; // mysql 连接
MYSQL_RES *g_res; // mysql 记录集
MYSQL_ROW g_row; // 字符串数组,mysql 记录行#define MAX_BUF_SIZE 1024 // 缓冲区最大字节数const char *g_host_name = "localhost";
const char *g_user_name = "root";
const char *g_password = "123456";
const char *g_db_name = "c_test";
const unsigned int g_db_port = 3306;void print_mysql_error(const char *msg) { // 打印最后一次错误if (msg)printf("%s: %s\n", msg, mysql_error(g_conn));elseputs(mysql_error(g_conn));
}int executesql(const char * sql) {/*query the database according the sql*/if (mysql_real_query(g_conn, sql, strlen(sql))) // 如果失败return -1; // 表示失败return 0; // 成功执行
}int init_mysql() { // 初始化连接// init the database connectiong_conn = mysql_init(NULL);/* connect the database */if(!mysql_real_connect(g_conn, g_host_name, g_user_name, g_password, g_db_name, g_db_port, NULL, 0)) // 如果失败return -1;// 是否连接已经可用//if (executesql("set names utf8")) // 如果失败// return -1;return 0; // 返回成功
}int main(void) {if (init_mysql());print_mysql_error(NULL);char sql[MAX_BUF_SIZE];if (executesql(sql))print_mysql_error(NULL);if (executesql("select * from user")) // 句末没有分号
        print_mysql_error(NULL);g_res = mysql_store_result(g_conn); // 从服务器传送结果集至本地,mysql_use_result直接使用服务器上的记录集int iNum_rows = mysql_num_rows(g_res); // 得到记录的行数int iNum_fields = mysql_num_fields(g_res); // 得到记录的列数
printf("共%d个记录,每个记录%d字段\n", iNum_rows, iNum_fields);puts("id\tname\n");while ((g_row=mysql_fetch_row(g_res))) // 打印结果集printf("%s\t%s\n", g_row[0], g_row[1]); // 第一,第二字段
mysql_free_result(g_res); // 释放结果集
mysql_close(g_conn); // 关闭链接return EXIT_SUCCESS;
}

编译

gcc -g -o mysql -I/usr/include/mysql/ connect.c -L/usr/lib64/mysql/ -lmysqlclient -lz

编译的时候要注意用到2个路径,mysql.h和libmysqlclient.so的路径

查找mysql.h路径

[root@liu mysql]# find / -name 'mysql.h'  
/usr/include/mysql/mysql.h

[root@liu mysql]# find / -name '*mysqlclient*' 
/usr/lib64/mysql/libmysqlclient_r.so.16.0.0
/usr/lib64/mysql/libmysqlclient.so.16
/usr/lib64/mysql/libmysqlclient_r.so.16
/usr/lib64/mysql/libmysqlclient_r.so
/usr/lib64/mysql/libmysqlclient.so
/usr/lib64/mysql/libmysqlclient.so.16.0.0

运行:

[root@liu mysql]# ./mysql 

运行结果:

共3个记录,每个记录2字段
id      name1       张三
2       李四
3       王五

一定要保持数据表编码,C文件编码的一致性,否则会出现乱码

转载于:https://www.cnblogs.com/lywy510/p/3615710.html

相关文章:

java servlet 多线程_Servlet的多线程和线程安全

线程安全首先说明一下对线程安全的讨论&#xff0c;哪种情况我们可以称作线程安全&#xff1f;网上对线程安全有很多描述&#xff0c;我比较喜欢《Java并发编程实战》给出的定义&#xff0c;“当多个线程访问某个类时&#xff0c;不管运行时环境采用何种调度方式&#xff0c;或…

JMeter 聚合报告之 90% Line 参数说明

其实要说明这个参数的含义非常简单&#xff0c;可能你早就知道他的含义&#xff0c;但我对这个参数一直有误解&#xff0c;而且还一直以为是“真理”&#xff0c;原于一次面试&#xff0c;被问到了这个问题&#xff0c;所以引起我这个参数的重新认识。 先说说我错误的认识&…

CCF-碰撞的小球

问题描述数轴上有一条长度为L&#xff08;L为偶数)的线段&#xff0c;左端点在原点&#xff0c;右端点在坐标L处。有n个不计体积的小球在线段上&#xff0c;开始时所有的小球都处在偶数坐标上&#xff0c;速度方向向右&#xff0c;速度大小为1单位长度每秒。当小球到达线段的端…

C语言网络编程:多路IO select实现多客户端

文章目录阻塞式的服务器程序多线程服务器程序非阻塞式服务器程序基于事件响应的服务器程序事件响应服务器程序的实现select阻塞式的服务器程序 我们接触过最多的最基础的网络通信模型为TCP/UDP通信模型&#xff0c;以下为TCP通信模型的基本流程C语言网络编程&#xff1a;TCP客…

MVC 中的 ViewModel

此文章总结自&#xff1a;http://rachelappel.com/use-viewmodels-to-manage-data-amp-organize-code-in-asp.net-mvc-applications ViewModel 这个概念不只是在在MVC模式中有&#xff0c;你会在很多关于MVC、MVP、MVVM的文章中见到这个说法&#xff0c;并且这个概念在任何技术…

java udp tcp协议_【java】TCP和UDP传输协议

TCP协议和UDP协议的比较TCP的全称是Transmission Control Protocol (传输控制协议)传输控制协议&#xff0c;是一种面向连接的协议&#xff0c;类似打电话在通信的整个过程中保持连接保证了数据传递的可靠性和有序性是一种全双工的字节流通信方式服务器压力比较大&#xff0c;资…

dot3_bump_mapping

为什么80%的码农都做不了架构师&#xff1f;>>> //----------------------------------------------------------------------------- // Name: ogl_dot3_bump_mapping.cpp // Author: Kevin Harris // Last Modified: 04/21/05 // Descript…

WPF入门教程-转载

最近为了做炫酷的UI&#xff0c;了解了WPF&#xff0c;之前一直是使用winform的&#xff0c;界面也是古老的不行。在园里找到了一个大佬以前写的教程&#xff0c;备注一下。按照系列教程走下来&#xff0c;可以直接上手了。备忘传送门>>>link&#xff1a;DotNet菜园-W…

记一次shell脚本推后台stopped的问题

我们知道linux 下shell可以被分为交互式脚本和非交互式脚本。 交互式脚本即 输入命令之后shell会等待你的输入&#xff0c;当你输入之后命令会被立即提交从而执行。这个时候我们常见的终端bash&#xff0c;以及login提示等都是交互式命令。 非交互式脚本即shell解释器不需要等待…

封装,继承,多态

一、封装&#xff1a; 封装是实现面向对象程序设计的第一步&#xff0c;封装就是将数据或函数等集合在一个个的单元中&#xff08;我们称之为类&#xff09;。被封装的对象通常被称为抽象数据类型。 封装的意义&#xff1a;   封装的意义在于保护或者防止代码&#xff08;数据…

java将一个数转成36进制的数_编程实现将一个N进制数转换成M进制数。

python: 手写算法版&#xff1a; def conversion_num(num, src, dest): rtn # 1、校验源和目标是否相同 if src dest: rtn num # 2、转成10进制# if src ! 10: num_str str(num) num_str num_str[::-1] exe_num 0 dec_num 0 for num_char in num_str: # 十六进制处理 i…

iOS之Storyboard导航大揭秘(1)

本文使用的软件版本&#xff1a; IOS&#xff1a;6.1 XCode&#xff1a;4.6 Storyboard&#xff08;故事板&#xff09;是XCode4.2才开始支持的&#xff0c;为了使设计View更容易。尽管用以前的nib&#xff08;xib&#xff09;拖拖拽拽也没问题&#xff0c;不过却需要 在各种文…

nginx的gzip压缩功能

我们在开发网站的时候&#xff0c;应该要考虑到pv&#xff0c;因为pv比较大可能会造成服务器带宽不够用&#xff0c;进而导致用户体验变差。 这个时候我们就可以考虑用nginx的gzip功能。 在nginx中开启gzip压缩功能很简单&#xff0c;之需要在nginx的配置文件nginx.conf中配置以…

C语言的单链表逆序和指定范围逆序

文章目录前言逆序指定范围逆序源码实现前言 关于链表的逆置&#xff0c;是考察对链表指针的理解。知道了如何不实用额外空间&#xff0c;同时使用O(n)复杂度对链表进行逆序之后将会对链表有好理解。 同时关于如何在指定范围内对链表逆置同样可以进一步加深理解 逆序 基本过程…

mysql udf 性能_适当的mysql udf

问题不在于参数的类型,而是在调用str_ucwords_init时它是NULL(因为在检索任何行之前调用了str_ucwords_init).要使str_ucwords与字段一起使用,您必须通过在_init函数中将initid-> maybe_null设置为1并在str_ucwords中将* null_value设置为1(并且结果为NULL,尽管这可能不是必…

让Windows7运行速度更快的BIOS优化设置教程

和以前使用WindowsXP一样&#xff0c;很多用户都在设法提高windows7的系统运行速速&#xff0c;比较常见的方法大多是对系统服务进行优化&#xff0c;去掉一些可有可无的系统服务&#xff0c;还有就是优化资源管理器菜单等。除此之外&#xff0c;还有一些“不常见的偏方”&…

开源 免费 java CMS - FreeCMS1.2-功能说明-网上调查

2019独角兽企业重金招聘Python工程师标准>>> 下载地址&#xff1a;http://code.google.com/p/freecms/ 网上调查 从FreeCMS 1.2 开始支持 Admin和站点管理员可以管理站点下所有网上调查&#xff0c;普通用户只可管理自己添加的网上调查。 1. 网上调查管理 从左…

Python 之 杂谈(迭代器iter)、偏函数

1、 l [1,2,3,b,5,6] def func():return l.pop() x iter(func,b) print(x.__next__()) print(x.__next__()) print(x.__next__())执行结果&#xff1a; 遇到“b”就停下 2、偏函数 from functools import partial def add(x,y):return xy func partial(add,1)#将1固定传给x…

C语言的单链表创建:头插法/尾插法

文章目录前言链表头插法链表尾插法源码实现前言 接下来一段时间&#xff0c;将对数据结构进行复习&#xff0c;总的来说数据结构自大学之后忘记得有点吓人&#xff0c;为了防止脑容量本就小得脑袋更小&#xff0c;必须得持续性得温故了。 链表数据结构得提出 是为了弥补数组上…

java配置文件实现方式_java相关:详解Spring加载Properties配置文件的四种方式

java相关&#xff1a;详解Spring加载Properties配置文件的四种方式发布于 2020-4-29|复制链接摘记: 一、通过 context:property-placeholder 标签实现配置文件加载1、用法示例&#xff1a; 在spring.xml配置文件中添加标签..一、通过 context:property-placeholder 标签实现配置…

objective-c abort() 与 exit() 函数的区别

exit()函数 调用exit会让用户感觉程序崩溃了&#xff0c;不会有按Home键返回时的平滑过渡和动画效果&#xff1b;另外&#xff0c;使用exit可能会丢失数据&#xff0c;因为调用exit并不会调用-applicationWillTerminate:方法和UIApplicationDelegate方法&#xff1b; abort() a…

用户、组的管理常用到的命令介绍

在LINUX系统管理中&#xff0c;我们经常添加删除修改用户和组的信息&#xff0c;所以我们来学习下创建删除修改用户和组 下面我们就来简单的说下什么是组、什么是用户的概念&#xff1f; 用户&#xff1a; 其实简单的理解就是文件或者目录创建的一种标识。 组&#xff1a; 组简…

react生命周期函数

在react中&#xff0c;生命周期函数指的是组件在加载前&#xff0c;加载后&#xff0c;以及组件更新数据和组件销毁时触发的一系列方法。通常分为以下几类&#xff1a; 组件加载的时候触发的函数&#xff1a;constructor 、componentWillMount、 render 、componentDidMount 组…

C语言的单链表求交点

单链表求交点&#xff0c;问题如下&#xff1a; 使用o(1)的空间复杂度&#xff0c;求两个链表相交的时候的交点&#xff0c;这个思想就类似于使用o(1)的空间复杂度和o(n)的时间复杂度来求链表的第k个节点。 过程如下&#xff1a; 获取两个链表的长度将较长的链表移动和短链表…

jquery中如何以逗号分割字符串_百度知道

jquery中如何以逗号分割字符串_百度知道javascript本身就是带split方法的定义和用法split() 方法用于把一个字符串分割成字符串数组。语法stringObject.split(separator,howmany)参数 描述separator 必需。字符串或正则表达式&#xff0c;从该参数指定的地方分割 stringObject。…

mysql 前台启动_从Windows命令行启动MySQL

可以从命令行手动启动MySQL服务器。可以在任何版本的Windows中实现。要想从命令行启动mysqld服务器&#xff0c;你应当启动控制台窗口(或“DOS window”)并输入命令&#xff1a;C&#xff1a;\> C:\Program Files\MySQL\MySQL Server 5.0\bin\mysqld根据系统中MySQL安装位置…

设置datagridview的数据源为(DATASET)SQL查寻结果

private void button5_Click(object sender, EventArgs e)02 {03 if (MessageBox.Show("确认删除该行吗&#xff1f;", "删除", MessageBoxButtons.YesNo, MessageBoxIcon.Question) DialogResult.Yes )04 {05 SqlConnection conn new SqlConnection();0…

vim中文手册

http://vimcdoc.sourceforge.net/doc/help.html转载于:https://www.cnblogs.com/answercard/p/10125611.html

C语言单链表求环,并返回环的起始节点

若链表中存在环&#xff0c;找出其中的环所在的节点&#xff0c;否则&#xff0c;返回NULL 在没有C set容器的优势前提下&#xff0c;我们对这样的环型的寻找以及定位可以利用快慢指针来实现。 有环的存在&#xff0c;类似与操场跑圈&#xff0c;必然存在快慢之分。有了快慢&a…

CSS3无前缀脚本prefixfree.js与Animatable使用介绍

要求 必备知识 本文要求基本了解 JAVASCRIPT 和 和 CSS3 基本知识。 运行环境 桌面端:IE9 &#xff0c;Opera 10&#xff0c;火狐3.5 &#xff0c;Safari 4和Chrome浏览器;移动端:移动Safari&#xff0c;Android浏览器&#xff0c;Chrome浏览器和Opera Mobile。 演示地址 演示…