如何读取MS Word文件名称和内容,并记录到数据库中

小兽 2004-10-13 04:03:46
如题····
...全文
195 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
laoQ 2004-11-13
  • 打赏
  • 举报
回复
刚好想找这这方面的资料,,,
顶了。。。
UP。
1unknow 2004-11-13
  • 打赏
  • 举报
回复
我也遇到了同样的问题,我做的是通过点击treeview里的节点,显示不同的word文档里的内容,
那么我这里有大量的word的文档,怎么把他们导入到sqlserver的库里面去呢,难道先开发一个
前台程序,一个一个的导入吗,MSSQLServer自己不能导入吗????
达人所说textcopy.exe的导入导出能实现我的要求吗!!!
Functions 2004-10-15
  • 打赏
  • 举报
回复
什么编程语言?我会PB & VB,都可以实现。
zlp321002 2004-10-14
  • 打赏
  • 举报
回复
也可以用全文检索
小兽 2004-10-14
  • 打赏
  • 举报
回复
是啊··当然不是直接通过SQLServer,就是想做这么一个应用程序,通过它读取一些word文档,并将文件名称和内容转存到数据库中··
Functions 2004-10-13
  • 打赏
  • 举报
回复
yjdn(无尽天空) 的方法很好,可以解决我的一个问题。呵呵~~~

不过楼主,你不会是直接通过MSSQLServer来实现你的要求吧?数据库一般作为后台数据存储,很少作为前台应用程序的。如果你使用什么编成语言来开发应用程序,一般都可以使用OLE Object对象来打开word文档。
小兽 2004-10-13
  • 打赏
  • 举报
回复
能不能做这样一个东西:
批量导入word文档,然后把文档名字和内容分别保存在不同的字段里面···
yjdn 2004-10-13
  • 打赏
  • 举报
回复
上面的办法可以保存很多种格式的文件。textcopy.exe可以在安装盘中找到
你可以直接运行textcopy.exe看一下效果,输入参数,直接用textcopy.exe也可以导入导出
yjdn 2004-10-13
  • 打赏
  • 举报
回复
把word整个文件保存到字段中倒是可以
或者,你在程序中,把word读到一个文本框,然后再保存到数据库
下面是一个保存word文件的例子
/*--利用 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' --列名
sp_textcopy @srv,'sa','sa的密码',@db,@tb,@col,'c:\test.jpg','where id=1','I' --保存到id=1的记录中,注意条件是:id=1
sp_textcopy @srv,'sa','sa的密码',@db,@tb,@col,'c:\test.doc','where id=2','I' --保存到id=2的记录中,注意条件是:id=2

--3.从数据库中读出保存为文件
sp_textcopy @srv,'sa','sa的密码',@db,@tb,@col,'c:\test.jpg','where id=1','O' --读出id=1的记录,注意条件是:id=1
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]
simonyou 2004-10-13
  • 打赏
  • 举报
回复
我也想知道

34,594

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧