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.rhkb.cn/news/241368.html

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

相关文章

如何使用万能头 #include<bits/stdc++.h>

准备蓝桥杯的时候看到了很多头文件包含了这个头文件&#xff0c;后来查了一下 它是C中支持的一个几乎万能的头文件&#xff0c;几乎包含所有的可用到的C库函数。以后写代码就可以直接引用这一个头文件了&#xff0c;不需要在写一大堆vector、string、map、stack…… 我们该如何…

JavaScript基础语法

速通回顾一遍 引入方式 一般会把<script>标签置于<body>元素底部&#xff0c;改善显示速度&#xff1a; 内部脚本&#xff1a;<script></script>标签内外部脚本&#xff1a;<script src""></script>配置src 外部js文件中&…

数据库-数据库分类

数据库可以分为关系型数据库和非关系型数据库&#xff0c;常见的数据库如下 关系型数据库 关系型数据库是一种采用关系模型来组织数据的数据库&#xff0c;它以行和列的形式存储数据&#xff0c;以便于用户理解。关系型数据库中的数据以二维表的形式组织&#xff0c;被称为表…

MSSQL-识别扩展extended event(扩展事件)中的时间单位

经常使用sqlserver extended event(扩展事件)&#xff0c;但是总是忘记扩展事件使用的时间单位&#xff0c;不确定它们是 秒、毫秒、还是微秒&#xff1f; 以下下代码能够从 相关DMV中提取description字段内容来识别时间单位&#xff1a; SELECT [p].[name] [package_name],[o…

mac PyCharm 上传文件到远程服务器+远程服务器下载到本地

1 部署配置 选择SFTP name&#xff1a;test6 输入ssh账号和密码。保存密码和30s心跳。 2 目录映射 Local path&#xff08;本地mac机器&#xff09;&#xff1a;/Users/clevercode/PycharmProjects/test6 Root path&#xff08;远程服务机器&#xff09;&#xff1a;/home/…

k8s---ingress对外服务(traefik)

目录 ingress的证书访问 traefik traefik的部署方式&#xff1a; deamonset deployment nginx-ingress与traefix-ingress相比较 nginx-ingress-controller ui访问 deployment部署 ingress的证书访问 ingress实现https代理访问: 需要证书和密钥 创建证书 密钥 secre…

汽车科技迎来新纪元!奔驰、宝马、谷歌、亚马逊、高通的下一代布局!

不久的将来&#xff0c;你将能够直接通过汽车支付。为了减少支付服务的复杂性&#xff0c;高通正在与摩根大通合作设计一款车载钱包&#xff0c;简化支付体验。这将使驾驶员能够直接通过汽车支付流媒体内容、电动车充电、停车或得来速餐食物。 下一代智能车会是什么样子&#…

KubeSphere平台使用

KubeSphere官网地址&#xff1a;https://kubesphere.io/zh/ KubeKey一键部署K8S集群&#xff1a;https://kubesphere.io/zh/docs/v3.4/installing-on-linux/introduction/multioverview/ 一台master node&#xff08;初始化主节点&#xff09;、两台 work node&#xff08; joi…

【分布式监控】zabbix与grafana连接

1.在zabbix- server服务端安装grafana&#xff0c;并启动服务 先在官网下载软件 https://grafana.com/grafana/download/9.4.7?editionenterprise&pggraf&plcmtdeploy-box-1#可以翻译成中文介绍&#xff0c;很详细的教程 yum install -y https://dl.grafana.com/ent…

Git 基本命令与操作流

记录 Git 中的基本命令和创建仓库、提交文件、删除文件等方面的操作 Git 基本命令 git status&#xff1a;查看状态 nothing to commit, working directory clean&#xff1a;所有已跟踪文件在上次提交后都未被更改过&#xff0c;或者说当前目录下没有出现任何处于未跟踪状态…

Python GUI 新手入门教程:轻松构建图形用户界面

Python 凭借其简单性和多功能性&#xff0c;已经成为最流行的编程语言之一。被广泛应用于从 web 开发到数据科学的各个领域。 在本教程中&#xff0c;我们将探索用于创建图形用户界面&#xff08;GUIs&#xff09;的 Python 内置库&#xff1a; Tkinter&#xff1a;无论你是初…

Maven普通工程和web工程创建

文章目录 创建项目前设置maven工程前设置工作创建项目前--》设置utf-8配置maven参数Maven普通工程和web工程创建Maven简单工程第一步&#xff1a;File–New–Project 第二步&#xff1a;选择maven然后下一步&#xff1a;填写后询选择finish初始化maven工程目录简介maven简单工程…

非常好用的Mac清理工具CleanMyMac X 4.14.7 如何取消您对CleanMyMac X的年度订购

CleanMyMac X 4.14.7是Mac平台上的一款非常著名同时非常好用的Mac清理工具。全方位扫描您的Mac系统&#xff0c;让垃圾无处藏身&#xff0c;您只需要轻松单击2次鼠标左键即可清理数G的垃圾&#xff0c;就这么简单。瞬间提升您Mac速度。 CleanMyMac X 4.14.7下载地址&#xff1a…

密码学学习笔记(二十四):TCP/IP协议栈

TCP/IP协议栈的基础结构包括应用层、传输层、网络层、数据链路层和物理层。 应用层 应用层位于TCP/IP协议栈的最顶层&#xff0c;是用户与网络通信的接口。这一层包括了各种高级应用协议&#xff0c;如HTTP&#xff08;用于网页浏览&#xff09;、FTP&#xff08;用于文件传输…

京东ES支持ZSTD压缩算法上线了:高性能,低成本 | 京东云技术团队

1 前言 在《ElasticSearch降本增效常见的方法》一文中曾提到过zstd压缩算法[1]&#xff0c;一步一个脚印我们终于在京东ES上线支持了zstd&#xff1b;我觉得促使目标完成主要以下几点原因&#xff1a; Elastic官方原因&#xff1a;zstd压缩算法没有在Elastic官方的开发计划中&…

【mars3d】 graphic.bindPopup(inthtml).openPopup()无需单击小车,即可在地图上自动激活弹窗的效果。

实现效果&#xff1a;new mars3d.graphic.FixedRoute({无需单击小车&#xff0c;即可在地图上实现默认打开弹窗的激活效果。↓↓↓↓↓↓↓↓ 相关链接说明&#xff1a; 1.popup的示例完全开源&#xff0c;可参考&#xff1a;功能示例(Vue版) | Mars3D三维可视化平台 | 火星科…

CentOS 8.5 安装图解

特特特别的说明 CentOS发行版已经不再适合应用于生产环境&#xff0c;客观条件不得不用的话&#xff0c;优选7.9版本&#xff0c;8.5版本次之&#xff0c;最次6.10版本&#xff08;比如说Oracle 11GR2就建议在6版本上部署&#xff09;&#xff01; 引导和开始安装 选择倒计时结…

外卖系统创新:智能推荐与用户个性化体验

外卖系统的日益普及使得用户对于更智能、个性化的体验有着不断增长的期望。在这篇文章中&#xff0c;我们将探讨如何通过智能推荐技术&#xff0c;为用户提供更贴心、更符合口味的外卖选择。我们将使用 Python 和基于协同过滤的推荐算法作为示例&#xff0c;让您更深入地了解智…

Vue3 在 history 模式下通过 vite 打包部署白屏

Vue3 在 history 模式下通过 vite 打包部署后白屏; 起因 hash 模式 url 后面跟个 # 强迫症犯了改成了 history,就此一波拉锯战开始了 ... 期间 nigix 和 router 各种反复排查尝试最终一波三折后可算是成功了 ... Vue官方文档 具体配置可供参考如下: 先简要介绍下,当前项目打包…

计算机毕业设计 基于SpringBoot的红色革命文物征集管理系统的设计与实现 Java实战项目 附源码+文档+视频讲解

博主介绍&#xff1a;✌从事软件开发10年之余&#xff0c;专注于Java技术领域、Python人工智能及数据挖掘、小程序项目开发和Android项目开发等。CSDN、掘金、华为云、InfoQ、阿里云等平台优质作者✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精…