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;
相关推荐
时差9539 分钟前
【面试题】Hive 查询:如何查找用户连续三天登录的记录
大数据·数据库·hive·sql·面试·database
让学习成为一种生活方式11 分钟前
R包下载太慢安装中止的解决策略-R语言003
java·数据库·r语言
秋意钟37 分钟前
MySQL日期类型选择建议
数据库·mysql
Dxy12393102161 小时前
python下载pdf
数据库·python·pdf
桀桀桀桀桀桀2 小时前
数据库中的用户管理和权限管理
数据库·mysql
superman超哥3 小时前
04 深入 Oracle 并发世界:MVCC、锁、闩锁、事务隔离与并发性能优化的探索
数据库·oracle·性能优化·dba
用户8007165452003 小时前
HTAP数据库国产化改造技术可行性方案分析
数据库
engchina4 小时前
Neo4j 和 Python 初学者指南:如何使用可选关系匹配优化 Cypher 查询
数据库·python·neo4j
engchina4 小时前
使用 Cypher 查询语言在 Neo4j 中查找最短路径
数据库·neo4j
尘浮生4 小时前
Java项目实战II基于Spring Boot的光影视频平台(开发文档+数据库+源码)
java·开发语言·数据库·spring boot·后端·maven·intellij-idea