導航:首頁 > 數據分析 > 怎麼將圖片存入資料庫

怎麼將圖片存入資料庫

發布時間:2022-12-30 06:21:34

1. 如何將圖片存到資料庫

保存圖片到資料庫中,有兩種方法:
1、一種是用大對象,即blob型,對c#不了解,版但是java、c++中都有專門操作blob的對象權,應該是以二進制流的方式走的。但是不建議採用這樣的管理方式,會加重資料庫、程序負擔,即使是手機開發也是如此。
2、圖片保存在本地,資料庫中用字元串存儲地址,這樣的方式比較好,也較易實現。但是缺乏安全性,把圖片重命名就行了,改個後綴,一般人就不會打開。還是不放心,用二進制加密下就好,這樣的程序代價仍然要比存在資料庫大對象中要好。

2. 如何在ASP.Net 中把圖片存入資料庫

一 介紹

可能有很多的時候 我們急需把圖片存入到資料庫當中 在一些應用程序中 我們可能有一些敏感的資料 由於存儲在文件系統(file system)中的東西 將很容易被某些用戶盜取 所以這些數據不能存放在文件系統中

在這篇文章中 我們將討論怎樣把圖片存入到Sql 當中

在這篇文章中我們可以學到以下幾個方面的知識

插入圖片的必要條件

使用流對象

查找准備上傳的圖片的大小和類型

.怎麼使用InputStream方法?

在我們開始上傳之前 有兩件重要的事我們需要做

(1)Form 標記的 enctype 屬性應該設置成 enctype= multipart/form data

(2) 需要一個<input type=file>表單來使用戶選擇他們要上傳的文件 同時我們需要導入 System IO名稱空間來處理流對象

把以上三點應用到aspx頁面 同時我們需要對SqlServer做以下的准備

(1)需要至少含有一個圖片類型的欄位的表

(2)如果我們還有另外一個變字元類型的欄位來存儲圖片類型 那樣會更好一些

現在 我們准備了一個Sql表(包含了一個image數據類型的欄位) 還有<input type=file>標記 當然我們還得准備Submit按鈕 以便用戶在選擇了圖片以後提交 在這個按鈕的Onclick事件里 我們需要讀取選取圖片的內容 然後把它存入到表裡 那我們先來看看這個Onclick事件

提交按鈕的Onclick事件的代碼

Dim intImageSize As Int Dim strImageType As StringDim ImageStream As Stream

Gets the Size of the ImageintImageSize = PersonImage PostedFile ContentLength

Gets the Image TypestrImageType = PersonImage PostedFile ContentType

Reads the ImageImageStream = PersonImage PostedFile InputStream

Dim ImageContent(intImageSize) As ByteDim intStatus As IntegerintStatus = ImageStream Read(ImageContent intImageSize)

Create Instance of Connection and Command ObjectDim myConnection As New SqlConnection(ConfigurationSettings AppSettings( ConnectionString ))Dim myCommand As New SqlCommand( sp_person_isp myConnection)

Mark the Command as a SPROCmyCommand CommandType = CommandType StoredProcere

Add Parameters to SPROCDim prmPersonImage As New SqlParameter( @PersonImage SqlDbType Image)prmPersonImage Value = ImageContentmyCommand Parameters Add(prmPersonImage)

Dim prmPersonImageType As New SqlParameter( @PersonImageType SqlDbType VarChar )prmPersonImageType Value = strImageTypemyCommand Parameters Add(prmPersonImageType)

TrymyConnection Open()myCommand ExecuteNonQuery()myConnection Close()Response Write( New person successfully added! )Catch SQLexc As SqlExceptionResponse Write( Insert Failed Error Details are: & SQLexc ToString())End Try

這是怎麼工作的呢?PersonImage是HTMLInputFile控制項的對象 首先需要獲得圖片的大小 可以使用下面的代碼實現

intImageSize = PersonImage PostedFile ContentLength

然後返回圖片的類型使用ContenType屬性 最後 也是最重要的事就是取得Image Stream 這可以用以下代碼實現

ImageStream = PersonImage PostedFile InputStream

我們需要一個位元組型數組來存儲image 內容 讀取整個圖片可以使用Stream對象的Read方法來實現 Read(in byte[] buffer int offset int count)方法有三個參數 【關於Read方法的詳細內容可以參看 Net FrameWorkSDK】 他們是

buffer位元組數組 此方法返回時 該緩沖區包含指定的字元數組 該數組的 offset 和 (offset + count) 之間的值由從當前源中讀取的位元組替換

offsetbuffer 中的從零開始的位元組偏移量 從此處開始存儲從當前流中讀取的數據

count要從當前流中最多讀取的位元組數

這個Read方法用以下代碼實現 intStatus = ImageStream Read(ImageContent intImageSize)現在 我們已經讀取了整個圖片的內容 下一步 我們要把這些內容存入到sql 表 我們將使用存儲過程來完成插入圖片類型和圖片內容到sql 表 如果你瀏覽了上面的代碼 你將會發現我們使用了sqldbtype image的數據類型(datatype) Ok了 完成了這些 我們也就成功的把圖片存入到SqlServer中了 下面是我們編寫的aspx頁面

二 結論

lishixin/Article/program/net/201311/15186

3. 怎麼將圖片錄入到資料庫中

1.把圖片在文件系統里的路徑存在資料庫里

2.要讀取圖片的時候把資料庫里的路徑查出來,然後再根據路徑在文件系統里讀取圖片。

4. 怎樣把圖片存入SQL資料庫表中

將圖片存入SQL資料庫中一般分兩種情況

一、把圖片轉換成二進制形式存儲在資料庫中

一般資料庫提供一個二進制欄位來存儲二進制數據。如SQLServer中的BINARY,VARBINARY;

1、BINARY數據類型用於存儲二進制數據。其定義形式為BINARY(n),n表示數據的長度,取值為1到8000。在使用時必須指定BINARY類型數據的大小,至少應為1個位元組。BINARY類型數據佔用n+4個位元組的存儲空間。在輸入數據時必須在數據前加上字元「0X」作為二進制標識,如:要輸入「abc」則應輸入「0xabc」。若輸入的數據過長將會截掉其超出部分。若輸入的數據位數為奇數,則會在起始符號「0X」後添加一個0,如上述的「0xabc」會被系統自動變為「0x0abc」。

2、VARBINARY數據類型的定義形式為VARBINARY(n)。它與BINARY類型相似,n的取值也為1到8000,若輸入的數據過長,將會截掉其超出部分。不同的是VARBINARY數據類型具有變動長度的特性,因為VARBINARY數據類型的存儲長度為實際數值長度+4個位元組。當BINARY數據類型允許NULL值時,將被視為VARBINARY數據類型。

一般情況下,由於BINARY數據類型長度固定,因此它比VARBINARY類型的處理速度快

二、圖片存儲在磁碟上,資料庫欄位中保存的是圖片的路徑

存儲路徑存儲路徑字元串即可,sql中可以使用varchar/nvarchar;

總結:將圖片文件直接以二進制存儲資料庫需要將圖片提前轉為二進制數據,以存儲圖片物理路徑的方式需要將圖片文件放置指定位置,這都需要配合不同的編程語言實現;

以C#為例:

//點擊按鈕執行存入
privatevoidbtnWrite_Click(objectsender,EventArgse)
{
OpenFileDialogofd=newOpenFileDialog();
ofd.Filter="*jpg|*.JPG|*.GIF|*.GIF|*.BMP|*.BMP";

if(ofd.ShowDialog()==DialogResult.OK)
{
stringfilePath=ofd.FileName;//圖片路徑
FileStreamfs=newFileStream(filePath,FileMode.Open);//讀取圖片流
byte[]imageBytes=newbyte[fs.Length];
BinaryReaderbr=newBinaryReader(fs);
imageBytes=br.ReadBytes(Convert.ToInt32(fs.Length));//圖片轉換成二進制流

stringstrSql=string.Format("insertinto[SBS].[dbo].[Model]([M_QRCode],[M_Skills])values(@image,'2')");
intcount=Write(strSql,imageBytes);

if(count>0)
{
MessageBox.Show("success");
}
else
{
MessageBox.Show("failed");
}
}
}

//資料庫連接和保存圖片語句
privateintWrite(stringstrSql,byte[]imageBytes)
{
stringconnStr="DataSource=資料庫地址;initialCatalog=SBS;UserID=sa;Password=sa;";

using(SqlConnectionconn=newSqlConnection(connStr))
{
using(SqlCommandcmd=newSqlCommand(strSql,conn))
{
try
{
conn.Open();//打開資料庫鏈接
SqlParametersqlParameter=newSqlParameter("@image",SqlDbType.Image);
sqlParameter.Value=imageBytes;
cmd.Parameters.Add(sqlParameter);
introws=cmd.ExecuteNonQuery();//執行插入操作
returnrows;
}
catch(Exceptione)
{
throw;
}
}
}
}

5. 如何將圖片插入到資料庫中

第一步://獲取當前選擇的圖片 this.pictureBox1.Image = Image.FromStream(this.openFileDialog1.OpenFile()); //獲取當前圖片的路徑 string path = openFileDialog1.FileName.ToString(); //將制定路徑的圖片添加到FileStream類中 FileStream fs = new FileStream(path, FileMode.Open, FileAccess.Read); //通過FileStream對象實例化BinaryReader對象 BinaryReader br = new BinaryReader(fs); //通過BinaryReader類對象的ReadBytes()方法將FileStream類對象轉化為二進制數組 byte[] imgBytesIn = br.ReadBytes(Convert.ToInt32(fs.Length));第二步://將圖片添加到資料庫中 string sql="insert into pic values(@pic)"; SqlParameter[] param = new SqlParameter[] { new SqlParameter("@pic", imgBytesIn) }; DBHelper.GetExecuteQuery(sql, param);第三步://將圖片從資料庫中取出 string sql="select * from pic where id=0"; SqlDataReader reader = DBHelper.GetExecuteReader(sql, null); MemoryStream mss = null;

6. python 如何把圖片存入資料庫

作者:小風寒吶
鏈接:https://zhuanlan.hu.com/p/30212013
來源:知乎
著作權歸作者所有。商業轉載請聯系作者獲得授權,非商業轉載請註明出處。
首先我們讀取圖庫中所有圖片的名稱,保存在fileNames中。然後讀取Data.csv中所有數據。
提取出Data.csv的最後一列(一共10002列,第10001列說明該數字是什麼數字,第10002列是圖片的名稱),也就是資料庫中存儲的所有圖片的名稱,存儲在item中。
將新加入圖庫的圖片名稱保存在newFileNames中。如果Data.csv為空,那麼就直接令newFileNames
=
fileNames。也就是說如果資料庫中什麼也沒有,那麼圖庫中所有圖片都是新加入的。
如果Data.csv不為空,那麼就將item裡面的內容與fileNames的內容比較,如果出現了fileNames裡面有的名稱item中沒有,那麼就將這些名稱放進newFileNames中。如果item里有的名稱fileNames中沒有,那就不管。
也就是說,我令我們的資料庫只進不出。
現在我們得到了新加入圖庫的圖片的名稱newFileNames。
將newFileNames中的名稱的圖片帶入上一文中函數GetTrainPicture進行處理,得到了一個nx10001的矩陣,每一行代表一個新加入的圖片,前10000列是圖片向量,第10001列是該圖片的數字,保存在pic中。

7. 圖片如何存入資料庫

通常對用戶上傳的圖片需要保存到資料庫中。解決方法一般有兩種:一種是將圖片保存的路徑存儲到資料庫;另一種是將圖片以二進制數據流的形式直接寫入資料庫欄位中。以下為具體方法:
一、保存圖片的上傳路徑到資料庫:
string uppath="";//用於保存圖片上傳路徑
//獲取上傳圖片的文件名
string fileFullname = this.FileUpload1.FileName;
//獲取圖片上傳的時間,以時間作為圖片的名字可以防止圖片重名
string dataName = DateTime.Now.ToString("yyyyMMddhhmmss");
//獲取圖片的文件名(不含擴展名)
string fileName = fileFullname.Substring(fileFullname.LastIndexOf("\\") + 1);
//獲取圖片擴展名
string type = fileFullname.Substring(fileFullname.LastIndexOf(".") + 1);
//判斷是否為要求的格式
if (type == "bmp" || type == "jpg" || type == "jpeg" || type == "gif" || type == "JPG" || type == "JPEG" || type == "BMP" || type == "GIF")
{
//將圖片上傳到指定路徑的文件夾
this.FileUpload1.SaveAs(Server.MapPath("~/upload") + "\\" + dataName + "." + type);
//將路徑保存到變數,將該變數的值保存到資料庫相應欄位即可
uppath = "~/upload/" + dataName + "." + type;
}
二、將圖片以二進制數據流直接保存到資料庫:
引用如下命名空間:
using System.Drawing;
using System.IO;
using System.Data.SqlClient;
設計資料庫時,表中相應的欄位類型為iamge
保存:
//圖片路徑
string strPath = this.FileUpload1.PostedFile.FileName.ToString ();
//讀取圖片
FileStream fs = new System.IO.FileStream(strPath, FileMode.Open, FileAccess.Read);
BinaryReader br = new BinaryReader(fs);
byte[] photo = br.ReadBytes((int)fs.Length);
br.Close();
fs.Close();
//存入
SqlConnection myConn = new SqlConnection("Data Source=.;Initial Catalog=stumanage;User ID=sa;Password=123");
string strComm = " INSERT INTO stuInfo(stuid,stuimage) VALUES(107,@photoBinary )";//操作資料庫語句根據需要修改
SqlCommand myComm = new SqlCommand(strComm, myConn);
myComm.Parameters.Add("@photoBinary", SqlDbType.Binary, photo.Length);
myComm.Parameters["@photoBinary"].Value = photo;
myConn.Open();
if (myComm.ExecuteNonQuery() > 0)
{
this.Label1.Text = "ok";
}
myConn.Close();
讀取:
...連接資料庫字元串省略
mycon.Open();
SqlCommand command = new
SqlCommand("select stuimage from stuInfo where stuid=107", mycon);//查詢語句根據需要修改
byte[] image = (byte[])command.ExecuteScalar ();
//指定從資料庫讀取出來的圖片的保存路徑及名字
string strPath = "~/Upload/zhangsan.JPG";
string strPhotoPath = Server.MapPath(strPath);
//按上面的路徑與名字保存圖片文件
BinaryWriter bw = new BinaryWriter(File.Open(strPhotoPath,FileMode.OpenOrCreate));
bw.Write(image);
bw.Close();
//顯示圖片
this.Image1.ImageUrl = strPath;
採用倆種方式可以根據實際需求靈活選擇。

8. 資料庫中可以存儲照片么怎麼存儲

數據中可以存儲圖片,但是需要注意不能直接存儲圖片,而是轉換成二進制或者Base64等的「文本」來存儲,在用的時候,可以再轉換回來。
網站開發中,一般將圖片存儲在文件系統中,而不是數據系統中,資料庫系統中只記錄圖片在文件系統中的路徑而已。

閱讀全文

與怎麼將圖片存入資料庫相關的資料

熱點內容
51虛擬機的文件管理在哪裡 瀏覽:13
win10系統有沒有便簽 瀏覽:722
java引用傳遞和值傳遞 瀏覽:109
oracle下載安裝教程 瀏覽:854
php篩選資料庫 瀏覽:830
怎麼用手機看wlan密碼 瀏覽:745
奧維地圖導入的文件在哪裡 瀏覽:364
sdltrados2014教程 瀏覽:43
培訓制度文件在哪裡找 瀏覽:601
勒索病毒防疫工具 瀏覽:861
win10c不能打開 瀏覽:375
xfplay影音先鋒蘋果版 瀏覽:597
兩個文件打開兩個word 瀏覽:921
蘋果6s桌面圖標輕微抖動 瀏覽:326
如何刪除手機中看不見的臨時文件 瀏覽:469
安卓412原生鎖屏apk 瀏覽:464
書加加緩存文件在哪裡 瀏覽:635
dock是word文件嗎 瀏覽:267
社保公司新辦去哪個網站下載資料 瀏覽:640
三維標注數據怎麼填寫 瀏覽:765

友情鏈接