sqlserver 数据库学习笔记

sqlserver 数据库学习笔记,学习sqlserver的朋友可以参考下。

1,exists和in的理解(参考)

exists:如果子查询中包括某一行,那么就为TRUE

in:如果操作数为TRUE等于表达式列表中的一个,那么就为TRUE

exists总是搞得不太明白

select 。。。from。。。where 。。。

where就相当于一个判断条件,只有where后面的表达式运算结果为TRUE,前面的才能select出来

EXISTS用于检查子查询是否至少会返回一行数据,该子查询实际上并不返回任何数据,而是返回值True或False

1: SELECT c.CustomerId, CompanyName 2: FROM Customers c 3: WHERE EXISTS( 4: SELECT OrderID FROM Orders o 5: WHERE o.CustomerID = cu.CustomerID)
像这样的EXISTS子查询中的SELECT什么根本不重要,因为子查询只是检查这个表中有没有满足WHERE后条件的行, 有就返回TRUE,没有就FALSE,所以很多EXISTS后都是SELECT的*

一行行的去判定,EXISTS返回的是TRUE,就是存在,则把这行的相关信息输出

1: select distinct 姓名 from xs 2: where not exists ( 3: select * from kc 4: where not exists ( 5: select * from xs_kc 6: where 学号=xs.学号 and 课程号=kc.课程号 )
分析下上面的查询语句:

把最外层的xs表里的记录一行一行的同中层一行一的笛卡尔乘积后拿到里面去检验

在最里层,如果xs_kc表里的某行有拿来检验的这行的学号,同时有中层拿来检验的课程号

就返回TRUE,说明这个这个学生选了这门课

中层如果某门课程没有收到返回的TRUE信息,说明这个名字和课程的搭配在xs_kc表中没有,或者说中层select出来的是没有被这个学生选择的课程信息,如果有这样的课程,就向最外层返回个TRUE

最外层在返回信息上加了not,即最外层找的是这样的一种学生:

他选择了所有的课程

最外层一行行的去检测,如果他满足这个条件,就输出他的姓名且只输出一次

我这是一层层的分析,还有么有什么别的办法?

2,select。。。into @。。。

和select @。。。 = 。。。应该是相同的吧

3,用AS为列重命名似乎比=更好点,和赋值区分开

4,用compute汇总的时候,如果是根据某列汇总的,先要order by此列,然后在compute相应信息,最后by此列

group或者compute的时候,如果by了某列,select里都要出现相同的列

区别是group的聚合函数在select行中(称为选择列表),而compute的聚合函数在compute行中,同时compute可以不带by,对所有行汇总

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/443621.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月7日 19:48:59
下一篇 2025年11月7日 19:56:11

相关推荐

  • css布局模型有哪些?css三种布局模型的介绍

    本篇文章给大家带来的内容是关于css布局模型有哪些?css三种布局模型的介绍,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 流动模型(flow) 默认的网页布局模式  * 块状元素都会在所处的包含元素内自上而下按顺序垂直延伸分布  * 内联元素都会在所处的包含元素内从左到右水平分布…

    2025年12月24日 好文分享
    000
  • HTML数据如何存储到数据库 HTML数据存储的技术方案比较

    直接存储原始HTML字符串最常见,适用于富文本编辑器输出等内容,实现简单、读取快,但需防范XSS和SQL注入;结构化JSON存储适合需程序化处理的场景,支持条件查询但渲染开销大;专用格式如Delta适用于协同编辑;分离存储则提升大型系统的查询性能与管理灵活性。 将HTML数据存储到数据库时,核心目标…

    2025年12月23日
    000
  • 数据库查询与HTML整合

    通过以下步骤,您可以将数据库查询结果整合到 html 页面中:建立数据库连接。执行查询并存储结果。遍历查询结果并将其显示在 html 元素中。 使用 PHP 将数据库查询与 HTML 整合 整合数据库查询结果和 HTML 页面可使您创建动态和交互式 Web 应用程序。本文将引导您完成使用 PHP 执…

    2025年12月22日
    000
  • 深入解析HTML如何读取数据库

    html 无法直接读取数据库,但可以通过 javascript 和 ajax 实现。其步骤包括建立数据库连接、发送查询、处理响应和更新页面。本文提供了利用 javascript、ajax 和 php 来从 mysql 数据库读取数据的实战示例,展示了如何在 html 页面中动态显示查询结果。该示例使…

    2025年12月22日
    000
  • html怎么读取数据库

    HTML 本身不具备直接读取数据库的能力,而是需要结合后端编程语言和数据库查询语言来实现。后端代码负责与数据库交互,从数据库中读取数据,并将数据嵌入到 HTML 页面中。这个过程通常涉及设置数据库、编写后端代码、将后端代码嵌入 HTML、配置服务器和访问网页。此外,前端 JavaScript 也可以…

    2025年12月22日
    000
  • 前端与后端的职责与技能要求

    前端与后端是软件开发中不可或缺的两个部分,它们分别承担着不同的职责和技能要求。本文将从职责和技能方面探讨前端与后端开发工程师的工作内容和要求。 一、前端工程师的职责及技能要求前端工程师负责实现用户界面和交互功能,直接面向用户,需要具备以下职责和技能要求: 实现网站或应用程序的用户界面设计,确保页面视…

    2025年12月22日
    000
  • 前端后端开发的发展历程与趋势展望

    随着互联网的迅猛发展和信息技术的日新月异,前端和后端开发作为两个重要的IT领域在过去几十年中也取得了巨大的进步。本文将探讨前端后端开发的发展历程,分析当前的发展趋势,并展望未来的发展方向。 一、前端后端开发的发展历程 早期阶段在互联网刚刚兴起的时期,网站开发主要关注内容的呈现,前端开发工作主要集中在…

    2025年12月22日
    000
  • 剖析前端和后端的技术差异

    前端和后端是软件开发中常见的两个领域,前端指的是用户界面和用户交互逻辑的开发,而后端则负责处理数据存储、逻辑处理和业务规则的实现。两者在技术上有着明显的差异,本文将从不同的角度来剖析前端和后端的技术差异。 首先,在技术栈方面,前端和后端使用的技术有很大的不同。前端常用的技术包括HTML、CSS和Ja…

    2025年12月22日
    000
  • 了解localstorage:它的数据库特点是什么?

    探究localstorage:它是一种什么样的数据库? 概述:在现代的Web开发中,数据的存储和管理是非常重要的一部分。随着技术的不断进步,新的数据库技术也不断涌现。其中之一就是localstorage。本文将介绍localstorage的概念、用途以及一些常用的代码示例,帮助读者更好地了解并使用l…

    好文分享 2025年12月21日
    000
  • 揭开localstorage的面纱:揭示它的真实本质和功能

    揭秘localstorage:究竟是什么样的数据库? 近年来,随着Web应用的快速发展,前端开发中涉及到数据存储的需求也越来越多。而localstorage作为一种前端数据存储的解决方案,备受广大开发者的关注和使用。那么,这个被称为“本地存储”的localstorage究竟是什么样的数据库呢?本文将…

    2025年12月21日
    000
  • 揭开localstorage的神秘面纱:深入探究这种数据库的特性

    解读localStorage:它到底是怎样的一种数据库? 概述: 在现代网页开发中,本地存储是一项非常重要的技术。其中之一就是localStorage(本地存储)技术。localStorage是一种在浏览器中储存数据的机制,它提供了一种简单的方式来存储和读取持久性数据。这种存储是基于浏览器的,而不是…

    2025年12月21日
    000
  • H5的本地存储和本地数据库详细介绍

    这次给大家带来h5的本地存储和本地数据库详细介绍,使用h5的本地存储和本地数据库的注意事项有哪些,下面就是实战案例,一起来看一下。 本地存储 1.1 本地存储由来的背景 由于HTML4时代Cookie的大小、格式、存储数据格式等限制,网站应用如果想在浏览器端存储用户的部分信息,那么只能借助于Cook…

    好文分享 2025年12月21日
    100
  • 什么是B+树?B+树在数据库中的作用

    B+树通过将数据存储在叶子节点并用内部节点索引,结合叶子间的链表实现高效查询与范围扫描,广泛用于数据库如MySQL的InnoDB引擎,提升检索速度;其相比二叉树和B树减少I/O次数,支持快速定位及顺序访问,适用于大容量数据存储场景。 B+树是一种自平衡的树数据结构,特别适用于磁盘存储,常被用作数据库…

    2025年12月20日
    000
  • B树是什么?B树在数据库中的应用

    b+树是数据库中最常用的索引结构,因为它在b树基础上优化了数据存储和范围查询性能;b树的所有节点都存储数据,而b+树仅在叶子节点存储数据且叶子节点通过指针连接成有序链表,这使得b+树具有更低的树高、更少的i/o操作和更高效的范围查询能力,因此mysql等数据库的存储引擎如innodb默认采用b+树作…

    2025年12月20日
    000
  • c++如何用C++写一个简单的数据库系统_c++ SQLite架构解析与实现【项目】

    推荐用C++封装SQLite而非从零手写数据库,因其已实现ACID、B+树索引、WAL日志等工业级特性;C++只需RAII管理句柄与语句、封装查询/事务接口、统一错误处理,即可高效构建安全易用的数据层。 直接用 C++ 从零写一个工业级数据库系统(如支持 SQL、事务、并发、持久化、索引等)极其复杂…

    2025年12月19日
    000
  • C++简易数据库 文件存储查询系统

    答案:用C++实现简易数据库需设计结构体并以二进制形式存入文件,支持增删改查。1. 定义Student结构体存储学生信息;2. 使用fstream以二进制模式读写文件;3. 增加记录时追加到文件末尾;4. 查询时遍历文件匹配id或姓名;5. 修改时用seekp定位并重写数据;6. 删除可用标记法或重…

    2025年12月18日
    000
  • 如何用C++实现桥接模式 抽象与实现分离设计方案

    c++++中桥接模式的核心优势在于解耦抽象与实现,使其能独立变化。1. 它通过将一个类中可能变动的具体操作抽离为独立的实现体系,降低类组合数量,避免“m x n”组合爆炸;2. 抽象类(如shape)包含指向实现接口的指针或引用,调用具体实现(如drawingapi),使两者互不影响;3. 适用于多…

    2025年12月18日 好文分享
    200
  • 将C++框架与数据库技术集成时有哪些注意事项?

    集成 c++++ 框架和数据库技术需要考虑以下事项:使用连接池以减少数据库连接的开销。利用持久性框架,如 hibernate 或 qt sql,来简化数据库交互。确保 c++ 数据类型与数据库数据类型正确映射。通过事务处理确保多数据库操作的原子性和一致性。采取安全措施,如参数化查询和数据验证,以防止…

    2025年12月18日
    000
  • C# Avalonia如何集成Entity Framework Core Avalonia EF Core教程

    在 Avalonia 中集成 EF Core 可行,关键在于异步操作、DI 注入 DbContextFactory 及正确管理生命周期;需避免 UI 线程阻塞,推荐用 AddDbContextFactory 而非 Scoped 或 Singleton 注册。 在 Avalonia 中集成 Entit…

    2025年12月17日
    000
  • EF Core在控制台程序中怎么用 EF Core控制台应用入门

    EF Core在控制台程序中入门只需四步:建模型、配上下文、跑迁移、写代码操作数据;依次完成项目创建与NuGet安装、定义实体类和DbContext、执行Add-Migration与Update-Database生成数据库、在Main中用Add/SaveChanges/ToList实现增删改查。 E…

    2025年12月17日
    000

发表回复

登录后才能评论
关注微信