SQL Server中数据表的增删查改

文章目录

  • 一、增
  • 二、查
  • 三、改
  • 四、删除

一、增

进行增删查改的前提需要在指定数据库中创建数据表,对这块不大理解的可以先看看前面几期文章:
创建数据库
创建数据表

use StudentManageDB
go
insert into Students (StudentName,Gender,Birthday,Age,StudentIdNo,PhoneNumber,StudentAddress,ClassId)
values('张三','女','2023-01-02',2,2023222222222,'012-1212121','北京朝阳区',1)select * from Students

这段代码执行过程:

  • 首先,选择StudentManageDB作为当前操作的数据库,大家可以改成自己创建的数据库名称。
  • 然后,向Students表插入一名新学生的信息。可以换成自己的表的信息。
  • 最后,查询Students表并返回表中所有的学生信息。
  • StudentName,Gender,Birthday,Age,StudentIdNo,PhoneNumber,StudentAddress,ClassId这些是标里面的题头:

在这里插入图片描述

  1. insert into Students (...) values(...)

    这条命令用于在Students表中插入一条新的记录。它指定了要插入数据的列,并为这些列提供了相应的值。具体来说,它向表中插入了一个名为“张三”的女性学生,出生日期为2023年1月02日,年龄为2岁,学生身份证号码为2023222222222,电话号码为012-1212121,住址为北京朝阳区,且分配到ClassID为1的班级。

  2. select * from Students

    这是一个查询命令,用来从Students表中检索所有的记录(行)和所有的字段(列)。*代表所有列。此命令执行后会返回Students表中的所有数据。就是看我们插入数据成功了没。

二、查

上面的select * from Students就是查询,不过我们可以选择查询:

use StudentManageDB
go
select StudentName,gender,Age from Students where age<>22

这段SQL代码用于从数据库中检索信息和指定当前操作的数据库:

  1. select StudentName, gender, Age from Students where age<>22

    这是一个查询命令,用于从Students表中选取姓名(StudentName)、性别(gender)和年龄(Age)这三个字段的值,但是有一个条件,即年龄(Age)不等于22。<>是SQL中的不等于操作符。这个查询将返回所有年龄不为22岁的学生的名字、性别和年龄信息。
    在这里插入图片描述
    注意:
    select语句经常与where子句联合使用。select用来指定从数据库表中检索哪些列的数据,而where子句用来指定检索条件,以便对结果进行过滤,仅返回满足特定条件的行。这种结合使用可以使得查询结果更加精确,符合用户的特定需求。

例如,有一个名为Employees的表,我们只想获取年龄大于30岁的员工的姓名和部门,SQL查询语句:

select EmployeeName, Department
from Employees
where Age > 30;

这里,select语句后面紧跟着from子句指定了要从哪个表中检索数据,where子句则定义了过滤条件。

  1. use StudentManageDB

    这条命令告诉数据库管理系统后续的操作都将针对名为StudentManageDB的数据库。这通常是为了确保操作在正确的数据库上执行。

这两个命令的执行顺序应该是先执行use StudentManageDB来选定数据库,然后执行select语句来检索数据。

三、改

use StudentManageDB
go
update Students set Gender ='男',Age=25 where StudentId=10000
select * from Students

这段代码是用于执行数据库操作的一系列SQL语句,更新特定学生的性别和年龄,同时查询并返回Students表中所有学生的数据。

  1. use StudentManageDB;

    这条语句用于指定后续的数据库操作将在StudentManageDB数据库上进行。use语句用来选择或者切换当前的数据库上下文。

  2. go

    GO是SQL Server Management Studio (SSMS) 中使用的一个批处理命令,它告诉SSMS执行前面的所有SQL语句。实际上,它是一个信号,告诉SSMS(数据库管理系统,就是我们的软件)到此为止是一个批次的结束。go并不是SQL语言的一部分,它在SQL Server工具中用于分割SQL语句。

  3. update Students set Gender ='男', Age=25 where StudentId=10000;

    这条update语句用于修改Students表中的数据。它将性别Gender字段更新为’男’,将年龄Age字段更新为25,条件是StudentId(学生ID)等于10000的学生。这意味着只有当记录的StudentId字段的值为10000时,该记录的GenderAge字段才会被更新。

  4. select * from Students;

    和上面一样,这是一个select语句,用来从Students表中检索所有的列(*是一个通配符,代表所有列)的所有行的数据。执行这条语句后,会展示Students表中所有学生的信息。
    总结一下,修改的语法:
    update <表名> set<列名=更新值>[where <更新条件>]

四、删除

在了解这个只是之前,我们先了解一下外键的概念:

在SQL中,外键是一个字段(或字段的集合),它用来确保一个表中的数据引用另一个表中的数据,从而维护数据之间的引用完整性。外键对应另一张表中的主键,确保了所引用的数据的存在。

例如,假设我们有两个表:StudentsClasses

Classes 表:

ClassIDClassName
1Math
2Science
3Literature

在这个例子中,ClassIDClasses 表的主键。

Students 表:

StudentIDStudentNameClassID
101John Doe1
102Jane Smith2
103Emily Jones3

Students 表中,ClassID 是一个外键,因为它引用了 Classes 表中的主键 ClassID。这样就确保了每个学生都被分配到了一个有效的班级。如果尝试插入一个引用不存在的 ClassID 的记录到 Students 表中,数据库将会抛出一个错误,因为这将违反外键约束。例如,如果尝试添加一个 ClassID 为 4 的学生(假设 Classes 表中没有 ClassID 为 4 的班级),这将会失败。
接下来是几种删除的方式:

在 SQL Server Management Studio (SSMS) 中,删除数据表中的数据主要有以下几种方式:

  1. delete语句:用于根据指定的条件删除表中的行。

    例如:

    delete from table_name where some_condition;
    

    使用delete时需小心,因为如果不指定条件(where子句),它会删除表中的所有行。永远确保在delete语句中使用正确的过滤条件,以避免意外删除额外的数据。
    注意: 如果我们删除的数据被外键引用,那么再加新数据的时候标识列会继续增长,像这样:
    在这里插入图片描述
    这个表中,班级被外键引用,我们删除了机械184(第四行),新增了机械185,但是不会再有4了,自动就变成5了。

  2. truncate table语句:用于删除表中的所有行,但不删除表本身。

    例如:

    truncate table table_name;
    

    truncate table通常比delete无条件语句更快,因为它不记录每行的删除动作。但是它是不可回滚的(在执行后不能恢复数据),并且会重置任何自增的身份列。此外,truncate无法在有外键引用的表上使用。

  3. drop table语句:用于完全删除表及其数据。

    例如:

    drop table table_name;
    

    使用drop table语句将删除整个表,包括表结构和所有数据,操作是不可逆的。所以在使用之前要十分确定是否真的想要删除整个表。

在操作删除数据的时候,要注意以下几点:

  • 备份数据:在执行删除操作前,应先备份相关的数据,以便在操作错误时能够恢复数据。
  • 使用where子句:在使用delete语句时,务必使用where子句指定条件,避免删除不必要的数据。
  • 考虑事务:如果需要对删除操作进行回滚(后面解释),应在事务中执行delete操作,并在确认无误后提交事务。
  • 外键约束:检查是否有外键约束与需要删除的数据相关联,delete操作可能会因违反外键约束而失败。
  • 触发器影响:了解是否有任何触发器与要删除的数据相关联,这些触发器可能会在删除操作执行时触发额外的动作。
  • 性能考虑:在删除大量数据时,delete操作可能会影响数据库性能,应考虑在低峰时段进行操作,或使用批处理删除以减少对性能的影响。

回滚:
回滚(Rollback)是数据库事务处理中的一个概念,指的是将数据库从某个状态恢复到之前的某个状态。在执行SQL语句,特别是修改数据的操作时(如insertupdatedelete),如果操作过程中发生错误,或者有意识地需要撤销操作所做的更改,可以用回滚来取消这次事务所做的所有操作。

在SQL中,回滚通常使用rollback关键字来实现,它与begin transactioncommit关键字一起使用,来定义一个事务的边界。

例如:

begin taansaction; -- 开始事务update Account set Balance = Balance - 100 where AccountId = 'A1'; -- 假设从账户A1扣除100
update Account set Balance = Balance + 100 where AccountId = 'A2'; -- 将100添加到账户A2-- 假设某种检查失败,需要撤销前面的操作
rollback transaction; -- 回滚事务,撤销上面的两个update操作-- 如果所有操作成功,可以提交事务
commit transaction; -- 提交事务,保存所有更改

使用rollback transation后,所有在begin taansaction之后和rollback命令之前的更改都将被撤销,恢复到事务开始前的状态。而commit tranaaction用于确认所有更改,将更改永久保存到数据库中。

在进行重要的批量更新操作时,使用事务是一个良好的实践,因为它提供了一种机制来保证操作的原子性:要么所有更改都被执行,要么所有更改都不被执行。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/634353.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

HarmonyOS【应用服务开发】在模块中添加Ability

Ability是应用/服务所具备的能力的抽象&#xff0c;一个Module可以包含一个或多个Ability。应用/服务先后提供了两种应用模型&#xff1a; FA&#xff08;Feature Ability&#xff09;模型&#xff1a; API 7开始支持的模型&#xff0c;已经不再主推。Stage模型&#xff1a;AP…

C# new Thread和Task.Run,多线程(Thread和Task)

一、开启多线程-new Thread的使用 示例一 Thread thread25yi new Thread(new ThreadStart(obj.MethodTimer1)); thread25yi.Start(); void MethodTimer1() { while (true) { Console.WriteLine(DateTime.Now.ToString() "_" thread25yi.CurrentThread.Managed…

杂记 | 在Linux上使用Docker-compose安装单机版Milvus向量数据库并配置访问控制和可视化面板(Attu)

文章目录 01 Milvus向量数据库简介02 安装前的准备03 安装3.1 创建milvus工作目录3.2 下载并编辑docker-compose.yml3.3 下载milvus.yml文件3.4 启动milvus 04 访问可视化面板并修改密码 01 Milvus向量数据库简介 Milvus是一款开源的向量数据库&#xff0c;它专为AI应用设计&a…

Docker(三)使用 Docker 镜像:从仓库获取镜像;管理本地主机上的镜像;介绍镜像实现的基本原理

作者主页&#xff1a; 正函数的个人主页 文章收录专栏&#xff1a; Docker 欢迎大家点赞 &#x1f44d; 收藏 ⭐ 加关注哦&#xff01; 使用 Docker 镜像 在之前的介绍中&#xff0c;我们知道镜像是 Docker 的三大组件之一。 Docker 运行容器前需要本地存在对应的镜像&#x…

IaC基础设施即代码:Terraform 使用 dynamic动态内联块 创建docker资源

目录 一、实验 1.环境 2.Terraform查看版本 3.Linux主机安装Docker 4.Terraform使用本地编译&#xff08;In-house&#xff09;的Providers 5.Docker-CE 开启远程API 6. Linux主机拉取镜像 7.Terraform 使用 dynamic动态内联块 创建资源 二、问题 1.Terraform 计划资源…

精品基于Uniapp+springboot校园学校趣事管理系统app

《[含文档PPT源码等]精品基于Uniappspringboot趣事管理系统app》该项目含有源码、文档、PPT、配套开发软件、软件安装教程、项目发布教程、包运行成功&#xff01; 软件开发环境及开发工具&#xff1a; 开发语言&#xff1a;Java 后台框架&#xff1a;springboot、ssm 安卓…

Unity vs Godot :哪个游戏引擎更适合你?

Unity vs Godot &#xff1a;哪个游戏引擎更适合你&#xff1f; 游戏引擎的选择对开发过程和最终产品质量有着重大影响。近年来&#xff0c;Godot和Unity这两款引擎受到广泛关注。本文将从多个维度对两者进行比较&#xff0c;以期为开发者提供正确的选择建议。 Godot和Unity都有…

Backtrader 文档学习-Indicators混合时间框架

Backtrader 文档学习-Indicators混合时间周期 1.不同时间周期 如果数据源在Cerebro引擎中具有不同的时间范围和不同的长度&#xff0c;指示器将会终止。 比如&#xff1a;data0是日线&#xff0c;data1是月线 。 pivotpoint btind.PivotPoint(self.data1) sellsignal self…

IMDB电影评论的情感分析——paddle

项目地址&#xff1a;IMDB电影评论的情感分析 - 飞桨AI Studio星河社区 (baidu.com) 1. 实验介绍 1.1 实验目的 理解并掌握循环神经网络的基础知识点&#xff0c;包括模型的时序结构、模型的前向传播、反向传播等掌握长短时记忆网络LSTM和门控循环单元网络GRU的设计原理熟悉如…

Halcon基于形变的模板匹配

Halcon基于形变的模板匹配 形变分为两种&#xff0c;一种是基于目标局部的形变&#xff0c;另一种是由于透视关系而产生的形变。基于形变的模板匹配也是一种基于形状的匹配方法&#xff0c;但不同的是&#xff0c;其返回结果中不仅包括轻微形变的形状.形变的位置和参数&#x…

Node.js基础知识点(五)- http

一.request 请求事件处理函数 var http require(http)var server http.createServer() request 请求事件处理函数&#xff0c;需要接收两个参数&#xff1a; Request 请求对象 请求对象可以用来获取客户端的一些请求信息&#xff0c;例如请求路径 Response 响应对象 响应对…

神器yakit之web fuzzer功能

前言 yakit并不像burp一样单独设置爆破模块&#xff0c;但是yakit也是可以爆破的&#xff0c;并且更好用&#xff08;个人感觉&#xff09;。 手工测试场景中需要渗透人员对报文进行反复的发送畸形或者特定的payload进行查看服务器的反馈并以此来进行下一步的判断。 Fuzz标签便…

Verilog基础:强度建模(二)

相关阅读 Verilog基础https://blog.csdn.net/weixin_45791458/category_12263729.html?spm1001.2014.3001.5482 三、拥有单个强度和确定值的net型信号的线与组合&#xff08;线网多驱动&#xff09; 首先来说明一下什么叫信号拥有单个强度和确定值&#xff0c;其实如果一个ne…

Vue中的日历组件 Calendar 实现 考勤打卡记录

日历组件 Calendar 可以自定义在页面添加内容。 实现效果图 1.由于Calendar没有右上角月份切换的API事件&#xff0c;可以给组件源码添加自定义添加一个事件 2.也可以通过自带的input事件来获取日历 3.vue页面完整代码 注释&#xff1a;this.$m(this.beginTime).format(…

Halcon 一维测量

文章目录 算子矩形算子弧形算子移动到新的参考点 Halcon 案例测量保险丝的宽度&#xff08;边缘对测量&#xff09;使用助手进行测量 halcon 案例获取芯片引脚的个数平均宽度距离&#xff0c;连续两个边缘的距离&#xff08;measure_pos &#xff09;halcon 定位测量Halcon 测量…

Java基础面试题-2day

面向对象 创建一个对象用什么运算符&#xff0c;对象实体和对象引用有什么不同&#xff1f; 创建对象使用new String A new String(); A即为对象引用&#xff0c;通过new运算符&#xff0c;创建String()类型的对象实体。 对象引用的存储位置在栈内存 对象实体的存储位置在堆…

【算法】使用优先级队列(堆)解决算法题(TopK等)(C++)

文章目录 1. 前言2. 算法题1046.最后一块石头的重量703.数据流中的第K大元素 2.5 如何选择大根堆 与 小根堆&#xff1f; 为什么选择大根堆&#xff08;小根堆&#xff09;&#xff1f;692.前K个高频单词295.数据流的中位数 1. 前言 我们知道&#xff1a;优先级队列是一种常用…

Maven 基础安装配置及使用

大家好我是苏麟 , 今天聊聊Maven . Maven Maven , 是Apache公司下基于Java开发的开源项目 . 我们构建一个项目需要用到很多第三方的类库&#xff0c;需要引入大量的jar包。一个项目Jar包的数量之多往往让我们瞠目结舌&#xff0c;并且Jar包之间的关系错综复杂&#xff0c;一…

高并发缓存问题分析以及分布式锁的实现

一,场景概述: 在高并发的环境下,比如淘宝,京东不定时的促销活动,大量的用户访问会导致数据库的性能下降,进而有可能数据库宕机从而不能产生正常的服务,一般一个系统最大的性能瓶颈&#xff0c;就是数据库的io操作,如果发生大量的io那么他的问题也会随之而来。从数据库入手也是…

Python | 六、哈希表 Hash Table(列表、集合、映射)

哈希表基础 哈希表是一类数据结构&#xff08;哈希表包含数组、集合和映射&#xff0c;和前两篇文章叙述的字符串、链表平级&#xff09;哈希表概念&#xff1a;类似于Python里的字典类型&#xff0c;哈希表把关键码key值通过哈希函数来和哈希表上的索引对应起来&#xff0c;之…