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

sql圖片庫

發布時間: 2022-09-10 09:36:27

⑴ C#怎麼將圖片保存到sql資料庫

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;

⑵ 運用c#+SQL如何建立圖片資料庫

一般不把圖片直接存在資料庫中,雖然資料庫支持存放二進制數據,一般是存放圖片的索引路徑,比如規定一個根目錄,裡面按類存放圖片,在資料庫中就要建立圖片類別表,存放圖片類的路徑比如
植物|root/植物
動物|root/動物
當然還可以按日期索引,等等,資料庫主要是存放圖片的索引,通過索引找到記對應圖片的實際存放路徑

⑶ 怎樣往SQL資料庫中插入圖片,最好舉例說明

首先存儲圖片主要是要保存到一個表內的欄位里。要確定保存的欄位類型為二進制數組等圖片可用的類型,
然後一般的sql工具都能把圖片變成二進制序列。到時候直接存入的時候存成
2進制
數列就可以。
等取出的時候用二進制流取出然後做成跟文件,然後拼接上原來存入文件的
擴展名
就是你剛才存入的文件。

⑷ 如何向SQL資料庫中插入圖片

一般的圖片是上傳到網站的某個目錄然後把圖片的地址存入資料庫
如果非要存圖片的話,就用讀取文件的形式,讀取圖片的二進制碼
$data
=
addslashes(fread(fopen($form_data,
"r"),
filesize($form_data)));
然後存入資料庫好了。。

⑸ vb加sql的圖片資料庫怎麼弄

'VB/VBA中實現資料庫中的文件存取

'示例資料庫為ACCESS資料庫,用SQL資料庫的話,只需要改連接字元串
'
'*************************************************************************
'**
'** 使用 ADODB.Stream 保存/讀取文件到資料庫
'** 引用 Microsoft ActiveX Data Objects 2.5 Library 及以上版本
'**
'** ----- 資料庫連接字元串模板 ---------------------------------------
'** ACCESS資料庫
'** iConcStr = "Provider=Microsoft.Jet.OLEDB.4.0;Persist Security Info=False" & _
'** ";Data Source=資料庫名"
'**
'** SQL資料庫
'** iConcStr = "Provider=SQLOLEDB.1;Persist Security Info=True;" & _
'** "User ID=用戶名;Password=密碼;Initial Catalog=資料庫名;Data Source=SQL伺服器名"
'**
'*************************************************************************
'
'保存文件到資料庫中
Sub s_SaveFile()
Dim iStm As ADODB.Stream
Dim iRe As ADODB.Recordset
Dim iConcStr As String

'ACCESS資料庫的連接字元串
iConcStr = "Provider=Microsoft.Jet.OLEDB.4.0;Persist Security Info=False" & _
";Data Source=F:\My Documents\客戶資料1.mdb"

'SQL資料庫的連接字元串
iConcStr = "Provider=SQLOLEDB.1;Persist Security Info=True;" & _
"User ID=用戶名;Password=密碼;Initial Catalog=資料庫名;Data Source=SQL伺服器名"
'讀取文件到內容
Set iStm = New ADODB.Stream
With iStm
.Type = adTypeBinary '二進制模式,如果是用text/ntext欄位保存純文本數據,則改用 adTypeText
.Open
.LoadFromFile "c:\test.doc"
End With

'打開保存文件的表
Set iRe = New ADODB.Recordset
With iRe
.Open "表", iConc, adOpenKeyset, adLockOptimistic
.AddNew '新增一條記錄
.Fields("保存文件內容的欄位") = iStm.Read
.Update
End With

'完成後關閉對象
iRe.Close
iStm.Close
End Sub

'從資料庫中讀取數據,保存成文件
Sub s_ReadFile()
Dim iStm As ADODB.Stream
Dim iRe As ADODB.Recordset
Dim iConc As String

'資料庫連接字元串
iConc = "Provider=Microsoft.Jet.OLEDB.4.0;Persist Security Info=False" & _
";Data Source=\\xz\c$\Inetpub\zj\zj\zj.mdb"

'打開表
Set iRe = New ADODB.Recordset
iRe.Open "tb_img", iConc, adOpenKeyset, adLockReadOnly
iRe.Filter = "id=64"

if iRe("img").ActualSize>0 Then

'保存到文件
Set iStm = New ADODB.Stream
With iStm
.Mode = adModeReadWrite
.Type = adTypeBinary '二進制模式,如果是用text/ntext欄位保存純文本數據,則改用 adTypeText
.Open
.Write iRe("img")
.SaveToFile "c:\test.doc"
End With

'關閉對象
iStm.Close
End If

iRe.Close
End Sub

⑹ SQL資料庫如何在表裡插入圖片

圖片保存在資料庫中有兩種方式:
1.看一下欄位的欄位類型,如果是二進制(image)的就要將圖片進行二進制轉換;
2.如果是字元串型(nvarchar)的,則直接保存圖片路徑,然後將圖片拷到那個路徑下即可.
一般圖片都是只存路徑的,存二進制占資料庫空間,會導致資料庫過大

⑺ sql資料庫中如何存放圖片相對路徑(不用代碼)

1、在打開【SQL Server Managemenet Studio】窗口,在【對象資源管理器】窗口依次站看【資料庫】——【新建的資料庫】節點。

⑻ SQL資料庫中如何存儲圖片和讀取

要看你用哪種語言,但是流程都差不多。都是把圖片變成留,然後變成位元組數組,然後再保存到資料庫裡面去。存地址確實是個辦法,但是卻不實用。

⑼ 怎樣把圖片存入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就要注意處理掉不必要的數據。