當前位置:首頁 » 編程語言 » csql保存圖片
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

csql保存圖片

發布時間: 2023-03-23 11:06:01

㈠ 如何在sql server中存儲圖片

1、首先可以存儲圖片鏈接,設置圖片鏈接欄位,如下圖所示。

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

一、先來熟悉一下將要使用的對象方法:

  1. 用來獲取上一個頁面傳 遞過來的數據一般是使用Request對象。同樣的,我們也可以使用Request對象 來獲取上傳上來的文件數據,使用的方法是Request.BinaryRead()。

  2. 要從資料庫中讀出來圖片的數據顯示到網頁上面要用到的方法是:Request.BinaryWrite()。

二、在得到了圖片的數據,要保存到資料庫中的時候,不可以直接使用Insert語句對資料庫進行操作,而是要使用ADO的AppendChunk方法。

  1. 同樣的,讀出資料庫中的圖片數據,要使用GetChunk方法。

  2. 各個方法的具體語法如下:

*Request.BinaryRead語法:

variant=Request.BinaryRead(count)

參數

variant

返回值保存著從客戶端讀取到數據。

count

指明要從客戶端讀取的數據量大小,這個值小於或者等於使用方法

Request.TotalBytes得到的數據量。

*Request.BinaryWrite語法:

Request.BinaryWritedata

參數

data

要寫入到客戶端瀏覽器中的數據包。

*Request.TotalBytes語法:

variant=Request.TotalBytes

參數

variant

返回從客戶端讀取到數據量的位元組數。

*AppendChunk語法

將數據追加到大型文本、二進制數據Field或Parameter對象。

object.AppendChunkData

參數

objectField或Parameter對象

Data變體型,包含追加到對象中的數據。

說明

使用Field或Parameter對象的AppendChunk方法可將長二進制或字元數

據填寫到對象中。在系統內存有限的情況下,可以使用AppendChunk方法對長

整型值進行部分而非全部的操作。

*GetChunk語法

返回大型文本或二進制數據Field對象的全部或部分內容。

variable=field.GetChunk(Size)

返回值

返回變體型。

參數

Size長整型表達式,等於所要檢索的位元組或字元數。

說明

使用Field對象的GetChunk方法檢索其部分或全部長二進制或字元數據。

在系統內存有限的情況下,可使用GetChunk方法處理部分而非全部的長整型

值。

GetChunk調用返回的數據將賦給「變數」。如果Size大於剩餘的數據,則

GetChunk僅返回剩餘的數據而無需用空白填充「變數」。如果欄位為空,則

GetChunk方法返回Null。

每個後續的GetChunk調用將檢索從前一次GetChunk調用停止處開始的數

據。但是,如果從一個欄位檢索數據然後在當前記錄中設置或讀取另一個欄位

的值,ADO將認為已從第一個欄位中檢索出數據。如果在第一個欄位上再次調

用GetChunk方法,ADO將把調用解釋為新的GetChunk操作並從記錄的起始

處開始讀取。如果其他Recordset對象不是首個Recordset對象的副本,則

訪問其中的欄位不會破壞GetChunk操作。

如果Field對象的Attributes屬性中的adFldLong位設置為True,則可

以對該欄位使用GetChunk方法。

如果在Field對象上使用Getchunk方法時沒有當前記錄,將產生錯誤3021

(無當前記錄)。

三、設計資料庫,作為測試的資料庫結構如下(Access97):

欄位名稱類型描述

id自動編號主鍵值

imgOLE對象用來保存圖片數據

對於在MSSQLServer7中,對應的結構如下:

欄位名稱類型描述

idint(Identity)主鍵值

imgimage用來保存圖片數據

四、正式編寫純ASP代碼上傳部分了,首先,有一個提供給用戶的上傳界面,可以讓用戶選擇要上傳的圖片。代碼如下(upload.htm):

<html>

<body>

<center>

<formname="mainForm"enctype="multipart/form-data"

action="process.asp"method=post>

<inputtype=filename=mefile><br>

<inputtype=submitname=okvalue="OK">

</form>

</center>

</body>

</html>

注意代碼中黑色斜體的部分,一定要在Form中有這個屬性,否則,將無

法得到上傳上來的數據。

五、接下來,要在process.asp中對從瀏覽器中獲取的數據進行必要的處理,因為在process.asp中獲取到的數據不僅僅包含了想要的上傳上來的圖片的數據,也包含了其他的無用的信息,需要剔除冗餘數據,並將處理過的圖片數據保存到資料庫中,這里以Access97為例。具體代碼如下(process.asp):

<%

response.buffer=true

formsize=request.totalbytes

formdata=request.binaryread(formsize)

bncrlf=chrB(13)&chrB(10)

divider=leftB(formdata,clng(instrb(formdata,bncrlf))-1)

datastart=instrb(formdata,bncrlf&bncrlf)+4

dataend=instrb(datastart+1,formdata,divider)-datastart

mydata=midb(formdata,datastart,dataend)setconnGraph=server.CreateObject("ADODB.connection")

connGraph.ConnectionString="driver={MicrosoftAccessDriver(*.mdb)};DBQ="&

server.MapPath("images.mdb")&";uid=;PWD=;"

connGraph.Opensetrec=server.createobject("ADODB.recordset")

rec.Open"SELECT*FROM[images]whereidisnull",connGraph,1,3

rec.addnew

rec("img").appendchunkmydata

rec.update

rec.close

setrec=nothing

setconnGraph=nothing

%>

六、這樣就把上傳來的圖片保存到了名為images.mdb的資料庫中了,剩下的工作就是要將資料庫中的圖片數據顯示到網頁上面了。

一般在HTML中,顯示圖片都是使用<IMG>標簽,也就是<IMGSRC="圖片路徑">,但是圖片是保存到了資料庫中,「圖片路徑」是什麼呢?呵呵,其實這個SRC屬性除了指定路徑外,也可以這樣使用哦:

<IMGSRC="showimg.asp?id=xxx">

所以,要做的就是在showimg.asp中從資料庫中讀出來符合條件的數據,並返回到SRC屬性中就可以了,具體代碼如下(showimg.asp):

<%

setconnGraph=server.CreateObject("ADODB.connection")

connGraph.ConnectionString="driver={MicrosoftAccessDriver(*.mdb)};DBQ="&

server.MapPath("images.mdb")&";uid=;PWD=;"

connGraph.Open

setrec=server.createobject("ADODB.recordset")

strsql="selectimgfromimageswhereid="&trim(request("id"))

rec.openstrsql,connGraph,1,1

Response.ContentType="image/*"

Response.BinaryWriterec("img").getChunk(7500000)

rec.close

setrec=nothing

setconnGraph=nothing

%>

七、注意在輸出到瀏覽器之前一定要指Response.ContentType="image/*",以便正常顯示圖片。最後要注意的地方是,我的process.asp中作的處理沒有考慮到第一頁(upload.htm)中還有其他數據,比如<INPUTtype=tesxtname=userid>等等,如果有這些項目,process.asp就要注意處理掉不必要的數據。

㈢ SQL資料庫中能存照片嗎

數據中可以存儲圖片,但是需要注意不能直接存儲圖片,而是轉換成二進制或者Base64等的「文本」來存儲,在用的時候,可以再純宴納轉換回來。

在網站開發中,一般將圖片存儲在文件系統中,而不是數據系統中,資料庫系統中只記錄圖片在文件系統中的路徑而已。

拓展資料:

SQL是Structured Query Language(結構化查詢語言)的縮寫。祥鏈SQL是專為資料庫而建立的操作命令集,是一種功做沒能齊全的資料庫語言。在使用它時,只需要發出「做什麼」的命令,「怎麼做」是不用使用者考慮的。SQL功能強大、簡單易學、使用方便,已經成為了資料庫操作的基礎,並且現在幾乎所有的資料庫均支持SQL。

網路_SQL資料庫

㈣ 在sql server中建好表後如何存儲圖片文件

圖片保存到伺服器本地硬碟上,封面只要保存存儲路徑

㈤ 在sql server中建好表後如何存儲圖片文件

方法:
1、建立過程
CREATEPROCEDUREsp_text(
@srvnamevarchar(30),
@loginvarchar(30),
@passwordvarchar(30),
@dbnamevarchar(30),
@tbnamevarchar(30),
@colnamevarchar(30),
@filenamevarchar(30),
@whereclausevarchar(40),
@directionchar(1))
AS
DECLARE@exec_strvarchar(255)
SELECT@exec_str=
'text/S'+@srvname+
'/U'+@login+
'/P'+@password+
'/D'+@dbname+
'/T'+@tbname+
'/C'+@colname+
'/W"'+@whereclause+
'"/F'+@filename+
'/'+@direction
EXECmaster..xp_cmdshell@exec_str

2、建表和初始化數據
createtable表名(編號int,image列名image)
go
insert表名values(1,0x)--必須的,且不是null
insert表名values(2,0x)--必須的,且不是null
go

3、讀入
sp_text'你的伺服器名','sa','你的密碼','庫名','表名','image列名','c:圖片.bmp','where編號=1','I'--注意條件是編號=1

sp_text'你的伺服器名','sa','你的密碼','庫名','表名','image列名','c:b.doc','where編號=2','I'--注意條件是編號=2

go

4、讀出成文件
sp_text'你的伺服器名','sa','你的密碼','庫名','表名','image列名','c:圖片.bmp','where編號=1','O'--注意條件是編號=1

sp_text'你的伺服器名','sa','你的密碼','庫名','表名','image列名','c:b.doc','where編號=2','O'--注意條件是編號=2
go

************如果報text不是可執行文件的話,你就到
C:
目錄下拷備text.exe到:
C:

㈥ SQL中怎麼存圖片路徑

圖片則建議保留在自己新建的images或是upload文件夾里,在頁面的具體需要圖片的地方拖進圖片控制項
資料庫只存放它的實際路徑即可
文章的內容則可以保存在資料庫里
比如說你建一個passage的表
裡面含如下欄位title(文章標題)
author(文章作者)
addtime(發表時間)
content(文章內容)
imageurl(文章圖片的資料庫路徑)
然後就是在cs頁面寫點資料庫編程的sql語句之類的就輕松搞定了
---------------------------------------------------------------------
我好象沒說明白,我是說圖片是隨即插入,沒有固定的地方.當然也可以沒有圖片.還有文字等.然後把這些保存到資料庫中.怎麼檢查文章中有圖片.怎麼保存.
那就要麻煩點
不過可以實現
你見過動網開發的論壇沒有(你想在哪裡插圖片就插圖片
插視頻插flash都可以)
寫點相應的正則表式
和公共類庫文件
然後調用實現
這個說起來簡單但還是需要基本功的哈

㈦ SQL中圖片存儲的方法,謝謝!

首先 在頁面放 個FileUpload 控制項
//判斷 FileUpload 是否為空
if (fileImage.FileName != "")
{

//得到 圖片的後綴名
string imgname = Path.GetExtension(fileImage.PostedFile.FileName.Trim());
//判斷後綴名的格式
if (imgname != ".jpg" && imgname != ".bmp" && imgname != ".gif")
{
lblMsg.Text = "圖片只支持jpg,gif,bmp3種格式";
return;
}
// 我是用的 分時間秒 毫秒 +後綴 名 以免圖片名稱重復 給上傳的圖片取個新名稱
string filename=DateTime.Now.Ticks.ToString()+Path.GetExtension(fileImage.PostedFile.FileName.Trim());
//把圖片保存到指定的文件夾裡面 "../tp/" 是文件夾路徑
fileImage.SaveAs(Server.MapPath("../tp/") + filename);
最後 在把 這個 保存的路徑 插入到數據

}
這是刪除 伺服器上上傳的圖片
File.Delete(Server.MapPath("../tp/") + 加資料庫 圖片的路徑);

㈧ 怎麼使用SQL來存儲圖片

只能把圖片以二進猛中改制的形式保存成image欄位.
不同的程序保存圖片或者文件到資料庫操作培蠢不一樣.
建議你保存圖片的路徑到資料庫,直接調用路徑來完成圖片的保存和顯示,這枝判樣讀取速度都會很快.

㈨ 怎麼樣把圖片存放到SQL SERVER 資料庫中

通常對用戶上傳的圖片需要保存到資料庫中。解決方法一般有兩種:一種是將圖片保存的路徑存儲到資料庫;另一種是將圖片以二進制數據流的形式直接寫入資料庫欄位中。以下為具體方法:
一、保存圖片的上傳派叢路徑到資料庫:
string uppath="";//用於保存圖片上傳路徑
//獲取上傳圖片的文件名
string fileFullname = this.FileUpload1.FileName;
//獲取圖片上傳的時間,以時間作為圖片的名字可以防止圖片重名
string dataName = DateTime.Now.ToString("MMddhhmmss");
//獲取圖片的文件名(不含擴展名)
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;
採用倆種方式可以根據實際需求靈活選擇。

㈩ C#SQL怎麼保存圖片

一、將圖片的存放路徑保存到SQL中(推薦)
二、以image格式存儲圖片信息。