样通过SQL语句将Image类型字段的内容取出

*--利用 textcopy.exe文件实现在数据库中存储/读取文件

需要textcopy.exe文件,该文件可以在sql 7.0安装光盘找到

--转贴自大力--*/

--建立存取处理的存储过程
if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[sp_textcopy]') and OBJECTPROPERTY(id, N'IsProcedure') = 1)
drop procedure [dbo].[sp_textcopy]
GO

CREATE PROCEDURE sp_textcopy
@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)--I 为存储到数据库,O 从数据库中读出成文件
AS
DECLARE @exec_str varchar (255)
SELECT @exec_str =
        'textcopy /S ' + @srvname +
        ' /U ' + @login +
        ' /P ' + @password +
        ' /D ' + @dbname +
        ' /T ' + @tbname +
        ' /C ' + @colname +
        ' /W "' + @whereclause +
        '" /F"' + @filename +
        '" /' + @direction
EXEC master..xp_cmdshell @exec_str 
go

--调用示例:
--1.创建示例表和初始化数据
create table tb(id int,img image)
insert tb
select 1,0x
union all select 2,0x
go

--2.将文件保存到数据库中
declare @srv varchar(255),@db sysname,@tb sysname,@col sysname
select @srv=@@servername--服务器名
,@db=db_name()--数据库名
,@tb='tb'--表名
,@col='img'--列名
exec sp_textcopy @srv,'sa','sa的密码',@db,@tb,@col,'c:/test.jpg','where id=1','I'--保存到id=1的记录中,注意条件是:id=1
exec sp_textcopy @srv,'sa','sa的密码',@db,@tb,@col,'c:/test.doc','where id=2','I'--保存到id=2的记录中,注意条件是:id=2

--3.从数据库中读出保存为文件
exec sp_textcopy @srv,'sa','sa的密码',@db,@tb,@col,'c:/test.jpg','where id=1','O'--读出id=1的记录,注意条件是:id=1
exec sp_textcopy @srv,'sa','sa的密码',@db,@tb,@col,'c:/test.doc','where id=2','O'--读出id=2的记录,注意条件是:id=2

--删除测试环境
drop table tb
if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[sp_textcopy]') and OBJECTPROPERTY(id, N'IsProcedure') = 1)
drop procedure [dbo].[sp_textcopy]

*************************************************************************
'**
'** 使用 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
   
    '数据库连接字符串
    iConcStr = "Provider=Microsoft.Jet.OLEDB.4.0;Persist Security Info=False" & _
        ";Data Source=F:/My Documents/客户资料1.mdb"
   
    '读取文件到内容
    Set iStm = New ADODB.Stream
    With iStm
        .Type = adTypeBinary    '二进制模式
        .Open
        .LoadFromFile "c:/test.word"
    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=F:/My Documents/客户资料1.mdb"
   
    '打开表
    Set iRe = New ADODB.Recordset
    iRe.Open "表", iConc, adOpenKeyset, adLockReadOnly
   
    '保存到文件
    Set iStm = New ADODB.Stream
    With iStm
        .Mode = adModeReadWrite
        .Type = adTypeBinary
        .Open
        .Write iRe("保存文件内容的字段")
        .SaveToFile "c:/test.word"
    End With
   
    '关闭对象
    iRe.Close
    iStm.Close
End Sub

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 ASP.NET 中,可以使用以下步骤将 FileUpload 控件中的图像和其他信息保存到 SQL Server 数据库中的 image 字段中: 1. 设置数据库连接字符串。 2. 在 ASP.NET 页面中添加 FileUpload 控件和其他输入控件(如文本框)来获取其他信息。 3. 在服务器端代码中,使用 FileUpload 控件的 SaveAs 方法将图像保存到服务器上的某个文件夹中。 4. 使用 System.IO.File 类的 ReadAllBytes 方法将保存的图像读入字节数组中。 5. 创建 SQL Server 数据库连接并打开连接。 6. 创建 SQL INSERT 语句,将图像字节数组和其他信息插入到数据库中的 image 字段中。 7. 执行 SQL INSERT 语句并关闭数据库连接。 以下是一个示例代码: ```csharp protected void btnSubmit_Click(object sender, EventArgs e) { // 获取文件名和扩展名 string fileName = Path.GetFileName(FileUpload1.PostedFile.FileName); string fileExtension = Path.GetExtension(FileUpload1.PostedFile.FileName); // 保存文件到服务器上的某个文件夹中 string filePath = Server.MapPath("~/Images/") + fileName; FileUpload1.SaveAs(filePath); // 读入图像字节数组 byte[] imageData = File.ReadAllBytes(filePath); // 获取其他信息 string name = txtName.Text; string description = txtDescription.Text; // 创建数据库连接 using (SqlConnection connection = new SqlConnection("your_connection_string_here")) { // 打开连接 connection.Open(); // 创建 SQL INSERT 语句 string sql = "INSERT INTO MyTable (Name, Description, ImageData) VALUES (@Name, @Description, @ImageData)"; // 创建 SqlCommand 对象 using (SqlCommand command = new SqlCommand(sql, connection)) { // 添加参数 command.Parameters.AddWithValue("@Name", name); command.Parameters.AddWithValue("@Description", description); command.Parameters.AddWithValue("@ImageData", imageData); // 执行 SQL INSERT 语句 command.ExecuteNonQuery(); } // 关闭连接 connection.Close(); } } ``` 请注意,此示例代码仅供参考。您需要根据自己的实际情况对其进行修改。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值