create table Employees
(
EmpId varchar(3) Primary Key,
EmpName varchar(10) not null,
EmpSex varchar(6) not null,
EmpBirthday DateTime not null,
EmpPostCode varchar(6) not null,
EmpAddress varchar(20),
EmpPhoto image,
EmpUpdate datetime
)
我要创建一个员工表,怎么在建表的时候把图片也加上去?

解决方案 »

  1.   


    CREATE TABLE myTable(FileName nvarchar(60), 
      FileType nvarchar(60), Document varbinary(max))
    GOINSERT INTO myTable(FileName, FileType, Document) 
       SELECT 'Test.jpg' AS FileName, 
          '.txt' AS FileType, 
          * FROM OPENROWSET(BULK N'C:\Test.jpg', SINGLE_BLOB) AS Document參照
      

  2.   

    用存储过程方法:
    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
    go3、读入
    sp_textcopy '你的服务器名','sa','你的密码','库名','表名','image列名','c:\图片.bmp','where 编号=1','I' --注意条件是 编号=1sp_textcopy '你的服务器名','sa','你的密码','库名','表名','image列名','c:\bb.doc','where 编号=2','I' --注意条件是 编号=2go4、读出成文件
    sp_textcopy '你的服务器名','sa','你的密码','库名','表名','image列名','c:\图片.bmp','where 编号=1','O' --注意条件是 编号=1sp_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
      

  3.   

    http://www.cnblogs.com/hobe/archive/2008/08/14/1267844.html
      

  4.   

    update dbo.BIZ_RPTTL_PTN_M set
    RPTTL_M_RPT_IMG =
    (SELECT * FROM
     OPENROWSET 
        (BULK 'C:\setup.bmp', single_blob) AS a) where RPTTL_M_ID=20080725 INSERT INTO dbo.PlayerList
    (score)
    SELECT * FROM
     OPENROWSET 
        (BULK 'E:\MyDoc\My Pictures\pic\1.jpg', single_blob) AS a SQL Server 2005 的 OPENROWSET 函数能够一次就完成远程数据的连结与存取作业。需要注意的是'C:\setup.bmp'等这些路径是DB服务器上的文件路径,不是客户端的路径。
      

  5.   

    我记得把数据类型设置为binnery就可以直接存入了。