所属分类:技术资料 来源:www.databasejournal.com 作者:MAK 日期:2004-12-19 20:44:06 阅读次数:     打印本页

上传多个文件到Ms sqlserver的image类型字段


December 14, 2004
Upload multiple files to SQL Server Image column
By Muthusamy Anantha Kumar aka The MAK
翻译:xiaolu

    这篇文章是个上传多个文件到Ms sqlserver的image类型字段的例子,很多办法可以做到,我想介绍的这种方法利用了OSQL.exe和TEXTCOPY.exe工具。 
先决条件:
    a.必须安装了ms sqlsever 2000的客户端工具
    b.sql的用户必须至少是dbowner权限
步骤:
    1.建立upload.bat,内容如下:

@ECHO off
cls
REM ECHO on
REM Objective: To upload all the files in the folder to SQL server as a table
REM Created by: MAK
REM Date: Nov 3, 2004
REM Contact: mak_999@yahoo.com
REM Check parameters
if "%1"=="" Goto noparmErr
if "%1"=="/?" Goto Help

REM assign variables
set Sourcefolder=%1
set servername=%2
set Databasename=%3
set loginname=%4
set password=%5
set LogFile=%6

Date/t > %6
time /t >> %6

REM Export DIR listing to Dirlist.txt
dir %1 /b > Dirlist.txt

OSQL /S%2 /U%4 /P%5 /d%3 /Q "if exists (select * from %3.dbo.sysobjects where id = object_id(N'[Myuploadtable]') and OBJECTPROPERTY(id, N'IsUserTable') = 1) drop table %3.dbo.[Myuploadtable] " >> %6

OSQL /S%2 /U%4 /P%5 /d%3 /Q "create table %3.dbo.Myuploadtable (id varchar(500),ImageFiles Image)" >> %6

FOR /F "usebackq delims==" %%i in (Dirlist.txt) do OSQL /S%2 /U%4 /P%5 /Q "insert into %3.dbo.Myuploadtable (id,ImageFiles) values('%%i',' ') " >> %6


FOR /F "usebackq delims==" %%i in (Dirlist.txt) do textcopy.exe /S%2 /U%4 /P%5 /D%3 /Tmyuploadtable /CImagefiles /F"%1%%i" /I /W"where [id]='%%i'" >> %6

GOTo END2

:noparmErr
Echo Usage help: example as follows
echo ...
Echo Objective: To upload all the files in the folder to SQL server Table 
Echo Created by: MAK
Echo USAGE:
ECHO ....
ECHO ....
Echo %0 SourceFolder Servername Databasename Login Password LogFile
Goto END2


:Help
Echo Usage help: example as follows
echo ...
Echo Objective: To upload all the files in the folder to SQL server Table 
Echo Created by: MAK
Echo USAGE:
ECHO ....
ECHO ....
Echo %0 SourceFolder Servername Databasename Login Password Logfile
Goto END2

:END
Echo "Compare Query results Completed" >>%LogFile%
date/t >> %LogFile%
time/t >> %LogFile%
goto END2

:END2


upload.bat下载

    2.把textcopy.Exe从Microsoft SQL Server\MSSQL\Binn目录拷贝到upload.bat同一目录。
    3.运行upload.bat,参数如下:
点击打开新窗口

      Upload  - bat文件名
      C:\myfiles\  - 所有要传的文件目录(放在一个目录下)
      SQL  - sqlserver的网络名称或者ip地址
      MyDB  - 数据库名(必须存在) 
      sa  - 数据库用户名
      yeahright  - 数据库密码
      x.log  - 本地log文件
点击打开新窗口


Select ID from Myuploadtable
01-2004-08-20-.wav 
Pfizer 12625.doc 
STARTSQL.bat 
status.bat 
STOPSQL.bat 
sysperfinfo.zip
Tech Interview.xls 
Unix.bat 
Taiwan.zip

select * from Myuploadtable
01-2004-08-20-.wav  0x5249464618990A00574
Pfizer 12625.doc 0xD0CF11E0A1B11AE 
STARTSQL.bat 0x6E65742073746F7D 
status.bat 0x6E6574207374617SDF 
STOPSQL.bat 0x6E65742073746FDF 
sysperfinfo.zip 0x5249464618990A00574 
Tech Interview.xls 0xD0CF11E0A1B11AEDF 
Unix.bat 0x6E65742073746F7DER 
Taiwan.zip 0x5249464618990A00DE




  • 上篇文章:PHP 4/5 多个漏洞(2004-12-17 18:46:17)
  • 下篇文章:由http暗藏通道看网络安全(2004-12-22 0:48:01)
  • 相关文章
    PHP+MySQL注入导出文件的新发现2004-12-8 18:24:41
    我收藏的Transact_SQL小手册,适合初学者2004-10-24 11:28:05
    MYSQL常用命令2004-10-20 4:35:43
    SQL数据库备份、还原、转移详解2004-9-26 4:24:34
    浅谈MYSQL跨库查询2004-9-17 13:40:47
    PHP-Nuke 7.4 SQL Injection Exploit2004-9-15 4:41:09
    How to execute system command in MSSQL2004-9-7 22:11:23
    Sql注射总结2004-9-3 23:59:27
    MySql ODBC驱动的使用2004-7-31 22:11:49
    我被SQL关到门外的解决之道2004-7-27 4:03:19


  • 联盟网站→[ 中国黑客联盟  |  网嗅网络 |  泰安铁通  |  小尤格斗界 ]