⑴ 資料庫圖片是存儲文件名放在本地還是圖片對象本身哪種好一點
兩種方式都是可以的
但我們通常採用的是
資料庫里存取圖片的文件名稱
圖片本身是存放在硬碟里的
⑵ 圖片該如何存儲在資料庫裡面,存放路徑好還是以二進制存放在資料庫里好
從項目的角度上來說,圖片存儲和資料庫存儲都是必須要分離的,
否則這一個模塊就能拖垮你的整個工程。
二進制的存儲方式,已經淘汰了,性能非常差,在以後的資料庫版本里已經取消了這個存儲方式。
存放路徑,是一種非常方便的解決方案,不存在什麼其他的問題,容易管理。
比如,你以前用二進制存儲的一個圖片,又要IO又要緩存的才能展示給用戶看。
現在你保存的是地址,僅僅需要把鏈接提取出來即可,這樣減少了數據訪問上的壓力。
⑶ 開發程序中,涉及到上傳圖片,上傳的圖片一般是直接在放在資料庫中呢 還是資料庫中保存圖片的路徑。
如果是資料庫中保存圖片的路徑一般:
1.建一個圖片文件夾,所有圖片上傳到這個文件夾
2.在數據為庫里存放這個圖片相對於你的應用程序根目錄的路徑.
3,顯示的時候,直接讓你的圖片框的SRC等於這個路徑就行了.
以上是B/S結構下的方法的一種.
⑷ 如何將圖片路徑存入資料庫 圖片路徑是放在哪的路徑
圖片的路徑通常是放在伺服器里的,將路徑存入資料庫的話很簡單,在資料庫設置一個varchar型的欄位就可以了。 資料庫是通過伺服器進行連接的,不用上傳的;要圖片顯示出來的話,當然要讀出資料庫相應得欄位獲取字元串,也就是圖片的路徑。
⑸ java web製作中資料庫圖片地址一般放在哪
從你問的問題來看,你放在工程里就可以了。
一般會創建圖片伺服器,圖片統一放到上邊
⑹ 資料庫中怎麼存放圖片
兩種,一種是將圖片轉化成二進制數據流存入資料庫中。一種是保存圖片的路徑,然後前台讀取路徑去調用圖片。相關的代碼網路一下應該會有,第二種方法實現上比較簡單,就是存儲路徑,然後根據路徑讀取對應的圖片顯示出來。第一種就比較麻煩,要先把圖片轉化成二進制數據,讀取時就是從資料庫讀取對應數據再轉化成圖片顯示出來。
⑺ 如何像資料庫中保存圖片
一般圖像是不保存在資料庫的.而是先將圖片放在工程下的某個文件夾中,將圖片所在的工程文件路徑存在資料庫中,當程序載入圖片的時候,從資料庫中讀取圖片的路徑,然後根據路徑在工程的文件夾中讀取圖片文件
⑻ 圖片如何存入資料庫
通常對用戶上傳的圖片需要保存到資料庫中。解決方法一般有兩種:一種是將圖片保存的路徑存儲到資料庫;另一種是將圖片以二進制數據流的形式直接寫入資料庫欄位中。以下為具體方法:
一、保存圖片的上傳路徑到資料庫:
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;
採用倆種方式可以根據實際需求靈活選擇。
⑼ 資料庫中可以存儲照片么怎麼存儲
數據中可以存儲圖片,但是需要注意不能直接存儲圖片,而是轉換成二進制或者Base64等的「文本」來存儲,在用的時候,可以再轉換回來。
在網站開發中,一般將圖片存儲在文件系統中,而不是數據系統中,資料庫系統中只記錄圖片在文件系統中的路徑而已。