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/zh-tw/n/126306.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
E37NU的頭像E37NU
上一篇 2024-10-03 23:07
下一篇 2024-10-03 23:07

相關推薦

  • 如何修改mysql的埠號

    本文將介紹如何修改mysql的埠號,方便開發者根據實際需求配置對應埠號。 一、為什麼需要修改mysql埠號 默認情況下,mysql使用的埠號是3306。在某些情況下,我們需…

    編程 2025-04-29
  • Python讀取CSV數據畫散點圖

    本文將從以下方面詳細闡述Python讀取CSV文件並畫出散點圖的方法: 一、CSV文件介紹 CSV(Comma-Separated Values)即逗號分隔值,是一種存儲表格數據的…

    編程 2025-04-29
  • Python中讀入csv文件數據的方法用法介紹

    csv是一種常見的數據格式,通常用於存儲小型數據集。Python作為一種廣泛流行的編程語言,內置了許多操作csv文件的庫。本文將從多個方面詳細介紹Python讀入csv文件的方法。…

    編程 2025-04-29
  • 如何用Python統計列表中各數據的方差和標準差

    本文將從多個方面闡述如何使用Python統計列表中各數據的方差和標準差, 並給出詳細的代碼示例。 一、什麼是方差和標準差 方差是衡量數據變異程度的統計指標,它是每個數據值和該數據值…

    編程 2025-04-29
  • Python多線程讀取數據

    本文將詳細介紹多線程讀取數據在Python中的實現方法以及相關知識點。 一、線程和多線程 線程是操作系統調度的最小單位。單線程程序只有一個線程,按照程序從上到下的順序逐行執行。而多…

    編程 2025-04-29
  • Python爬取公交數據

    本文將從以下幾個方面詳細闡述python爬取公交數據的方法: 一、準備工作 1、安裝相關庫 import requests from bs4 import BeautifulSou…

    編程 2025-04-29
  • Python兩張表數據匹配

    本篇文章將詳細闡述如何使用Python將兩張表格中的數據匹配。以下是具體的解決方法。 一、數據匹配的概念 在生活和工作中,我們常常需要對多組數據進行比對和匹配。在數據量較小的情況下…

    編程 2025-04-29
  • Python數據標準差標準化

    本文將為大家詳細講述Python中的數據標準差標準化,以及涉及到的相關知識。 一、什麼是數據標準差標準化 數據標準差標準化是數據處理中的一種方法,通過對數據進行標準差標準化可以將不…

    編程 2025-04-29
  • 如何使用Python讀取CSV數據

    在數據分析、數據挖掘和機器學習等領域,CSV文件是一種非常常見的文件格式。Python作為一種廣泛使用的編程語言,也提供了方便易用的CSV讀取庫。本文將介紹如何使用Python讀取…

    編程 2025-04-29
  • Python如何打亂數據集

    本文將從多個方面詳細闡述Python打亂數據集的方法。 一、shuffle函數原理 shuffle函數是Python中的一個內置函數,主要作用是將一個可迭代對象的元素隨機排序。 在…

    編程 2025-04-29

發表回復

登錄後才能評論