none
SQL2000,SQL2005中怎样在表中插入Text,image数据 RRS feed

答案

  • Text-- 直接用当字符串输入操作就行了
    image--是SQL05之前的版本時使用的類型
    直接操作,在SQL05以上版本用varbinary(max)--類型

    以插入圖片為例:
    SQL2000用
    方法:
    1、建立过程
    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)) 
    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  
    
    2、建表和初始化数据
    create table 表名 (编号 int,image列名 image)
    go
    insert 表名 values(1,0x)    -- 必须的,且不是null
    insert 表名 values(2,0x)    -- 必须的,且不是null
    go
    
    3、读入
    sp_textcopy '你的服务器名','sa','你的密码','库名','表名','image列名','c:\图片.bmp','where 编号=1','I' --注意条件是 编号=1
    
    sp_textcopy '你的服务器名','sa','你的密码','库名','表名','image列名','c:\bb.doc','where 编号=2','I' --注意条件是 编号=2
    
    go
    
    4、读出成文件
    sp_textcopy '你的服务器名','sa','你的密码','库名','表名','image列名','c:\图片.bmp','where 编号=1','O' --注意条件是 编号=1
    
    sp_textcopy '你的服务器名','sa','你的密码','库名','表名','image列名','c:\bb.doc','where 编号=2','O' --注意条件是 编号=2
    go
    
    ************如果报textcopy不是可执行文件的话,你就到
    C:\Program Files\Microsoft SQL Server\MSSQL\Binn
    目录下拷备 textcopy.exe到:
    C:\Program Files\Microsoft SQL Server\80\Tools\Binn
    
    SQL2005直接用
    INSERT INTO myTable(FileName, FileType, Photo) 
       SELECT 'Roy1.jpg' AS FileName, 
          '.JPG' AS FileType, 
          * FROM OPENROWSET(BULK N'C:\Roy1.jpg', SINGLE_BLOB) AS Document 
    

    ROY WU(吳熹 )
    2010年2月22日 15:50
    版主

全部回复

  • Take look at textcopy in books online.
    2010年2月22日 2:12
  • 直接 isnert 就好了嘛

    insert tb(text列, image 列)
    values('内容', 0x123)

    2010年2月22日 4:06
  • Depends, can't insert file that way.
    2010年2月22日 4:19
  • 你好,我明白你要的是什么

    以图片为例子,看下面的代码
     private void btnUpload_Click(object sender, System.EventArgs e)
            {
                SqlConnection con=new SqlConnection("server=.;database=pubs;uid=sa;pwd=;");
                con.Open();
                FileStream fs=File.Open(this.File1.PostedFile.FileName,FileMode.Open); //获得Post图片
                byte[] by=new byte[fs.Length];
                fs.Read(by,0,(int)fs.Length); //读到字节数组
                String SqlCmd = "insert into ImageStore(ImageData,ImageContentType,ImageDescription,ImageSize) values(@Image,@fileType,@fileDec,@fileSize)";
                SqlCommand CmdObj = new SqlCommand(SqlCmd, con);
                CmdObj.Parameters.Add("@Image",SqlDbType.Image, (int)fs.Length).Value = by;
                CmdObj.Parameters.Add("@fileType",SqlDbType.VarChar,20).Value=this.File1.PostedFile.ContentType;
                CmdObj.Parameters.Add("@fileDec",SqlDbType.VarChar,200).Value=this.txtDescript.Text;
                CmdObj.Parameters.Add("@fileSize",SqlDbType.BigInt).Value=this.File1.PostedFile.ContentLength;
                fs.Close();
                CmdObj.ExecuteNonQuery();
                dataGridBind();
            }

    ImageData 的数据库类型是Image 类型的
    希望对你有帮助




    我们要把爱心传递给更多需要帮助的人。
    微软(黑龙江).Net俱乐部:http://hlj.cnblogs.com
    博客:http://terryfeng.cnblogs.com
    微博:http://t.sina.com.cn/terryfeng
    个人:http://www.terryfeng.com
    2010年2月22日 9:28
  • 你要通过程序,否则在维护数据里面的字段后面有个小按钮,点完了,可以选择图片,看看行不





    我们要把爱心传递给更多需要帮助的人。
    微软(黑龙江).Net俱乐部:http://hlj.cnblogs.com
    博客:http://terryfeng.cnblogs.com
    微博:http://t.sina.com.cn/terryfeng
    个人:http://www.terryfeng.com
    2010年2月22日 9:30
  • Text-- 直接用当字符串输入操作就行了
    image--是SQL05之前的版本時使用的類型
    直接操作,在SQL05以上版本用varbinary(max)--類型

    以插入圖片為例:
    SQL2000用
    方法:
    1、建立过程
    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)) 
    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  
    
    2、建表和初始化数据
    create table 表名 (编号 int,image列名 image)
    go
    insert 表名 values(1,0x)    -- 必须的,且不是null
    insert 表名 values(2,0x)    -- 必须的,且不是null
    go
    
    3、读入
    sp_textcopy '你的服务器名','sa','你的密码','库名','表名','image列名','c:\图片.bmp','where 编号=1','I' --注意条件是 编号=1
    
    sp_textcopy '你的服务器名','sa','你的密码','库名','表名','image列名','c:\bb.doc','where 编号=2','I' --注意条件是 编号=2
    
    go
    
    4、读出成文件
    sp_textcopy '你的服务器名','sa','你的密码','库名','表名','image列名','c:\图片.bmp','where 编号=1','O' --注意条件是 编号=1
    
    sp_textcopy '你的服务器名','sa','你的密码','库名','表名','image列名','c:\bb.doc','where 编号=2','O' --注意条件是 编号=2
    go
    
    ************如果报textcopy不是可执行文件的话,你就到
    C:\Program Files\Microsoft SQL Server\MSSQL\Binn
    目录下拷备 textcopy.exe到:
    C:\Program Files\Microsoft SQL Server\80\Tools\Binn
    
    SQL2005直接用
    INSERT INTO myTable(FileName, FileType, Photo) 
       SELECT 'Roy1.jpg' AS FileName, 
          '.JPG' AS FileType, 
          * FROM OPENROWSET(BULK N'C:\Roy1.jpg', SINGLE_BLOB) AS Document 
    

    ROY WU(吳熹 )
    2010年2月22日 15:50
    版主