首页 > 数据库 > SQL Server > 正文

SQL Server数据库---》增删查改

2024-08-31 00:54:43
字体:
来源:转载
供稿:网友
SQL Server数据库---》增删查改

***数据的插入:(增)

insertinto表名(字段列表)values(值列表)

如果不写字段列表就要为表添加全部的列数据

其实into也可以省略

每次只能插入一条数据

1.如果字段可以为null或有默认值,也可以在添加值的时候使用null/default代替,但不能什么都不填

2.非空字段一定要传入值

3.插入的值必须要符合表的Check约束

4.所有的字段都可以使用单引号’’如果本来是字符串的值没有加‘’号,那么会报错,因为会被当成变量

5.日期值一定要加单引号,如果没有加也不会报错,但显示的是系统默认值1905-6-20

6.如果表没有设置自动增长标识种子,那么添加字段的值要从id开始也就是标识列开始

***数据更新(数据修改)修改删除一定需要考虑有没有条件

语法:

update表名set字段=值/表达式where条件

一般来说可以作为是条件的是主键或唯一键

1.多条件查询要用and连接

2.修改多个字段用,号隔开

Null值的处理:

如果要把本来是null值的数据改成别的数据使用isnull不是=号,如下把Person表中是null的电话号码改成110代码如下:

updatePersonsetphone=‘110’wherephoneisnull

如果把本来有的数据改成null值的话就用=号赋值就可以,不用用is但赋的这个null值不可以加单引号,大小写都不要紧如下:

UpdatePersonsetphone=NUllwhereid=3

数据的删除:只是删除表的数据行

语法:

Delete【from】表名where条件

1.删除是一条一条删除,所有效率低下,它每一次删除都要将操作写入到日志文件中,所以效率低下,而且标识列不会从种子值重新计算,而是接着上次删除最后的标识列,比如删除了标识列为4的行数据,那么再添加一条数据标识列就从5开始

--truncate删除方法:

语法:truncatetable表名 --没有条件

它是一次性删除整个表这种删除方式可以只写入一次日志文件,删除后标识列会从种子值重新计算如设置的标识种子是1,就从1

数据检索:数据的搜索也就是查询--返回虚拟结果集

语法:

select字段列表/*from表列表where条件

eg:select name,age,sex from Student where id=10

添加虚拟结果集的列名:设置列名通过as,也可以用=也就是字段as值如:nameas姓名或name=姓名

--select可以做查询,也可以赋值和输出如:

select1输出的结果是1

select1+1输出的结果是2

select'1'+1结果也是2

select1+‘1’输出的结果是2

select‘1’+‘1’输出的结果是11

只有当加号的两边都是字符串时,是字符串连接

一次性插入多条记录(很少使用,效率太低)

1.将数据移动到新表中新表不能先存在,它是系统自动创建的,它会根据所查询的列自动生成一个对应的表结构

生成的表结构只保留字段名称和类型以及标识列属性,其它的类似于主键,唯一键,关系等约束都没有

Select*intonewGradefromgrade

然后在删除原表数据

Truncatetablegrade

将临时表的数据移动到已经存在的源表中

--目标表必须已经存在,且查询出的列的类型和数量必须和已经存在的目标表的结构一致,且不能破坏目标表的数据完整性。

*Insertinto目标表select*from源表

InsertintogradeselectclassnamefromnewGrade

eg:

select*intonewPersonfromPerson

truncatetablePerson

insertintoPersonselectname,agefromnewPerson

注意:也可以用数据的导出和导入


发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表