mysql中如何存取二进制文件(mysql中如何存取二进制文件数据)

  • 1、怎么在mysql中存储二进制文件
  • 2、Mysql LONGBLOB 类型存储二进制数据 (修改+调试+整理)
  • 3、不知道大家是怎样把二进制数据插入mysql的

像图片这种东西一般都不是直接保存在数据库的,你图片上传了之后,会有个上传后的图片保存路径,你就把这个图片保存的路径给保存到数据库就可以了,你在取的时候直接那这个路径,去找到对应的图片就可以了;图片上传工具有配置上传后保存路径的地方,你把传的图片重命名一下,如果有多张图片,记得名字别重复就行!

在DBMS中线要创建数据库test,table

bintest,data字段数据类型用LONGBLOB即可测试

//测试文件c:\\test.iso,你可以找任何一个文件修改为即可,我找的是一个exe程序,修改为test.iso而已

//最大测试过加入文件大小为650M(一个正真的iso文件)

//注意:还要修改my.ini文件中的max_allowed_packet字段,我设置的是

复制代码

代码如下:

//max_allowed_packet

=

1024M

//#define

host

“localhost”

//mysql

server

//#define

username

“root”

//#define

password

“674800”

//#define

database

“test”

//int

port

=

3306;

//

Mysql3.cpp

:

Defines

the

entry

point

for

the

console

application.

//

#include

“stdafx.h”

#include

Winsock2.h

#include

mysql.h

#include

string.h

#include

stdio.h

#include

stdlib.h

#include

sys/types.h

#include

sys/stat.h

#include

fcntl.h

#pragma

comment(lib,”libmysql.lib”)

#define

INSERT_QUERY

“INSERT

INTO

bintest(id,

data)

VALUES(NULL,

?)”

#define

host

“localhost”

//mysql

server

#define

username

“root”

#define

password

“674800”

#define

database

“test”

int

port

=

3306;

int

get_file_size(char

*path,

off_t

*size)

{

struct

stat

file_stats;

if(stat(path,

file_stats))

return

-1;

*size

=

file_stats.st_size;

return

0;

}

void

test()

{

MYSQL_BIND

bind[1];

unsigned

long

length;

char*

pos

=

NULL;

off_t

size;

FILE*

fp;

char*

filename

=

“c:\\test.iso”;

if

((get_file_size(filename,

size))

==

-1)

//得到文件的大小

{

perror(“get

file

size”

);

exit(1);

}

if

((pos

=

(char

*)malloc(sizeof(char)*(size+1)))

==

NULL)

{

perror(“malloc

buf”

);

exit(1);

}

if

((fp

=

fopen(filename,

“rb”

))

==

NULL)

//读文件

{

perror(“fopen

file”

);

exit(1);

}

if

((fread(pos,

1,

size,

fp))

0)

//读文件失败

{

perror(“fread

file”

);

exit(1);

}

MYSQL

*mysql

=

mysql_init(NULL);

//mysql

初始化

if

(!mysql)

return;

if

(!mysql_real_connect(mysql,host,username,password,”test”,port,NULL,0))//链接服务器

{

int

ret

=

mysql_errno(mysql);

mysql_close(mysql);

return;

}

MYSQL_STMT

*stmt

=

mysql_stmt_init(mysql);

if

(!stmt)

{

fprintf(stderr,

mysql_stmt_init(),

out

of

memory\n”);

exit(0);

}

if

(mysql_stmt_prepare(stmt,

INSERT_QUERY,

strlen(INSERT_QUERY)))

{

fprintf(stderr,

“\n

mysql_stmt_prepare(),

INSERT

failed”);

fprintf(stderr,

“\n

%s”,

mysql_stmt_error(stmt));

exit(0);

}

memset(bind,

0,

sizeof(bind));

//bind[0].buffer_type=

MYSQL_TYPE_STRING;

//bind[0].buffer_type

=

MYSQL_TYPE_LONG;

bind[0].buffer

=

pos;

//bind[0].buffer_type

=

MYSQL_TYPE_TINY;

bind[0].buffer_type

=

MYSQL_TYPE_BLOB;

bind[0].length=

length;

bind[0].is_null=

0;

/*

Bind

the

buffers

*/

if

(mysql_stmt_bind_param(stmt,

bind))

{

fprintf(stderr,

“\n

param

bind

failed”);

fprintf(stderr,

“\n

%s”,

mysql_stmt_error(stmt));

exit(0);

}

int

rc

=0;

/*

Supply

data

in

chunks

to

server

*/

if

(mysql_stmt_send_long_data(stmt,0,

pos,

size))

{

fprintf(stderr,

“\n

send_long_data

failed”);

fprintf(stderr,

“\n

%s”,

mysql_stmt_error(stmt));

exit(0);

}

//

pos

+=

size;

/*

Supply

the

next

piece

of

data

*/

if

(mysql_stmt_send_long_data(stmt,0,

pos,

size))

{

fprintf(stderr,

“\n

send_long_data

failed”);

fprintf(stderr,

“\n

%s”,

mysql_stmt_error(stmt));

exit(0);

}

/*

Now,

execute

the

query

*/

if

(mysql_stmt_execute(stmt))

{

fprintf(stderr,

“\n

mysql_stmt_execute

failed”);

fprintf(stderr,

“\n

%s”,

mysql_stmt_error(stmt));

exit(0);

}

}

int

main()

{

test();

//sleep(1);

return

0;

}

运行结果:

一般很少将二进制的数据,存到数据库里一般是加二年制的数据转换成指定的文件保存在,嗯文件目录里然后再,数据库里存储对应的存储地址,或者是,蒋,数据转换成其他类型存入到数据库。

原创文章,作者:E37NU,如若转载,请注明出处:https://www.506064.com/n/126306.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
E37NU的头像E37NU
上一篇 2024-10-03 23:07
下一篇 2024-10-03 23:07

相关推荐

  • c语言无情铁手,无情铁手余小c语言

    本文目录一览: 1、英雄联盟诺克萨斯之手无情铁手有什么用 可以费血吗 2、四大名捕都是谁 3、无情,铁手,追命,冷血的原名叫什么? 英雄联盟诺克萨斯之手无情铁手有什么用 可以费血吗…

    编程 2024-12-05
  • 详解Java DateTimeFormatter

    一、DateTimeFormatter简介 Java 8新引入的DateTimeFormatter类是Java日期时间API中一个很重要的类,用于格式化和解析日期时间字符串。它可以…

    编程 2024-11-22
  • Python启动应用程序的终极方法

    一、什么是os.startfile 使用Python的os.startfile功能,是一种通过Python脚本启动操作系统上任何应用程序的方法。这种方法非常易于掌握,因为它无需担心…

    编程 2024-11-04
  • 使用SpringBoot连接数据库实现数据操作

    在当前互联网时代,数据操作是软件开发的重要组成部分。使用SpringBoot连接数据库,能够快速、轻松地实现数据持久化操作。本文从以下几个方面进行讲解: 一、SpringBoot集…

    编程 2024-11-26
  • Linux下Ping命令的使用方法

    一、什么是Ping命令 Ping命令是一种网络工具,用于测试网络连接是否正常。它通过发送网络数据包到指定主机并等待响应来测试主机是否可用。如果主机正常工作并响应,Ping命令将显示…

    编程 2024-12-03
  • FontCSS:使用 iconfont 强化你的网页体验

    使用 iconfont 是一种非常方便和流行的方式来使你的网页看起来更美观。通过使用 FontCSS,网站开发人员可以轻松地添加自定义的图标和字体,并让用户无需等待字体下载过程即可…

    编程 2024-12-10
  • Linuxlocale命令详解

    Linuxlocale命令是一个用来获取和设置系统区域设置信息的命令行工具。它可以用来确定以下内容: 默认编码 日期和时间格式 货币符号 文本排序顺序 语言环境 在本文中,我们将从…

    编程 2024-11-14
  • 探索192.168.1.26:全面了解这个IP地址的方方面面

    一、基本概述 如果你是一位计算机网络方面的专业人士,你一定知道192.168.1.26这个IP地址。它是一个局域网IP地址,通常在一个小型网络中使用,如在家中或小办公室中的网络中。…

    编程 2024-10-04
  • javajob,java job框架

    本文目录一览: 1、java中如何实现Job Scheduing 2、java quartz job 执行时间配置 3、怎么实现java简单调用kettle我自己做好的job 4、…

    编程 2024-11-25
  • 正则表达式全面解析

    一、正则表达式是什么 正则表达式,也叫做“正规表达式”,可以看做是一种特殊的字符串模式,使用特殊的语法规则, 表示一段文本中的某种特定模式。使用正则表达式可以完成很多文本处理工作,…

    编程 2024-11-28

发表回复

登录后才能评论