当前位置:首页 » 编程语言 » sql照片怎么导出来
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

sql照片怎么导出来

发布时间: 2022-08-29 02:33:27

Ⅰ 如何从sql中导出照片

在MS SQL SERVER 安装目录下有个可执行文件叫 TEXTCOPY.EXE
可对 MS SQL SERVER 中的文本或图像数据进行输入输出.
不过你可以在MS-DOS方式下执行text /? 得到它的描述。
下面是这个工具的描述:
Copies a single text or image value into or out of SQL Server. The val
ue
is a specified text or image 'column' of a single row (specified by th
e
"where clause") of the specified 'table'.

If the direction is IN (/I) then the data from the specified 'file' is

copied into SQL Server, replacing the existing text or image value. If
the
direction is OUT (/O) then the text or image value is copied from
SQL Server into the specified 'file', replacing any existing file.

TEXTCOPY [/S ][sqlserver]] [/U [login]] [/P ][password]]
[/D ][database]] [/T table] [/C column] [/W"where clause"]
[/F file] [{/I | /O}] [/K chunksize] [/Z] [/?]

/S sqlserver The SQL Server to connect to. If 'sqlserver' is n
ot
specified, the local SQL Server is used.
/U login The login to connect with. If 'login' is not spec
ified,
a trusted connection will be used.
/P password The password for 'login'. If 'password' is not
specified, a NULL password will be used.
/D database The database that contains the table with the tex
t or
image data. If 'database' is not specified, the d
efault
database of 'login' is used.
/T table The table that contains the text or image value.

/C column The text or image column of 'table'.
/W "where clause" A complete where clause (including the WHERE keyw
ord)
that specifies a single row of 'table'.
/F file The file name.
/I Copy text or image value into SQL Server from 'fi
le'.
/O Copy text or image value out of SQL Server into '
file'.
/K chunksize Size of the data transfer buffer in bytes. Minimu
m
value is 1024 bytes, default value is 4096 bytes.

/Z Display debug information while running.
/? Display this usage information and exit.

You will be prompted for any required options you did not specify.

为此, 可写一个存储过程,调用这个命令
CREATE PROCEDURE sp_text (
@srvname varchar (30),
@login varchar (30),
@password varchar (30),
@dbname varchar (30),
@tbname varchar (30),
@colname varchar (30),
@filename varchar (30),
@whereclause varchar (40),
@direction char(1))
AS
DECLARE @exec_str varchar (255)
SELECT @exec_str =
'text /S ' + @srvname +
' /U ' + @login +
' /P ' + @password +
' /D ' + @dbname +
' /T ' + @tbname +
' /C ' + @colname +
' /W "' + @whereclause +
'" /F ' + @filename +
' /' + @direction
EXEC master..xp_cmdshell @exec_str

下面是一个拷贝图像到SQL Server的pubs数据库的例子, 表名pub_info, 字段名
logo,图像文件名picture.bmp,保存到pub_id='0736'记录 sp_text @srvn
ame = 'ServerName',
@login = 'Login',
@password = 'Password',
@dbname = 'pubs',
@tbname = 'pub_info',
@colname = 'logo',
@filename = 'c:\picture.bmp',
@whereclause = " WHERE pub_id='0736' ",
@direction = 'I'
你看看 调用成拷贝就行

Ⅱ 怎样把SQL数据库里的图片导出到指定的文件夹

首先可以还原或附加这个数据库的备份,然后就找到存放图片的字段读出来,
通过。net、java等语言编程的程序读出这个字段的数据保存到文件夹就OK了.

Ⅲ 导出sql2005 数据库中的jpg格式图片导出

使用asp代码导出,数据库中的二进制图片导出为本地JPG图片
此方法可以把以二进制存储在数据库中的图片通过ADODB.Stream以图片格式保存到电脑硬盘中,非常实用且精典,值得收藏!
<%
db="img.mdb"
Set conn = Server.CreateObject("ADODB.Connection")
connstr="Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" & Server.MapPath(""&db&"")
conn.Open connstr
set rs=server.createobject("ADODB.recordset")
sql="select * from img"
rs.open sql,conn,1,1
do while not rs.eof
call SaveToFile(rs("pic"),rs("id")&".gif")
rs.movenext
loop
rs.close
set rs=nothing
set conn=nothing

Sub SaveToFile(ByVal strBody,ByVal Filename)
'***********************
'存储内容到文件
'by 天涯才 QQ:23969
'[email protected]
'2005-08-11
'winXP+IIS5.5测试通过
'***********************
Dim objStream
Set objStream = Server.CreateObject("ADODB.Stream")
If Err.Number=-2147221005 Then
Response.Write "<div align='center'>非常遗憾,您的主机不支持ADODB.Stream,不能使用本程序</div>"
Err.Clear
Response.End
End If
With objStream
.Type = 2
.Open
.Position = objStream.Size
.WriteText = strBody
.SaveToFile Server.MapPath(Filename),2
.Close
End With
Set objStream = Nothing
End Sub
%>

注意:后来用PS打不开,报错。而且用IE也不识别。
解决的办法:用ACDSee 打开,选中图片右键=>转换=>在框内选择JPG格式=>确定即可!

Ⅳ 导出sql照片

ASP

此方法可以把以二进制存储在数据库中的图片通过ADODB.Stream以图片格式保存到电脑硬盘中,非常实用且精典,值得收藏!

<%
db="img.mdb"
Set conn = Server.CreateObject("ADODB.Connection")
connstr="Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" & Server.MapPath(""&db&"")
conn.Open connstr
set rs=server.createobject("ADODB.recordset")
sql="select * from img"
rs.open sql,conn,1,1
do while not rs.eof
call SaveToFile(rs("pic"),rs("id")&".gif")
rs.movenext
loop
rs.close
set rs=nothing
set conn=nothing

Sub SaveToFile(ByVal strBody,ByVal Filename)
'***********************
'存储内容到文件

'winXP+IIS5.5测试通过
'***********************
Dim objStream
Set objStream = Server.CreateObject("ADODB.Stream")
If Err.Number=-2147221005 Then
Response.Write "<div align='center'>非常遗憾,您的主机不支持ADODB.Stream,不能使用本程序</div>"
Err.Clear
Response.End
End If
With objStream
.Type = 2
.Open
.Position = objStream.Size
.WriteText = strBody
.SaveToFile Server.MapPath(Filename),2
.Close
End With
Set objStream = Nothing
End Sub
%>

注意:后来用PS打不开,报错。

而且用IE也不识别。

解决的办法:

用ACDSee 打开,选中图片右键=>转换=>在框内选择JPG格式=>确定即可!

Ⅳ SQL导出图片问题

Dim conn As SqlConnection = New SqlConnection
conn.ConnectionString = "data source=your ip address,port; network library=dbmssocn; initial catalog=your database name;password=your password; user id=your user id;"
conn.Open()
Dim cmd As SqlCommand = New SqlCommand
cmd.CommandText = "select id, imagedata from yourTableName"
cmd.CommandType = CommandType.Text
cmd.Connection = conn
Dim dr As SqlDataReader
dr = cmd.ExecuteReader()
Dim b As Byte()
Dim id As Integer
Dim filename As String = "d:\{0}.jpg"
While dr.Read()
id = dr.Item("id").ToString()
b = dr.Item("imagedata")
Dim stream As New System.IO.MemoryStream
Dim image As System.Drawing.Image
stream.Write(b, 0, b.Length)
image = System.Drawing.Image.FromStream(stream)
image.Save(String.Format(filename, id))
End While
dr.Close()
conn.Close()

Ⅵ 如何sql语句把sql2005中的图片导出,请高手帮帮忙写个SQL语句。表名hr_hi_person,图片字段mpicture 。

图片存放的数据库是二进制的。通过SQL无法导出成图片。需要在程序里面转换。
resultset rs=con.openresult(" select mpicture fromm hr_hi_person");
while(rs.next){
image a=image.frombyte(rs.getstring(1).getbytes());

}

大概是这样,记得不是很清楚

Ⅶ 怎么把sql数据中的二进制图片批量导出到本地啊,有木有工具,求大神发个来邮箱:[email protected]

一般情况下,图片是以文件的形式保存在计算机上而非数据库的表字段中,数据库只是保存了该文件的索引,所以,你可以直接登录服务器将文件复制回来。

Ⅷ 怎么样批量导出sql数据库中的图片

  1. 打开数据库SQL server ,右击数据库选择“任务” “生成脚本

  2. 选择你要导出的数据库,点击下一步

  3. 将编写数据脚本选项选择为true,点击下一步

  4. 选择表,点击下一步

  5. 选择你要导出表的数据

  6. 选择将脚本保存到“新建查询”窗口,点击下一步,

  7. 点击完成,之后就不要操作,直到生成脚本成功后,点击关闭按钮。

  8. 只要在其他数据库中直接运行,同样的一张表就在另一个数据库中生成了。

Ⅸ 求助:如何将SQL里面的image字段导出到EXCEL显示为图片

image列以二进制的形式存储的,sql不能实现直接显示在EXCEL中,一般要通过程序开发语言在前端实现;
但可以考虑以html格式保存,这样image上传到了服务器端,这样直接复制到excel是可以显示html页面的。