圖片本身是二進制數據.不是十六進制的.
所以在資料庫中要存為二進制.
② 資料庫怎麼儲存圖片
資料庫存儲圖片,其實是存儲圖片在伺服器上的路徑或圖片的絕對地址 。它是一個字元串,所以資料庫欄位的類型可使用varchar【可變的,長度不超過255】。在前台調用時,需要將路徑放置在img標簽的src屬性中,即可顯示圖片
③ 急急急!!!把圖片存儲到資料庫中!!!
搞個欄位 XML類型的 AttachData
前台代碼是
<TD class=Label noWrap>文件全文:</TD>
<TD class=Edit width="100%" colSpan=3><SPAN contentEditable=false LF_DefaultValue="" LF_ErrorMsg="" LF_FormatString="" LF_ValidExp="" LF_Expression="" ControlType="Attachment" ControlID="LF_AttachData" LF_FieldName="AttachData" LF_DispName="文件全文" LF_DataType="nvarchar" LF_SearchType="0" LF_ColSpan="2" LF_Align="0" LF_FillStyle="0" LF_AutoPostBack="False" LF_MustFill="False" LF_ReadOnly="False" LF_Display="True" LF_PopupWindowType="0" LF_ForeColor="" LF_DispHeight="" LF_DispWidth="100%" LF_PopupWindowName="" LF_PopupWindowStyle="" LF_SearchString="" LF_Fields_XG="" LF_Editable="True" LF_ContentField="AttachComment">##文件全文##</SPAN></TD>
④ 怎樣將圖片存儲到SQL資料庫中
可以用數據類型設置為image
但是本人認為存儲圖片到資料庫里,有點慢,本人實際一般都是把圖片復制到一個公共文件夾里,然後按照一定規則起名字,再把存儲路徑保存到資料庫里,調用的時候把路徑給圖片控制項給他就可以了,感覺能快點
只是個人想法
⑤ 圖片數據存儲與讀取,及格式是什麼
任何文件數據在硬碟中查看都是這個樣子的,不單單是圖片數據才是這個樣子的哦。視頻、音樂、文本等形式的文件在硬碟中查看也是這個樣子的。文件中所有的要素,比如你說的格式等,都包含在裡面了。在這種形式的數據下,就沒有什麼格式的概念了,只有數據的概念。這些數據是對文件的二進制碼編譯而成的十六進制碼。眾所周知,計算機只能讀取二進制碼,十六進制碼是不能被計算機識別的,那為什麼查看硬碟數據時顯示的是十六進制碼而不是二進制碼呢?因為,如果我們直接查看二進制碼的話,很不方便。首先,二進制碼很長,閱讀起來很費時,其次,二進制碼只有0、1兩個字元,不方便記憶,為了方便人們查看和修改硬碟中的數據,就把二進制碼改成十六進制的顯示方式,這樣識別起來就方便多了。那麼要說方便,改成十進制讀起來不是更方便嗎,但是十六進制可以得到更短的字元串,修改起來更方便。比如01110110這個數,十進制的值是118,十六進制的值是76,可見,十六進制可以得到更短的字元串。
最右邊的那些亂碼是十六進制碼以ASCII碼顯示的結果。ASCII碼是美國信息交換標准碼,共128個,包括52個英文字母大小寫、10個阿拉伯數字和英文標點及一些控制符。比如第一行倒數第四個十六進制碼49,對應的ASCII碼是73,而73正是字母」I「的編號。那些亂七八糟的漢字和符號是由於所對應的十六進制碼不在ASCII碼的范圍內,所以就亂了。詳細就不展開了,如有興趣,可以在網路上搜索答案。
⑥ 圖片如何存儲在資料庫當中
頭條的文件就存在資料庫,可能他們取出來就是二進制吧,播放器可以解碼
⑦ 資料庫如何存儲圖片和取出圖片
思路是這樣的!你在個人資料裡面加個欄位
varchar類型的,用來保存圖片路徑。然後把圖片名稱保存到資料庫就行了,取的話就用Sql讀出圖片名稱,把要放置圖片的位置路徑寫好,名稱就用那個欄位拼下字元串就行了!我是學Java的。C#代碼不是很熟,思路就這樣的吧。我以前就這樣做的,你可以試下!
⑧ 圖片如何存入資料庫
通常對用戶上傳的圖片需要保存到資料庫中。解決方法一般有兩種:一種是將圖片保存的路徑存儲到資料庫;另一種是將圖片以二進制數據流的形式直接寫入資料庫欄位中。以下為具體方法:
一、保存圖片的上傳路徑到資料庫:
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;
採用倆種方式可以根據實際需求靈活選擇。
⑨ 資料庫以img存儲,如何讀取圖片
直接使用企業管理器好像沒有辦法操作吧,通過軟體或自己做個小軟體讀取。
#region //讀取資料庫中圖片到內存.並顯示
public void LoadToMemoryAndDisable(string serverAdress, string database)
{
//讀取資料庫中圖片到內存.並顯示
SqlConnection conn = new SqlConnection("server=" + serverAdress + ";integrated security = sspi;database = " + database);
SqlCommand cmd = new SqlCommand("select * from imgtable where imgname like '%bmp%'", conn);
conn.Open();
SqlDataReader dr;
try
{
dr = cmd.ExecuteReader();
dr.Read();
System.Data.SqlTypes.SqlBinary sb = dr.GetSqlBinary(2);
//或byte[] imageData = (byte[])dr[2];
MemoryStream ms = new MemoryStream(sb.Value);//在內存中操作圖片數據
Bitmap bmp = new Bitmap(Bitmap.FromStream(ms));
this.pictureBox1.Image = bmp;
dr.Close();
}
catch (Exception ex)
{
MessageBox.Show(ex.Message);
}
finally
{
conn.Close();
}
}
#endregion
⑩ 資料庫中怎麼存放圖片
兩種,一種是將圖片轉化成二進制數據流存入資料庫中。一種是保存圖片的路徑,然後前台讀取路徑去調用圖片。相關的代碼網路一下應該會有,第二種方法實現上比較簡單,就是存儲路徑,然後根據路徑讀取對應的圖片顯示出來。第一種就比較麻煩,要先把圖片轉化成二進制數據,讀取時就是從資料庫讀取對應數據再轉化成圖片顯示出來。