数据库在应用系统开发中很常见,在众多的数据库中,mysql总是会占有一席之地。本篇说明一下如何在ubuntu18.04上安装mysql数据库。
目录
1.更新环境
2.安装mysql数据库系统
3.检测是否安装成功
4.启动、重启、关闭,删除
5.给root用户设置密码
6.安装可视化工具
8.安装mysql客户端
9.安装mysql开发工具包
10.C语言连接数据库
1.更新环境
sudo apt update
2.安装mysql数据库系统
sudo apt install mysql-server
3.检测是否安装成功
sudo mysql -u root -p 回车
show databases;
能看到数据库,则表示mysql服务器安装成功。
4.启动、重启、关闭,删除
sudo /etc/init.d/mysql start
sudo /etc/init.d/mysql restart
sudo /etc/init.d/mysql stop
sudo apt-get autoremove mysql-server / sudo apt-get remove mysql-server
5.给root用户设置密码
mysql --version
通过查看本人安装的是mysql5.7
mysql -uroot -p 回车
// 查看安全策略
SHOW VARIABLES LIKE 'validate_password%';
// 修改安全策略
set global validate_password_policy=0;
set global validate_password_length=1;
//修改密码
ALTER USER 'root'@'localhost' IDENTIFIED BY '<密码密码>';
exit
设置完成之后,登录数据库就需要密码了。
6.安装可视化工具
sudo apt-get install mysql-workbench
mysql-workbench
删除方式如下:
sudo apt autoremove mysql-workbench
8.安装mysql客户端
sudo apt-get install mysql-client
9.安装mysql开发工具包
sudo apt-get install libmysqlclient-dev
安装成功,你会在/usr/include/mysql中看到mysql.h
10.C语言连接数据库
connmysql.cpp
#include <mysql/mysql.h>
#include <stdio.h>
#include <stdlib.h>
MYSQL *conn_ptr;
MYSQL_RES *res_ptr;
MYSQL_ROW sqlrow;
unsigned int timeout = 7; //超时时间7秒
void dispaly_row(MYSQL *ptr)
{
unsigned int field_count = 0;
while (field_count < mysql_field_count(ptr)) //返回在结果结合中字段的数目
{
printf("%s", sqlrow[field_count]);
field_count++;
}
printf("\n");
}
void display_header()
{
MYSQL_FIELD *field_ptr;
printf("Column details:\n");
while ((field_ptr = mysql_fetch_field(res_ptr)) != NULL) //返回列的定义字段信息
{
printf("\t Name:%s\n", field_ptr->name);
printf("\t Type:");
if (IS_NUM(field_ptr->type)) //若字段类型为数字
{
printf("Numeric field\n");
}
else
{
switch (field_ptr->type)
{
case FIELD_TYPE_VAR_STRING:
printf("VACHAR\n");
break;
case FIELD_TYPE_LONG:
printf("LONG\n");
break;
default:
printf("Type is %d,check in mysql_com.h\n", field_ptr->type);
}
}
printf("\t Max width %ld \n", field_ptr->length);
if (field_ptr->flags & AUTO_INCREMENT_FLAG)
printf("\t Auto increments\n");
printf("\n");
}
}
int main()
{
int ret = 0;
int first_row = 1;
conn_ptr = mysql_init(NULL); //初始化
if (!conn_ptr)
{
printf("mysql_init failed!\n");
return -1;
}
ret = mysql_options(conn_ptr, MYSQL_OPT_CONNECT_TIMEOUT, (const char *)&timeout); //设置超时选项
if (ret)
{
printf("Options Set ERRO!\n");
}
conn_ptr = mysql_real_connect(conn_ptr, "localhost", "root", "用户名密码", "数据库名", 3306, NULL, 0); //连接MySQL testdb数据库,端口为3306
if (conn_ptr)
{
printf("Connection Succeed!\n");
ret = mysql_query(conn_ptr, "SELECT * FROM user"); //执行SQL语句
if (!ret)
{
res_ptr = mysql_use_result(conn_ptr);
if (res_ptr)
{
display_header();
printf("Retrieved %lu rows\n", (unsigned long)mysql_num_rows(res_ptr)); //在结果集合中返回行的数量
while ((sqlrow = mysql_fetch_row(res_ptr))) //返回store_result中得到的结构体,并从中检索单行
{
dispaly_row(conn_ptr);//打印表中的内容
}
}
if (mysql_errno(conn_ptr))
{
printf("Connect Erro:%d %s\n", mysql_errno(conn_ptr), mysql_error(conn_ptr)); //返回错误代码、错误消息
return -2;
}
mysql_free_result(res_ptr);
}
else
{
printf("Connect Erro:%d %s\n", mysql_errno(conn_ptr), mysql_error(conn_ptr)); //返回错误代码、错误消息
return -3;
}
mysql_close(conn_ptr);
printf("Connection closed!\n");
}
else //错误处理
{
printf("Connection Failed!\n");
if (mysql_errno(conn_ptr))
{
printf("Connect Erro:%d %s\n", mysql_errno(conn_ptr), mysql_error(conn_ptr)); //返回错误代码、错误消息
}
return -2;
}
return 0;
}
编译执行:
g++ connmysql.cpp -L/user/lib/mysql -lmysqlclient
./a.out
运行结果如下: