- 主要知识点列表
编号 | 语言或插件 | 知识点 | 说明 |
---|---|---|---|
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是判断对象是否存在,类比应该也是适用用来判断存储过程和视图是否存在,感兴趣的可以尝试下
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,...)
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())
2、此处可以有个小技巧,上面的可以改为,只写一次insert into和values,值写多个,如下
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
4、已经存在表的情况下 - insert into select
- 字段必须一致
- 全字段添加时,不能有自增长,需要先去掉,可通过上面方式解决
--全表字段添加
insert into TempTest
select * from TempTest
--自定义字段 - 必须字段匹配
insert into TempTest(guid_value)
select guid_value from TempTest