MySQL入门尝鲜

1.MySQL安装

具体安装和配置MySQL教程可以参考资料[1]。

2.数据库查询和创建

2.1 数据库查询

通过下面的查询指令,就可以查询到已经创建的数据库

>> show databases;

数据库查询结果

2.2 数据库创建

数据库创建可以使用下面的命令行来实现:

>> create database [数据库名]

再次使用查询指令,可以看到已经创建的数据库。
数据库创建

2.3 数据库删除

数据库删除可以使用下面的命令行来实现:

>>  drop database [数据库名]

再次使用查询指令,可以看到已经删除数据库成功。
数据库删除

2.4 数据库切换

当我们创建表的时候,需要先指定数据库,然后才能进行创建,可以通过下面指令来指定数据库:

>> use [数据库名];

指定数据库

3.表创建、删除、插入和查询

3.1 表创建

表创建的基本语法为:

create table [表名] (
	column1 datatype,
	column2 datatype,
	...
	columnN datatype,
	primary key(one or more colums)
);

举个例子,创建一个student表:

create table student (
	id int not null,
	name varchar(20) not null,
	gender varchar(20) not null,
	age int not null,
	primary key(`id`)
);

后面部分是对当前字段的约束,如not null表示当前字段不能为NULL,primary key用于设置表的主键。
可以用下面指令来查询当前创建表的结构:

>> desc [表名]

创建和查询表
如果要对表进行重命名,可以使用如下指令:

>> rename [旧表名] to [新表名];

3.2 表删除

表删除很简单,可以使用如下指令

>> drop table [表名];

3.3 表插入

表插入使用如下指令:

>> insert into [表名] values ([表值]);

例如,前面创建的表student,向里面插入两行数据:

>> insert into student values (1, '张三', '男', 20);
>> insert into student values (2, '李四', '男', 21);

3.4 表查询

表查询可以使用如下指令:

>> select * from [表名];

表查询

3.5 表删除

删除表中数据可以使用如下指令:

>> delete from [表名] where [删除条件]

这里为了后续实验,先插入了一行数据:王二麻子,然后删除这行数据。
表删除

4. C++代码来查询数据库

4.1 MySQL库配置

如果熟悉OpenCV配置过程,这个就很简单,主要分三个步骤:
(1) 将库dll路径添加到系统环境变量,添加完毕后要重启一下电脑,系统变量才会生效:
dll库添加到系统环境变量
(2) 创建一个visual studio工程,注意要切换到x64环境,添加个main.cpp,配置MySQL的include位置:
配置MySQL的include
(3) 配置MySQL的lib位置:
配置MySQL的lib
(4) 配置系统需要链接的库:
配置MySQL需要链接的库

4.2 测试用例

#include <mysql.h>
#include <stdio.h>

int main() {
	const char* host = "127.0.0.1";
	const char* user = "root";           // 这个改成自己的用户名
	const char* passw = "123456";  // 这个改成自己的密码
	const char* db = "school";         // 这个改成自己要访问数据库
	MYSQL mysql;

	// 1.初始化数据库
	mysql_init(&mysql);

	// 2.设置字符编码
	mysql_options(&mysql, MYSQL_SET_CHARSET_NAME, "gbk");

	// 3.连接数据库
	if (mysql_real_connect(&mysql, host, user, passw, db, 3306, NULL, 0) == NULL) {
		printf("错误原因:%s\n", mysql_error(&mysql));
		printf("连接失败!\n");
		exit(-1);
	}

	// 4.查询结果
	int ret = mysql_query(&mysql, "select * from student;");   // 这个要改成要访问的表
	printf("ret: %d.\n", ret);

	// 5.获取结果
	MYSQL_RES* res = mysql_store_result(&mysql);

	// 6.打印查询到的结果
	MYSQL_ROW row;
	while (row = mysql_fetch_row(res)) {
		printf("%s ", row[0]); // ID
		printf("%s ", row[1]); // Name
		printf("%s ", row[2]); // gender
		printf("%s \n", row[3]); // age
	}

	// 7.释放结果集
	mysql_free_result(res);

	// 8.关闭数据库
	mysql_close(&mysql);

	system("pause");
	return 0;
}

运行结果如下,可以看到跟使用命令行查询得到相同结果:
运行结果
Enjoy!

参考资料

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值