SqlServer 使用T-SQL单纯的复制表数据

今天用Sql Server Manager Studio 先复制一个库建立一个新库出来,各种报错,也不知道是为什么,连备份再还原都不行,算了,自己写个SQL 脚本来执行算了......

坏处是视图,存储过程和函数都没有复制过来

复制代码
-- 设置源数据库和目标数据库的名称
DECLARE @SourceDBName NVARCHAR(128) = 'BestraneConnect';
DECLARE @TargetDBName NVARCHAR(128) = 'BestraneConnect_AppConfig';
DECLARE @SQL NVARCHAR(MAX);

-- 判断目标数据库是否存在,如果存在则删除
IF DB_ID(@TargetDBName) IS NOT NULL
BEGIN
-- 将目标数据库设置为单用户模式,并回滚挂起的事务
SET @SQL = 'ALTER DATABASE ' + QUOTENAME(@TargetDBName) + ' SET SINGLE_USER WITH ROLLBACK IMMEDIATE;';
EXEC sp_executesql @SQL;

-- 删除目标数据库
SET @SQL = 'DROP DATABASE ' + QUOTENAME(@TargetDBName) + ';';
EXEC sp_executesql @SQL;
END

-- 创建目标数据库
SET @SQL = 'CREATE DATABASE ' + QUOTENAME(@TargetDBName) + ';';
EXEC sp_executesql @SQL;

-- 生成动态 SQL 语句,自动复制源数据库的所有表的结构到目标数据库
SET @SQL = '';

SELECT @SQL = @SQL +
'SELECT * INTO ' + QUOTENAME(@TargetDBName) + '.dbo.' + QUOTENAME(t.name) +
' FROM ' + QUOTENAME(@SourceDBName) + '.dbo.' + QUOTENAME(t.name) + ';'
FROM sys.tables t
WHERE t.type = 'U';

-- 执行动态 SQL 语句
EXEC sp_executesql @SQL;
相关推荐
Tapdata1 小时前
《实时分析市场报告 2025》上线 | 从批处理到实时洞察,2025 年全球实时分析市场全景解读
数据库
海梨花2 小时前
【从零开始学习Redis】项目实战-黑马点评D2
java·数据库·redis·后端·缓存
代码的余温3 小时前
SQL性能优化全攻略
数据库·mysql·性能优化
手把手入门5 小时前
★CentOS:MySQL数据备份
数据库·mysql·adb
SelectDB6 小时前
5000+ 中大型企业首选的 Doris,在稳定性的提升上究竟花了多大的功夫?
大数据·数据库·apache
路多辛6 小时前
Golang database/sql 包深度解析(二):连接池实现原理
数据库·sql·golang
SimonKing6 小时前
Mybatis批量插入,形式不同性能也不同
数据库·后端·程序员
杰克尼7 小时前
MYSQL-175. 组合两个表
数据库·mysql
DemonAvenger7 小时前
MySQL索引原理深度解析与优化策略实战
数据库·mysql·性能优化
189228048618 小时前
NY270NY273美光固态闪存NY277NY287
服务器·网络·数据库·科技·性能优化