【Sql Server】创建表模拟批量添加数据以及添加的方式

本文涉及的产品
云数据库 RDS SQL Server,基础系列 2核4GB
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
简介: 在实际项目场景中,需要快速模拟大批量数据进行查询测试基于这个需求,模拟大数据方式有很多,这里简答的写几个中在数据库模拟大数据的方式
  • 主要知识点列表
编号 语言或插件 知识点 说明
1 sql server create table 关键词,创建表
2 sql server indentity 自增长函数
3 sql server primary key 设置主键标识

【创建表】

1)sql语句创建表的关键词为,create table,需要主要顺序,容易把数据类型和字段名写反了

格式为:create table + 表名
(
    字段名 数据类型 自增函数 主键关键词,
    字段名 数据类型,
    ...
)

2)indentity(种子-起始值,增量) - 自增长函数

放在字段里,一般用于整型,能够灵活设置自增长的起始值以及增长的基础,此处1,1,表示记录从1开始,每次加1,如果设置的是indentity(168000,2),记录ID值从168000开始,每次添加一条记录就加2

3)primary key - 主键标识

放在主键后面,表示当前字段为表的唯一主键

4)代码如下

create table TempTest
(
    id int identity(168000,2) primary key,
    guid_value varchar(50),
    create_time datetime 
)

5)判断当前表是否存在

通过上篇文章,我们已经知道怎么查询临时表是否存在,那么是不是也同样适用普通表呢,通过下图可以知道,是可以的,因为object_d是判断对象是否存在,类比应该也是适用用来判断存储过程和视图是否存在,感兴趣的可以尝试下

image.png

if object_id('TempTest') is not null begin
    print('存在')
end
else begin
    print('不存在')
end

【添加表记录】

1、普通常见的添加操作 - insert into values

insert into 表名(字段名1,字段名2,...)
values(字段名1,字段名2,...)

image.png

insert into TempTest(guid_value,create_time)
values(newid(),getdate())

insert into TempTest(guid_value,create_time)
values(newid(),getdate())

insert into TempTest(guid_value,create_time)
values(newid(),getdate())

image.png

2、此处可以有个小技巧,上面的可以改为,只写一次insert into和values,值写多个,如下

image.png

insert into TempTest(guid_value,create_time) values
(newid(),getdate()),
(newid(),getdate()),
(newid(),getdate()),
(newid(),getdate()),
(newid(),getdate()),
(newid(),getdate())

3、在添加数据的同时创建表

适合数据库还没有创建表的情况,可以重名表名以及自定义表字段,但是必须是from表里有的字段,可以全表字段添加也可以筛选需要的字段

需要注意,此操作只会把字段基础信息添加进来,自增长也会带过来,主键不会

select id,guid_value into TempTest_two from TempTest

image.png

image.png

4、已经存在表的情况下 - insert into select

  • 字段必须一致

image.png

  • 全字段添加时,不能有自增长,需要先去掉,可通过上面方式解决

image.png

--全表字段添加
insert into TempTest
select * from TempTest

--自定义字段 - 必须字段匹配
insert into TempTest(guid_value)
select guid_value from TempTest
相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情: https://www.aliyun.com/product/rds/sqlserver
相关文章
|
4月前
|
SQL 自然语言处理 数据库
【Azure Developer】分享两段Python代码处理表格(CSV格式)数据 : 根据每列的内容生成SQL语句
本文介绍了使用Python Pandas处理数据收集任务中格式不统一的问题。针对两种情况:服务名对应多人拥有状态(1/0表示),以及服务名与人名重复列的情况,分别采用双层for循环和字典数据结构实现数据转换,最终生成Name对应的Services列表(逗号分隔)。此方法高效解决大量数据的人工处理难题,减少错误并提升效率。文中附带代码示例及执行结果截图,便于理解和实践。
121 4
|
2月前
|
SQL 数据挖掘 关系型数据库
【SQL 周周练】一千条数据需要做一天,怎么用 SQL 处理电表数据(如何动态构造自然月)
题目来自于某位发帖人在某 Excel 论坛的求助,他需要将电表缴费数据按照缴费区间拆开后再按月份汇总。当时用手工处理数据,自称一千条数据就需要处理一天。我将这个问题转化为 SQL 题目。
113 12
|
2月前
|
SQL 数据采集 资源调度
【SQL 周周练】爬取短视频发现数据缺失,如何用 SQL 填充
爬虫爬取抖音和快手的短视频数据时,如果遇到数据缺失的情况,如何使用 SQL 语句完成数据的补全。
80 5
|
5月前
|
SQL 关系型数据库 MySQL
基于SQL Server / MySQL进行百万条数据过滤优化方案
对百万级别数据进行高效过滤查询,需要综合使用索引、查询优化、表分区、统计信息和视图等技术手段。通过合理的数据库设计和查询优化,可以显著提升查询性能,确保系统的高效稳定运行。
173 9
|
4月前
|
SQL 容灾 关系型数据库
阿里云DTS踩坑经验分享系列|DTS打通SQL Server数据通道能力介绍
SQL Server 以其卓越的易用性和丰富的软件生态系统,在数据库行业中占据了显著的市场份额。作为一款商业数据库,外部厂商在通过解析原生日志实现增量数据捕获上面临很大的挑战,DTS 在 SQL Sever 数据通道上深研多年,提供了多种模式以实现 SQL Server 增量数据捕获。用户可以通过 DTS 数据传输服务,一键打破自建 SQL Server、RDS SQL Server、Azure、AWS等他云 SQL Server 数据孤岛,实现 SQL Server 数据源的流动。
234 0
阿里云DTS踩坑经验分享系列|DTS打通SQL Server数据通道能力介绍
|
8月前
|
SQL 存储 缓存
SQL Server 数据太多如何优化
11种优化方案供你参考,优化 SQL Server 数据库性能得从多个方面着手,包括硬件配置、数据库结构、查询优化、索引管理、分区分表、并行处理等。通过合理的索引、查询优化、数据分区等技术,可以在数据量增大时保持较好的性能。同时,定期进行数据库维护和清理,保证数据库高效运行。
187 4
|
9月前
|
SQL 移动开发 Oracle
SQL语句实现查询连续六天数据的方法与技巧
在数据库查询中,有时需要筛选出符合特定时间连续性条件的数据记录
|
9月前
|
SQL 数据挖掘 数据库
SQL查询每秒的数据:技巧、方法与性能优化
id="">SQL查询功能详解 SQL(Structured Query Language,结构化查询语言)是一种专门用于与数据库进行沟通和操作的语言
|
9月前
|
SQL 存储 关系型数据库
添加数据到数据库的SQL语句详解与实践技巧
在数据库管理中,添加数据是一个基本操作,它涉及到向表中插入新的记录
1175 4
|
9月前
|
SQL 监控 数据处理
SQL数据库数据修改操作详解
数据库是现代信息系统的重要组成部分,其中SQL(StructuredQueryLanguage)是管理和处理数据库的重要工具之一。在日常的业务运营过程中,数据的准确性和及时性对企业来说至关重要,这就需要掌握如何在数据库中正确地进行数据修改操作。本文将详细介绍在SQL数据库中如何修改数据,帮助读者更好
1425 4