我的数据库是sql2008格式的,怎么做才能在SQL2005中也能打开啊
我试了备份和直接附加数据库源文件的方法都不行。大家有什么好办法啊

解决方案 »

  1.   

    --参考2005 到2000的 差不多
    2005转到2000的步骤步骤 
    1. 生成for 2000版本的数据库脚本 
    2005 的manger studio 
    -- 打开"对象资源管理器"(没有的话按F8), 连接到你的实例 
    -- 右键要转到2000的库 
    -- 任务 
    -- 生成脚本 
    -- 在"脚本向导"的"选择数据库"中, 确定选择的是要转到2000的库 
    -- 勾选"为所选数据库中的所有对象编写脚本" 
    -- 在接下来的"选择脚本选项"中, 找到"为服务器版本编写脚本"项, 选择"SQL Server 2000" 
    -- 其他选项根据需要设置 
    -- 最后把脚本保存到一个 .sql 脚本文件 2. 在2000中创建目标数据库 
    在查询分析器(或2005的manger studio在打开脚本文件), 连接到SQL Server 2000,执行上面生成的脚本.以创建一个新的数据库 3. 将数据从2005导到2000 
    2005 的manger studio 
    -- 打开"对象资源管理器"(没有的话按F8), 连接到你的实例 
    -- 右键要转到2000的库 
    -- 任务 
    -- 导出数据 
    -- 在"SQL Server 导入和导出向导"的"选择数据源"步骤中, 确定选择的是要导出的数据库 
    -- 在"选择目标"步骤中, 连接到 2000, 并选择步骤2新建的库 
    -- 在"选择源表和源视图"中, 选择所有的表 
    -- 最后完成 
      

  2.   

    ****************************************************************************
     软件名称: May Flower Erp
     版权所有: (C) 2005-2006 May Flower ERP 开发组
     功能描述: 获取指定表的创建脚本,包括表和字段的属性、外键(注释掉的)
    ----------------------------------------------------------------------------
     参数列表: 
            1: @TableName 需要创建脚本的表的名称
    ****************************************************************************
    |</PRE>*/
    CREATE PROCEDURE [dbo].[sp_HelpTable](@TableName sysname)
    AS
      SET NOCOUNT ON
      DECLARE @ObjectID int
      DECLARE @TableScript table(Iden int IDENTITY(1, 1), ScriptLine nvarchar(4000))
      SET @ObjectID = object_id(@TableName)
      IF @ObjectID IS NULL OR OBJECTPROPERTY(@ObjectID, 'IsTable') = 0
      BEGIN
        RAISERROR('指定的对象不是表对象', 16, 1)
        RETURN
      END 
      --获取表的创建脚本
      --插入表头
      INSERT INTO @TableScript(ScriptLine)
        SELECT N'CREATE TABLE [' + USER_NAME(OBJECTPROPERTY(@ObjectID, N'OwnerId')) + N'].[' + object_name(@ObjectID) + N']('  --插入字段
      INSERT INTO @TableScript(ScriptLine)
        SELECT N'  [' + a.Name + N'] [' + b.name + N']' + 
               CASE WHEN c.Object_id IS NOT NULL THEN N' IDENTITY(' + CONVERT(nvarchar, c.seed_value) + N', ' + CONVERT(nvarchar, c.increment_value) + N')' 
                    ELSE '' END +
               CASE WHEN b.xusertype IN (167, 175, 231, 239) THEN N'('+CONVERT(nvarchar, a.prec)  + N')'
                    WHEN b.xusertype in (106, 108)           THEN N'('+CONVERT(nvarchar, a.xprec) + N', ' + CONVERT(nvarchar, a.xscale) + N')'
                    ELSE '' END +
               CASE a.isnullable WHEN 1 THEN N'' ELSE N' NOT' END + N' NULL' +
               CASE WHEN d.Name IS NOT NULL THEN N' DEFAULT ' + d.Definition ELSE N'' END +
               N',' 
          FROM sys.syscolumns a
            LEFT JOIN sys.systypes b ON a.xusertype = b.xusertype
            LEFT JOIN sys.identity_columns c ON c.Object_id = a.ID AND c.Column_ID = a.ColID
            LEFT JOIN sys.default_constraints d ON d.Parent_Object_ID = a.ID AND d.Parent_column_ID = a.ColID
        WHERE a.[ID] = @ObjectID
        ORDER BY a.ColOrder  --插入主键和索引
      DECLARE @IndexID int, @IndexScript nvarchar(4000)
      DECLARE IndexCursor CURSOR FOR 
        SELECT b.Index_ID, N'  CONSTRAINT [' + a.Name + N'] ' + 
               CASE a.Type WHEN 'PK' THEN N'PRIMARY KEY ' WHEN 'UQ' THEN N'UNIQUE ' END + 
               CASE b.Type WHEN 1    THEN N'CLUSTERED'   WHEN 2     THEN N'NONCLUSTERED ' END + N'('
          FROM sys.key_constraints a
            LEFT JOIN sys.indexes b ON b.Object_ID = a.Parent_Object_ID AND b.index_id = a.unique_index_id
        WHERE a.Parent_Object_ID = @ObjectID
      OPEN IndexCursor
      FETCH NEXT FROM IndexCursor INTO @IndexID, @IndexScript
      WHILE @@FETCH_STATUS = 0
      BEGIN
        SELECT @IndexScript = @IndexScript + N'[' + INDEX_COL(object_name(@ObjectID), 2 , 1) + N'],'
          FROM sys.index_columns 
        WHERE Object_ID = @ObjectID
          AND Index_ID = 2
        
        SET @IndexScript = LEFT(@IndexScript, LEN(@IndexScript) -1) + N'),'
        INSERT INTO @TableScript(ScriptLine) VALUES(@IndexScript)
        FETCH NEXT FROM IndexCursor INTO @IndexID, @IndexScript
      END
      Close IndexCursor
      DEALLOCATE IndexCursor  insert into @TableScript(ScriptLine) VALUES(')')
      select * from @TableScript 本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/fredrickhu/archive/2009/10/14/4669511.aspx
      

  3.   

    谢谢大家,不过这个也没有办法把SQL 2008的表中的数据导出到SQL2005中啊
      

  4.   

    1.在sql2008生成脚本.
    2.在sql2005中利用这些脚本进行创建.
    3.在sql2008中利用导入导出工具把数据导进sql2005中.