首页 > 数据库 >Sql介绍 与 Sql基础查询

Sql介绍 与 Sql基础查询

时间:2024-09-26 22:24:41浏览次数:8  
标签:FORM employees Sql 介绍 查询 SQL WHERE SELECT

Sql介绍 与 Sql基础查询

SQL

SQL也称为结构化查询语言(Structure Query Language),是一种用于管理和操作关系型数据库的标准化计算机语言,SQL语言广泛应用于各种关系型数据库系统(RDBMS)如Mysql,Oracle,Microsoft SQL Server等等

SQL对数据库的操作

  1. 数据查询:通过SELECT语句从数据库中检索数据
  2. 数据定义(DDL):其中包括CREATE,ALTER,DROP对数据库进行定义和修改数据库结构
  3. 数据操控(DML):包括INSERT,UPDATE,DELETE语句插入,更新,删除数据
  4. 数据控制:通过GRANT,REVOKE语句管理用户权限和范围控制

SQL的特点

  • 标准化:SQL是一个标准化的语言,各大数据库厂商都支持SQL语言
  • 高度非过程化:与过程化的与语言不同,SQL不需要指定特点算法或步骤完成任务.SQL语句更专注描述所需结果,而非如何得到所需结果
  • 集合操作:SQL支持集合操作,即一次可以处理多行数据.一个SELECT语句就可以返回多条记录,INSERT,UPDATE也可以一次影响多行数据
  • 事务支持:SQL支持事务处理,允许将一组相关数据,作为一个完整的单元来执行.事务具有:原子性(Atomicity),一致性(Consistency),隔离性(Isolation),持久性(Durability)(关于这些性质在之后的事务章节会详细讲解),ACID,这四个性质确保了数据的一致性与可靠性
  • 集成能力:SQL可以与其他 编程语言相互集成,使得开发者能够在应用程序中嵌入SQL代码,实现高效操作,其中典型的属Java开发者可以使用JDBC来执行SQL查询

SQL基础查询

语法结构

  • SELECT 查询列表 FORM 表名 其中查询列表可以是表中的字段,常量值,表达式,函数等等

SELECT * FORM emplyees; 其中* 表示查询表中所有数据

查询表中单个字段

  • SELECT 字段名 FORM 表名

    eg:查询员工的所有姓名

    SELECT e_name FORM emplyees;

查询表中多个字段

使用逗号将每个字段分隔开来

  • SELECT 字段1,字段2,字段3 FORM 表名;

    eg:示例:查询所有员工的姓名,邮箱,电话号码

    SELECT e_name,e_email,e_phone_num FORM emplyees;

为字段起别名

在实际的数据库表结构中,有些字段名过长,或者不好理解,我们可以对字段名起个表明,在后续调用中直接使用其别名即可,在多表查询中,有些字段名会出现重复,这时我们可以对相应的字段其别名,不宜混淆

  • 使用AS关键字
    • 在将要其别名字段后使用AS关键字
      • SELECT 字段名 AS 别名 FORM 表名;
  • 直接使用空格隔开
    • 即在字段和别名之间用空格隔开即可
      • SELECT 字段名 别名 FORM 表名;

去重

对查询出的语句可能会出先字段名重复的结果,这时,我们可以使用去重功能

  • 使用DISTINCT关键字:

    • SELECT DISTINCT 要去重的字段 ,其他字段… FORM 表名;

    eg:查询部门表中的部门ID,对于每个部门ID出现一次即可,因此我们可以使用去重

    SELECT DISTINCT d_id FORM department;

+号操作

Mysql中 +号只有一个功能:作为运算符,不能作为连接符

  • + 号两侧都是数值型,视为正常的加法运算
  • +号两侧出现了字符,这尝试将字符转化为数值类型,若转化成功,则继续执行加法操作,失败则转化为数值0;转化规则为:从首部开始将所有数值型字符进行转化直到遇到字符型字符,如’11’⇒11;’1a’⇒1;’abc’⇒0;’11a1’⇒11
  • null值与任何数值类型进行+操作都为null
SELECT 1 + 1; //2
SELECT '1' + '1';//2
SELECT 'a' + 1;//1
SELECT 'a' + 'b';//0
SELECT '1a' + '1b';//2
SELECT '11a11' + '11b11'//22;
SELECT 1 + null;//null

CONCAT()操作

既然+号只能作为运算符,那如何连接字符呢?→CONCAT()函数

  • CONCAT() :使用SELECT调用CONCAT();

    • SELECT CONCAT(str1,str2,…);

    eg:查询员工姓名和邮箱,按固定格式(姓名[[email protected]])要求输出,比如:张三[[email protected]]

    SELECT CONCAT(e_name,’[’,e_email,’]’)FORM employees;

IFNULL()函数

  • IFNULL():若查询出的值存在NULL值,使用替代值替代

    • SELECT IFNULL(字段名,代替值) FROM 表名;

    eg:查询员工的姓名和部门ID,如果该员工没有部门信息,显示未知

    SELECT e_name,IFNULL(d_id,’未知’) FORM employees;


条件查询

条件查询,允许在查询数据时,指定某些条件,从而筛选出符合条件的记录

WHERE关键字

WHERE关键字是条件查询的核心;

  • 语法结构:

    SELECT 查询列表  //执行顺序3
    FORM 表名       //执行顺序 1
    WHERE 条件表达式;//执行顺序2
    

    eg:查询 d_id 为 10 的所有员工

    SELECT d_id FORM employees WHERE d_id=10;

表达式筛选

SQL中包含了条件运算符:>, <,>=,<=, =, !=,<>;<>与!=的作用相同都表示不等于,条件运算符是应用于条件表达式中的

  • eg.1:查询工资大于8000的员工信息

    SELECT *FROM employees WHERE salary>8000;

  • eg.2查询部门编号不等于3的员工信息

    SELECT *FORM employees WHERE d_id ! =3;

逻辑运算

逻辑运算符也是一般在WHERE表达式中使用,可帮助在查询中指定多个条件或改变条件逻辑关系

  • 逻辑运算符包括:&&,||,!,分别对应and,or,not

  • eg1:查询工资在8000到10000之间的员工信息→使用AND运算符连接

    SELECT * FORM employees WHERE salary>8000 AND salary<100000;

  • eg2:查询工资大于8000或者部门3的员工信息→使用OR运算符连接

    SELECT * FORM employees WHERE salary >8000 OR d_id=3;

模糊查询

LIKE关键字

SQL中常用的是LIKE关键字,其配合通配符来实现模糊查询

  • 常用通配符

    • % :代表可匹配度多个字符,包括0个,1个

    • _:代表只能匹配一个字符

      SELECT 查询列表
      FROM 表名
      WHERE 列名 LIKE '模式';
      
  • eg1:查询姓名中包含【微】字的员工信息

    SELECT * FORM employees WHERE e_name LIKE ‘%微%’;

  • eg2:查询姓名中第二个字是【可】字的员工信息

    SELECT * FORM employees WHERE e_name LIKE ’_微%’;

BETEWEEN…AND

查询在某段范围值内的数据,包含临界值,即BETEWEEN 8000 AND 100000⇒[8000,10000]

  • eg1:查询工资在8000到10000之间的员工信息

    SELECT * FORM employees WHERE salary BETWEEN 8000 AND 10000;

  • eg2:查询入职时间在2018-01-01到2022-01-01之间的员工信息

    SELECT * FORM employees WHERE hiredate BETWEEN ‘2018-01-01’ AND ’2022-01-01’;

IN关键字

IN运算符用于检测字段值是否在一个指定的值列表中,使用IN运算符可以简化查询语句,特别在需要处理多个值情况下

  • eg:查询在部门2或者部门3的员工信息

    SELECT *FORM employees WHERE d_id IN(2,3); 等价于SELECT * FORM employees WHERE d_id=2 OR d_id=3;

IS NULL/IS not NULL

用于检测一个值是否NULL的运算符

  • eg1:查询没有部门的员工信息

    SELECT * FORM employees WHRER d_id is NULL;

  • eg2:查询有部门的员工信息

    SELECT * FROM emplyees WHERE d_id is not NULL;

排序查询

查询出来的数据默认按照表格的保存顺序查询,我们如果需要修改查询结果展示的顺序,可以使用排序查询,

ORDER BY关键字

在SQL中ORDER BY实现排序,ASC代表升序,DESC代表降序

  • 语法结构

    SELECT 查询列表
    FROM 表
    [WHERE 筛选列表]
    ORDER BY 排序列表 [ASC升序|DESC降序] -- ASC|DESC不写默认是ASC
    

实现单字段排序

  • ORDER BY 排序字段 [ASC升序|DESD降序];

  • eg:查询员工信息按工资高低排序

    - 按照工资升序
    SELECT * FROM emplyees ORDER BY salary ASC -- ASC可以不写
    - 按照工资降序
    SELECT * FROM emplyees ORDER BY salary DESC -- DESC不能省略
    

使用多个字段排序

  • eg:查询员工信息,先按部门ID降序,再按工资升序

    SELECT * FROM emplyees ORDER BY department_id DESC,salary ASC;

标签:FORM,employees,Sql,介绍,查询,SQL,WHERE,SELECT
From: https://www.cnblogs.com/ihave2carryon/p/18434575

相关文章

  • 排查慢收口问题及优化慢查询方法
    目录排查慢收口问题及优化慢查询方法一、开启慢SQL查询日志二、使用explain分析SQL执行计划三、利用其他监控工具在实际的线上环境中,慢收口问题是经常会碰到的。下面为大家总结了排查和优化慢查询的方法:一、开启慢SQL查询日志在数据库层面,开启慢SQL查询日......
  • dedecms经常出现mysql"连接数据库失败,可能数据库密码不对
    遇到“DedeCms错误警告:连接数据库失败,可能数据库密码不对或数据库服务器出错”的错误信息时,可以采取以下步骤来排查和解决问题:1.检查数据库配置文件打开织梦CMS的数据库配置文件,通常位于 /data/common.inc.php 或 /include/config_database.php。检查数据库连接参数是否正......
  • 附录A. PostgreSQL 常用命令
    附录A.PostgreSQL常用命令附录A.PostgreSQL常用命令A.1数据定义语言(DDL)命令A.1.1创建数据库(CREATEDATABASE)A.1.2创建表(CREATETABLE)A.1.3创建索引(CREATEINDEX)A.1.4创建视图(CREATEVIEW)A.1.5创建序列(CREATESEQUENCE)A.2数据操纵语言(DML)命令A.2.1插入数据(IN......
  • ETL: 学习搭配PENTAHO-SERVER-CE-9.4.0.0-343 + MYSQL8.0.35 部分错误日志
     学习搭配PENTAHO-SERVER-CE-9.4.0.0-343+ MYSQL8.0.35 ,启动PENTAHO 后,日志显示:UsingCATALINA_BASE:"E:\Programs\pentaho-server\tomcat"UsingCATALINA_HOME:"E:\Programs\pentaho-server\tomcat"UsingCATALINA_TMPDIR:"E:\Programs......
  • 【2024计算机毕业设计】基于jsp+mysql的JSP在线水果超市商城
    运行环境:最好是javajdk1.8,我在这个平台上运行的。其他版本理论上也可以。IDE环境:Eclipse,Myeclipse,IDEA或者SpringToolSuite都可以,如果编译器的版本太低,需要升级下编译器,不要弄太低的版本tomcat服务器环境:Tomcat7.x,8.x,9.x版本均可操作系统环境:WindowsXP/7......
  • python爬虫介绍
    python网络爬虫介绍网络爬虫就是按照一定的规则,自动地抓取网络上的各种信息的程序。网络爬虫分类按照系统结构和实现技术,可以把分为通用网络爬虫、聚焦网络爬虫、增量式网络爬虫、深层网络爬虫。实际应用中可以将这几种结合起来使用。 通用网络爬虫:如网络搜过引擎,根据提示信息尽可......
  • 自我介绍
    1.大家好,我是20241417罗若元,我想用“乐观”“佛系”“内敛”来描述我自己,首先我是个比较乐观的人,看待各种事情也总喜欢先往好处想,通常都在没考虑后果的情况下处处碰壁,为此,我没少挨遭罪。但我面对各种困难的态度都如出一辙,并不像大多数人会为自己的失误哀声叹气,我会迅速从阴霾走出,......
  • sql语法
    DDL用于定义数据库对象的结构,如表、视图、索引等。其主要操作包括:CREATE:创建新表、视图、索引等。CREATETABLEtable_name(column1datatype,column2datatype,);ALTER:修改现有表的结构,如添加、删除列,修改数据类型等。ALTERTABLEtable_nameADDcolumn_namedatatype;......
  • 掌握 Vuejs:“从查询中检索对象参数”项目
    深入vue.js的世界并学习如何解决vue-router库中具有挑战性的错误。这个项目名为“从查询中检索对象参数”,是一次全面的实践体验,不仅可以增强您的vue.js技能,还可以提高您解决问题和调试的能力。在这个项目中,您将踏上修复将对象推送到查询参数时导致问题的错误的旅程。通过逐......
  • 自我介绍
    慢热幽默热心嘻嘻大家好,我是来自密码科学与技术系信息安全专业的田诗橙。我的性格比较慢热,大家初见我时可能会觉得我不太好相处,哈哈其实不是这样的哦,我呀只是不太会找话题,所以不太会主动找陌生人聊天,实际上,大家在一起学习生活,混熟了之后会了解到一个不一样的我。了解我的人都知......