Mysql——三、SQL语句(上篇)

Mysql

    • 一、SQL语句基础
      • 1、SQL简介
      • 2、SQL语句分类
      • 3、SQL语句的书写规范
    • 二、数据库操作
    • 三、MySQL 字符集
      • 1、变量
      • 2、utf8和utf8mb4的区别
    • 四、数据库对象
    • 五、SELECT语句
      • 1、简单的SELECT语句
      • 2、SQL函数
        • 2.1 聚合函数
        • 2.2 数值型函数
        • 2.3 字符串函数
        • 2.4 日期和时间函数
        • 2.5 流程控制函数

一、SQL语句基础

1、SQL简介

SQL:结构化查询语言(Structured Query Language),在关系型数据库上执行数据操作、数据检索以及数据维护的标准语言。使用SQL语句,程序员和数据库管理员可以完成如下的任务。

  • 改变数据库的结构
  • 更改系统的安全设置
  • 增加用户对数据库或表的许可权限
  • 在数据库中检索需要的信息
  • 对数据库的信息进行更新

2、SQL语句分类

MySQL致力于支持全套ANSI/ISO SQL标准。在MySQL数据库中,SQL语句主要可以划分为以下几类:
mysql
数据库show databases;

行 列

DDL(Data Definition Language):数据定义语言,定义对数据库对象(库、表、列、索引)的操作。CREATE、DROP、ALTER、RENAME、 TRUNCATE等。
DML(Data Manipulation Language): 数据操作语言,定义对数据库记录的操作。select ,INSERT、DELETE、UPDATE等。

​ DQL(Data Query Language)数据查询语言:SELECT语句。

DCL(Data Control Language): 数据控制语言,定义对数据库、表、字段、用户的访问权限和安全级别。GRANT、REVOKE等。
TCL(Transaction Control):事务控制。COMMIT、ROLLBACK、SAVEPOINT等。

注:可以使用help查看这些语句的帮助信息。

3、SQL语句的书写规范

  • 在数据库系统中,SQL语句不区分大小写(建议用大写) 。
  • (数据)但字符串常量区分大小写。
  • SQL语句可单行或多行书写,以“;”结尾。
  • 关键词不能跨多行或简写。
  • 用空格和缩进来提高语句的可读性。
  • 子句通常位于独立行,便于编辑,提高可读性。

sql语句注释:

  • (1)单行注释:“–” “#”
mysql> -- select user,host from mysql.user;
mysql> select user from mysql.user -- where user='root';-> ;
+------------------+
| user             |
+------------------+
| mysql.infoschema |
| mysql.session    |
| mysql.sys        |
| root             |
+------------------+

在这里插入图片描述
在这里插入图片描述

  • (2)多行注释:/* text */
mysql> select user from mysql.user /*/*> where user='root'/*> */-> ;
+------------------+
| user             |
+------------------+
| mysql.infoschema |
| mysql.session    |
| mysql.sys        |
| root             |
+------------------+ 

二、数据库操作

1、查看

语法:SHOW DATABASES [LIKE wild];

wild可以使用"%“和”_"通配符。

%表示匹配任意零个或多个的任意字符。

_表示单个任意字符。

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| sys                |
+--------------------+

在这里插入图片描述
Information_schema:主要存储了系统中的一些数据库对象信息:如用户表信息、列信息、权限信息、字符集信息、分区信息等。(数据字典表)
performance_schema:主要存储数据库服务器的性能参数
mysql:存储了系统的用户权限信息及帮助信息。
sys: 5.7新增,之前版本需要手工导入。这个库是通过视图的形式把information_schemaperformance_schema结合起来,查询出更加令人容易理解的数据。
test:系统自动创建的测试数据库,任何用户都可以使用。

mysql> show databases like '__s%';
+-----------------+
| Database (__s%) |
+-----------------+
| mysql           |
| sys             |
+-----------------+

2、创建

语法:CREATE DATABASE [IF NOT EXISTS] 数据库名;

用给定的名字创建一个数据库,如果数据库已经存在,则报错。

#查看创建数据库的语句:SHOW CREATE DATABASE <数据库名>;
mysql> show create database mysql;
+----------+---------------------------------------------------------------------------------------------------------------------------------+
| Database | Create Database                                                           |
+----------+---------------------------------------------------------------------------------------------------------------------------------+
| mysql    | CREATE DATABASE `mysql` /*!40100 DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci */ /*!80016 DEFAULT ENCRYPTION='N' */ |
+----------+---------------------------------------------------------------------------------------------------------------------------------+
mysql> create database chap03;
Query OK, 1 row affected (0.00 sec)mysql> show create database chap03;
+----------+----------------------------------------------------------------------------------------------------------------------------------+
| Database | Create Database                                                         |
+----------+----------------------------------------------------------------------------------------------------------------------------------+
| chap03   | CREATE DATABASE `chap03` /*!40100 DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci */ /*!80016 DEFAULT ENCRYPTION='N' */ |
+----------+----------------------------------------------------------------------------------------------------------------------------------+

在这里插入图片描述

3、删除

语法:DROP DATABASE [IF EXISTS]数据库名;

删除数据库中得所有表和数据库(慎用)

mysql> drop database chap03;

在这里插入图片描述

4、切换

语法: USE 数据库名;

把指定数据库作为默认(当前)数据库使用,用于后续语句。

mysql> use mysql
# 查看当前连接的数据库
mysql> select database();
+------------+
| database() |
+------------+
| mysql      |
+------------+

在这里插入图片描述

#设置提示符显示当前数据库名称
[root@mysql8-0-30 mysql]# vim /etc/my.cnf.d/mysql-server.cnf
[mysql]
prompt=mysql8.0 [\\d]>
[root@mysql8-0-30 mysql]# systemctl restart mysqld
[root@mysql8-0-30 mysql]# mysql -uroot -pAdmin123! mysql
mysql8.0 [mysql]>

5、执行系统命令

语法:system 命令

mysql> system date
2023年 02月 06日 星期一 15:57:52 CST
mysql> system ls /
afs  boot  etc   lib    media  opt   root  sbin  sys  usr
bin  dev   home  lib64  mnt    proc  run   srv   tmp var

在这里插入图片描述

三、MySQL 字符集

MySQL字符序包括字符集(CHARACTER)和校对规则(COLLATION)两个概念:字符集是多个字符(英文字符,汉字字符,或者其他国家语言字符)的集合,字符集种类较多,每个字符集包含的字符个数不同。

通常命名规则是: 字符集\_语言\_ci/cs/bin
常见字符集:
​    gbk支持中文简体字符,汉子占用的两个;
​    big5支持中文繁体字符;
​    utf8几乎支持世界所有国家的字符,汉字占用3个字节;
​    latin1支持西欧字符、希腊字符等
校对规则
​	cs: 区分大小写
​	bin:区分大小写
​	ci: 不区分大小写
特点:1、字符编码方式是用一个或多个字节表示字符集中的一个字符2、每种字符集都有自己特有的编码方式,因此同一个字符,在不同字符集的编码方式下,会产生不同的二进制Mysql的字符集和校验规则有4个级别的默认设置:服务器级,数据库级,表级和字段级。分别在不同的地方设置,作用也不相同。	

1、变量

系统变量全局变量作用域:mysql服务器每次启动都会为所有的系统变量设置初始值。我们为系统变量赋值,针对所有会话(连接)有效,可以跨连接,但不能跨重启,重启之后,mysql服务器会再次为所有系统变量赋初始值。会话变量:作用域:针对当前会话(连接)有效,不能跨连接。会话变量是在连接创建时由mysql自动给当前会话设置的变量。>-- show [global|session] variables  lile '%变量名%'>-- select @@[global.|session.]系统变量名称;>-- set [global|session|persist] 系统变量名=;  修改变量值 eg: >set global password_history=1;
自定义变量概念:变量由用户自定义的,而不是系统提供的。作用域:针对当前会话(连接)有效,作用域同会话变量。局部变量:declare用于定义局部变量变量,在存储过程和函数中通过declare定义变量在begin…end中,且在语句之前。并且可以通过重复定义多个变量。(declare变量的作用范围同编程里面类似,在这里一般是在对应的begin和end之间。在end之后这个变量就没有作用了,不能使用了。这个同编程一样。)
-- set @变量名=;
-- set @变量名:=;
-- select @变量名:=;
-- set中=号前面冒号是可选的,select方式=前面必须有冒号
赋值(更新变量的值)
set @变量名=;
set @变量名:=;
select @变量名:=;select @变量名
#查看字符集
mysql> show variables like 'character%';
+--------------------------+----------------------------+
| Variable_name            | Value                      |
+--------------------------+----------------------------+
| character_set_client     | utf8mb4                    |
| character_set_connection | utf8mb4                    |
| character_set_database   | utf8mb4                    |
| character_set_filesystem | binary                     |
| character_set_results    | utf8mb4                    |
| character_set_server     | utf8mb4                    |
| character_set_system     | utf8mb3                    |
| character_sets_dir       | /usr/share/mysql/charsets/ |
+--------------------------+----------------------------+

在这里插入图片描述

修改mysql默认字符集

  • 1.在[mysqld]下添加
    character-set-server=utf8
    init_connect = ‘SET NAMES utf8’
  • 2.在[client]下添加
    default-character-set=utf8
  • 3.5.8开始,官方建议使用utf8mb4。
#查看当前mysql服务实例支持的校对规则
mysql> show collation;
| Collation                   | Charset  | Id  | Default | Compiled | Sortlen | Pad_attribute |
| armscii8_bin                | armscii8 |  64 |         | Yes      |       1 | PAD SPACE     |

在这里插入图片描述

Collation 字符集校对规则名称。MySQL校对规则名称是:以对应的字符集名称开头,以国家名居中(或以general居中),以ci、cs或bin结尾。【ci表示大小写不敏感,cs表示大小写敏感,bin表示按二进制编码值比较。】
Charset 与字符集校对规则关联的字符集名称
Id 字符集校对规则编号
Default 是不是对应字符集默认的校对规则
Compiled 是否有将此字符集校对规则集成到服务器中
Sortlen 这个与字符串表示的字符集所需要的内存数量有关
Pad_attribute 控制字符串尾部空格处理方式。PAD SPACE:在排序和比较运算中,忽略字符串尾部空格;NO PAD:在排序和比较运算中,字符串尾部空格当成普通字符,不能忽略。

2、utf8和utf8mb4的区别

MySQL在5.5.3之后增加了这个utf8mb4的编码,mb4就是most bytes 4的意思,专门用来兼容四字节的unicode。好在utf8mb4是utf8的超集,除了将编码改为utf8mb4外不需要做其他转换。当然,为了节省空间,一般情况下使用utf8也就够了。

既然utf8能够存下大部分中文汉字,那为什么还要使用utf8mb4呢? 原来mysql支持的 utf8 编码最大字符长度为 3 字节,如果遇到 4 字节的宽字符就会插入异常了。三个字节的 UTF-8 最大能编码的 Unicode 字符是 0xffff,也就是 Unicode 中的基本多文种平面(BMP)。也就是说,任何不在基本多文本平面的 Unicode字符,都无法使用 Mysql 的 utf8 字符集存储。包括 Emoji 表情(Emoji 是一种特殊的 Unicode 编码,常见于 ios 和 android 手机上),和很多不常用的汉字,以及任何新增的 Unicode 字符,如表情等等(utf8的缺点)。

因此在8.0之后,建议大家使用utf8mb4这种编码。

查看MYSQL所支持的字符集
mysql> show charset;
mysql>SHOW COLLATION;”即可查看当前MySQL服务实例支持的字符序(校验码)
自定义字符集的方式
方式一:服务器级别
mysql>SHOW VARIABLES like 'character%';
mysql>show variables like 'collation%';    字符序character_set_client:MySQL客户机字符集。character_set_connection:数据通信链路字符集,当MySQL客户机向服务器发送请求时,请求数据以该字符                               集进行编码。character_set_database:数据库字符集。character_set_filesystem:MySQL服务器文件系统字符集,该值是固定的binary。character_set_results:结果集的字符集,MySQL服务器向MySQL客户机返回执行结果时,执行结果以该字符                            集进行编码。character_set_server:MySQL服务实例字符集。character_set_system:元数据(字段名、表名、数据库名等) 的字符集,默认值为utf8。# vim /etc/mysql/my.cnf
5.5以前系统,在【client】下面加入 default-character-set=utf8
[client]
default-character-set=utf8
5.5版本以后的系统
[client]
default-character-set=utf8
[mysqld]
default-storage-engine=INNODB
character-set-server=utf8
collation-server=utf8_general_ci
重启服务查看测试
mysql> show variables like 'char%';
注意:修改my.cnf是对今后所创建的数据库起作用,修改的是mysql默认的字符集,但是不能修改已经创建好的数据库编码,已经创建好的需要重新进行修改。这里建议在修改了单个数据库之后,最好是将全局的默认编码也一并改过来,省的以后在出现相似的问题

在这里插入图片描述

方式二:(自定义数据库更改字符集)
mysql> show create database db2;
mysql> alter database db1 default character set  utf8;  更改数据库的字符集
mysql> alter database db1 default character set  utf8mb4  collate  utf8mb4_general_ci;
mysql> create database db2 default character set=utf8;
mysql> create  database db2 default character set gbk;
方式三:(自定义表数据字符集)
mysql> show create table student\G
mysql> create table  student (id num,name char(10),tel int) default character utf8;
mysql> alter table student convert to character set gbk;或者 alter table t4 default character set utf8;
方式四:(修改指定字段的字符集)
mysql> alter table test1 modify name char(10) character set utf8;
mysql> show full columns from test1\G....*************************** 2. row ***************************Field: nameType: char(10)Collation: utf8_general_ciNull: YESKey: Default: NULLExtra: Privileges: select,insert,update,referencesComment: 2 rows in set (0.00 sec)

四、数据库对象

数据库对象的命名规则:

  • 必须以字母开头
  • 可包括数字和特殊字符(_和$)
  • 不要使用MySQL的保留字
  • 同一Schema下的对象不能同名

五、SELECT语句

1、简单的SELECT语句

  • 1.select语法
#简单的SELECT语句:
SELECT {*, column [alias],...}
FROM table;
说明:
select *表示所有列。
FROM 提供数据源(表名/视图名)
  • 2、SELECT语句中的算术表达式:
    对数值型数据列、变量、常量可以使用算数操作符创建表达式(+ - * / %)
    对日期型数据列、变量、常量可以使用部分算数操作符创建表达式(+ -)
    运算符不仅可以在列和常量之间进行运算,也可以在多列之间进行运算。

运算符的优先级:
乘法和除法的优先级高于加法和减法;
同级运算的顺序是从左到右;
表达式中使用括号可强行改变优先级的运算顺序;

1、导入实验sqlmysql> source /root/myemployees.sql

在这里插入图片描述

2、熟悉四张表使用该数据库mysql> use myemployees;Database changed查看数据库中的表mysql> show tables;+-----------------------+| Tables_in_myemployees |+-----------------------+| departments           || employees             || jobs                  || locations             |+-----------------------+4 rows in set (0.00 sec)查询表中内容mysql> select * from departments;mysql> select * from employees;mysql> select * from jobs;mysql> select * from locations;查看表结构mysql> desc departments;mysql> desc employees;mysql> desc jobs;mysql> desc locations;

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

3、select 语法SELECT[ALL | DISTINCT | DISTINCTROW ][HIGH_PRIORITY][STRAIGHT_JOIN][SQL_SMALL_RESULT] [SQL_BIG_RESULT] [SQL_BUFFER_RESULT][SQL_NO_CACHE] [SQL_CALC_FOUND_ROWS]select_expr [, select_expr] ...[into_option][FROM table_references[PARTITION partition_list]][WHERE where_condition][GROUP BY {col_name | expr | position}, ... [WITH ROLLUP]][HAVING where_condition][WINDOW window_name AS (window_spec)[, window_name AS (window_spec)] ...][ORDER BY {col_name | expr | position}[ASC | DESC], ... [WITH ROLLUP]][LIMIT {[offset,] row_count | row_count OFFSET offset}][into_option][FOR {UPDATE | SHARE}[OF tbl_name [, tbl_name] ...][NOWAIT | SKIP LOCKED]| LOCK IN SHARE MODE][into_option]into_option: {INTO OUTFILE 'file_name'[CHARACTER SET charset_name]export_options| INTO DUMPFILE 'file_name'| INTO var_name [, var_name] ...}
基础语法:select 字段列表 from 数据源;
完整语法:select 去重选项 字段列表 [as 字段别名] from 数据源 [where子句] [group by 子句] [having子句] [order by 子句] [limit子句];select 要查询的信息 from 表名;  要查询你的信息可以是什么:(1)表中的一个字段或很多字段(中间用“,”分开)as  字段别名(2)常量值(3)表达式(4)函数
(1)查询表字段(all   distinct)#查询单个字段mysql> select first_name from employees;#查询多个字段mysql> select first_name,last_name from employees;#查询所有字段mysql> select * from employees;#去重复 distinct,#DISTINCT的作用范围是后面所有字段的组合mysql> select distinct department_id from employees;

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

(2)查询常量mysql> select 100;+-----+| 100 |+-----+| 100 |+-----+1 row in set (0.00 sec)注意:在数据库中表数据字符一定要用单引号mysql> select 'john';+------+| john |+------+| john |+------+1 row in set (0.00 sec)

在这里插入图片描述

(3)查询表达式mysql> select 1+1;+-----+| 1+1 |+-----+|   2 |+-----+1 row in set (0.00 sec)#dual特殊表,虚拟表主要是为了使执行的select语句的语法完整mysql> select 1 + 1 from dual;+-------+| 1 + 1 |+-------+|     2 |+-------+1 row in set (0.00 sec)mysql> select 100%98;+--------+| 100%98 |+--------+|      2 |+--------+1 row in set (0.00 sec)+符号的作用mysql> select 100+90;+--------+| 100+90 |+--------+|    190 |+--------+1 row in set (0.00 sec)#当有字符型的时候,它会试图将字符型转换成数值型,然后再计算。mysql> select '123'+100;+-----------+| '123'+100 |+-----------+|       223 |+-----------+1 row in set (0.00 sec)#如果字符型不能转换,它就会自动将字符型转换为0,然后再计算。mysql> select 'abc'+90;+----------+| 'abc'+90 |+----------+|       90 |+----------+1 row in set, 1 warning (0.00 sec)#NULL+任何东西的结果为NULL,null是一种状态不是一种数据类型mysql> select null+'hehe';+-------------+| null+'hehe' |+-------------+|        NULL |+-------------+1 row in set, 1 warning (0.00 sec)补充说明:MySQL的+默认只有一个功能:运算符
SELECT 100+80; # 结果为180
SELECT '123'+80; # 只要其中一个为数值,则试图将字符型转换成数值,转换成功做预算,结果为203
SELECT 'abc'+80; # 转换不成功,则字符型数值为0,结果为80
SELECT 'This'+'is'; # 转换不成功,结果为0
SELECT NULL+80; # 只要其中一个为NULL,则结果为NULL
null值使用
空值是指不可用、未分配的值
空值不等于零或空格
任意类型都可以支持空值
(包括空值的任何算术表达式都等于空)
字符串和null进行连接运算,得到也是null

在这里插入图片描述
在这里插入图片描述

(4)查询函数mysql> select version();+-----------+| version() |+-----------+| 8.0.34    |+-----------+1 row in set (0.00 sec)#字段别名

在这里插入图片描述

(5)查询定义别名as 可以省略
改变列的标题头
用于表示计算结果的含义
作为列的别名
如果别名中使用特殊字符,或者是强制大小写敏感,或有空格时,都可以通过为别名添加加双引号实现。mysql> select 100%98 as 余数结果;+--------------+| 余数结果     |+--------------+|            2 |+--------------+1 row in set (0.00 sec)mysql> select 100%98 余数;+--------+| 余数   |+--------+|      2 |+--------+1 row in set (0.00 sec)

在这里插入图片描述

函数连接姓名进行查询concat mysql> select last_name+first_name as 姓名 from employees;  这个无法实现mysql> select concat (last_name,first_name) as 姓名 from employees;
案列:查询salary,并起别名为 out put,别名里有特殊符号空格,这时要加单引号。mysql> select salary as 'out put' from employees;
ifnull()函数
ifnull(expression,alt_values) 当第一个参数的表达式expression为null,则返回第二参数的备用值。

在这里插入图片描述

练习:
1.显示表departments的结构,查询它的全部数据。
explain  desc  describe
>desc departments;
>select *  from departments;2.显示employees中的全部job_id(不能重复)
select distinct job_id from employees;
3.显示employees的全部列(注意commission_pct有可能为null),各列之间用逗号链接,列头显示OUT_PUT
select concat(employee_id,',',first_name,',',ifnull(commission_pct,0),',',hiredate) as out_put from employees;1.desc departments;
select * from departments;
2....distinct....;
3.select concat(first_name,',',last_name,',',ifnull(commission_pct,0),......) from employees;

2、SQL函数

2.1 聚合函数

聚合函数对一组值进行运算,并返回单个值。也叫分组函数。

COUNT(*|列名) 统计行数,*表示所有记录都不忽略,指定列名时会忽略null
AVG(数值类型列名) 平均值,忽略null
SUM (数值类型列名) 求和,忽略null
MAX(列名) 最大值,忽略null
MIN(列名) 最小值,忽略null
2.2 数值型函数
函数名称作用
ABS()求绝对值
SQRT求平方根
POW 和 POWER(2,3)两个函数的功能相同,返回参数的幂次方
MOD(10,3)求余数
CEIL 和 CEILING两个函数功能相同,都是返回不小于参数的最小整数,即向上取整
FLOOR向下取整,返回值转化为一个BIGINT
RAND生成一个0~1之间的随机数,传入整数参数时,用来产生重复序列; # rand() --> 属于[0,1) # rand() * 6 --> 属于[0,6) ,达不到6,可以达到5 # rand() * 6 + 5 --> 属于[5,11) ,达不到11,可以达到10 # floor(rand() * 6 + 5) --> 属于[5,10]
ROUND对所传参数进行四舍五入
SIGN返回参数的符号(-1表示负值,0,1表示正数)
2.3 字符串函数
函数名称作用
LENGTH(‘str’)计算字符串长度函数,返回字符串的字节长度
CHAR_LENGTH(‘str’)计算字符串长度函数,返回字符串的字符长度,注意两者的区别
CONCAT(‘column1’,‘column2,’…)合并字符串函数,返回结果为连接参数产生的字符串,参数可以是一个或多个
INSERT(str,pos,len,newstr)替换字符串函数从第pos字符还是将len长度的字符替换为新字符
LOWER(‘Str’)将字符串中的字母转换为小写
UPPER(‘str’)将字符串中的字母转换为大写
LEFT(str,len)从左侧字截取符串,返回字符串左边的若干个字符
RIGHT(str,len)从右侧字截取符串,返回字符串右边的若干个字符
TRIM(’ str ') trim(j from ‘jaj’)删除字符串左右两侧的空格
REPLACE(s,s1,s2)字符串替换函数,返回替换后的新字符串
SUBSTRING(str,n,len)截取字符串,返回从指定位置开始的指定长度的字符换
REVERSE(‘’)字符串反转(逆序)函数,返回与原始字符串顺序相反的字符串
STRCMP(expr1,expr2)比较两个表达式的顺序。若expr1 小于 expr2 ,则返回 -1,0相等,1则相反
LOCATE(substr,str [,pos])返回第一次出现子串的位置
INSTR(str,substr)返回第一次出现子串的位置
2.4 日期和时间函数
函数名称作用
CURDATE()
CURRENT_DATE()
CURRENT_DATE
两个函数作用相同,返回当前系统的日期值
CURTIME
CURRENT_TIME()
CURRENT_TIME
两个函数作用相同,返回当前系统的时间值
NOW()返回当前系统的日期和时间值
SYSDATE返回当前系统的日期和时间值
DATE获取指定日期时间的日期部分
TIME获取指定日期时间的时间部分
MONTH获取指定日期中的月份
MONTHNAME获取指定曰期对应的月份的英文名称
DAYNAME获取指定曰期对应的星期几的英文名称
YEAR获取年份,返回值范围是 1970〜2069
DAYOFWEEK获取指定日期对应的一周的索引位置值,也就是星期数,注意周日是开始日,为1
WEEK获取指定日期是一年中的第几周,返回值的范围是否为 0〜52 或 1
〜53
DAYOFYEAR获取指定曰期是一年中的第几天,返回值范围是1~366
DAYOFMONTH 和 DAY两个函数作用相同,获取指定日期是一个月中是第几天,返回值范围是1~31
DATEDIFF(expr1,expr2)返回两个日期之间的相差天数,如
SELECT DATEDIFF(‘2007-12-31 23:59:59’,‘2007-12-30’);
SEC_TO_TIME将秒数转换为时间,与TIME_TO_SEC 互为反函数
TIME_TO_SEC将时间参数转换为秒数,是指将传入的时间转换成距离当天00:00:00的秒数,00:00:00为基数,等于 0 秒
2.5 流程控制函数
函数名称作用
IF(expr,v1,v2)判断,流程控制,当expr = true时,或者为1时返回 v1,当expr = false、null 、0时返回v2
IFNULL(v1,v2)判断是否为空,如果 v1 不为 NULL,则 IFNULL 函数返回 v1,否则返回 v2
CASE搜索语句

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

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

相关文章

云原生开发:从容器到微服务的全栈指南

文章目录 什么是云原生开发&#xff1f;1. 容器化2. 微服务架构 云原生开发的优势1. 可伸缩性2. 高可用性3. 灵活性4. 快速交付 云原生开发的1. 学习曲线2. 复杂性3. 运维挑战 云原生开发的最佳实践1. 自动化部署2. 监控和日志3. 安全性4. 弹性设计5. 文档和培训 未来展望结论 …

C++ 迭代器(iterator)

迭代器介绍 迭代器&#xff08;iterator&#xff09;&#xff1a;容器类型内置的“指针” - 使用迭代器可以访问某个元素&#xff0c;迭代器也能从一个元素移动到另一个元素。 - 有迭代器的类型都拥有 begin 和 end 成员- begin&#xff1a;返回指向第一个元素&#xff08;或字…

博客无限滚动加载(html、css、js)实现

介绍 这是一个简单实现了类似博客瀑布流加载功能的页面&#xff0c;使用html、css、js实现。简单易懂&#xff0c;值得学习借鉴。&#x1f44d; 演示地址&#xff1a;https://i_dog.gitee.io/easy-web-projects/infinite_scroll_blog/index.html 代码 index.html <!DOCT…

知识工程---neo4j 5.12.0+GDS2.4.6安装

&#xff08;已安装好neo4j community 5.12.0&#xff09; 一. GDS下载 jar包下载地址&#xff1a;https://neo4j.com/graph-data-science-software/ 下载得到一个zip压缩包&#xff0c;解压后得到jar包。 二. GDS安装及配置 将解压得到的jar包放入neo4j安装目录下的plugi…

【数据结构--八大排序】之冒泡排序+选择排序+插入排序

&#x1f490; &#x1f338; &#x1f337; &#x1f340; &#x1f339; &#x1f33b; &#x1f33a; &#x1f341; &#x1f343; &#x1f342; &#x1f33f; &#x1f344;&#x1f35d; &#x1f35b; &#x1f364; &#x1f4c3;个人主页 &#xff1a;阿然成长日记 …

ROS系统读取USB相机图像数据

ROS系统读取USB相机图像数据 前言usb_cam 功能包下载与编译摄像头选择连接摄像头可配置参数 前言 usb_cam功能包简介 为了丰富机器人与外界的交互方式&#xff0c;已经增加了与机器人的语音交互方式&#xff0c;不仅使机器人能够说话发声&#xff0c;还能听懂我们说的话&#…

26947-2011 手动托盘搬运车 学习记录

声明 本文是学习GB-T 26947-2011 手动托盘搬运车. 而整理的学习笔记,分享出来希望更多人受益,如果存在侵权请及时联系我们 1 范围 本标准规定了手动托盘搬运车(以下简称托盘车)的结构参数、技术要求、试验方法、检验规则、 标志、包装、运输和贮存。 本标准适用于额定载荷…

GPIO的输入模式

1. GPIO支持4种输入模式&#xff08;浮空输入、上拉输入、下拉输入、模拟输入&#xff09; 1. 模拟输入 首先GPIO输出部分(N-MOS,P-MOS)是不起作用的。并且TTL施密特触发器也是不工作的。 上下拉电阻的开关都是关闭的。相当于I/o直接接在模拟输入。 模拟输入模式下&#xff…

【每日一题】种花问题

文章目录 Tag题目来源题目解读解题思路方法一&#xff1a;贪心 写在最后 Tag 【贪心】【数组】【2023-09-29】 题目来源 605. 种花问题 题目解读 种花要种在空地&#xff08;没有种过花的位置&#xff09;上&#xff0c;花不能种在相邻位置上否则会抢夺水资源无法正常生长&a…

ChatGPT,AIGC 助力人力资源管理对身份证号处理

HR&#xff0c;行政&#xff0c;文员办公对于员工信息管理中有一项目非常重要的操作&#xff0c;便是从身份证号中提取相关信息如下&#xff1a; 可以用ChatGPT完成三个字段的提取与计算。 我们先让ChatGPT描述一下身份证号每一位都代表什么意思。 接下来从身份证号中提取出生…

集合-ArrayList源码分析(面试)

系列文章目录 1.集合-Collection-CSDN博客​​​​​​ 2.集合-List集合-CSDN博客 3.集合-ArrayList源码分析(面试)_喜欢吃animal milk的博客-CSDN博客 目录 系列文章目录 前言 一 . 什么是ArrayList? 二 . ArrayList集合底层原理 总结 前言 大家好,今天给大家讲一下Arra…

高仿互站网多套模板完整源码

高仿互站网 后台手机端两套模板 电脑端二十套模版&#xff0c;简单介绍几个功能&#xff0c; 支持用户注册开店 开店申请&#xff0c;支持用户发布自己商品 支持卡密形式或实物形式&#xff0c; 支持用户自己发布求助 任务大厅功能&#xff0c;源码完整 更多功能自己去发现吧…

iTOP-RK3588开发板体验RKNN_DEMO

RKNN 是 Rockchip NPU 平台(也就是开发板)使用的模型类型&#xff0c;是以.rknn 结尾的模型文件。 RKNN SDK 提 供 的 demo 程 序 中 默 认 自 带 了 RKNN 模 型 &#xff0c; 在 RKNN SDK 的 examples/rknn_yolov5_demo/model/RK3588/目录下&#xff0c;如下图所示&#xff…

爬取北京新发地当天货物信息并展示十五天价格变化(三)---获取物品十五天内的价格

。。。。。。。。。。。。。。。。。。。。。。 1.网页请求一下内容2.通过爬虫进行请求3.获取商品十五天详细数据并绘制折线图4.项目详细代码 1.网页请求一下内容 通过抓包我们发现一共七个参数 limit: 20 # 一页多少数据 current: …

Python计算巴氏距离

Python计算巴氏距离 巴氏距离简介 在统计中&#xff0c;巴氏距离&#xff08;Bhattacharyya Distance&#xff09;测量两个离散或连续概率分布的相似性。它与衡量两个统计样品或种群之间的重叠量的巴氏系数密切相关。巴氏距离和巴氏系数以20世纪30年代曾在印度统计研究所工作…

大麦订单截图生成 大麦一键生成订单截图

新版大麦订单生成 图样式展示 这个样式图就是在大麦生成完的一个订单截图&#xff0c;它的状态是等待卖家发货 后台一键生成&#xff0c;独立后台管理 教程&#xff1a;修改conf数据库账号密码 不会的可以看源码里有搭建教程 下载程序&#xff1a;https://pan.baidu.com/…

Android widget 小部件使用指南强化版

Android widget 小部件使用指南强化版 一、简单UI的小部件二、含集合的小部件三、可配置的小部件四、可控制的小部件五、Android 12 Widget 更新 小部件是主屏幕定制的一个重要方面。您可以将它们视为应用程序最重要的数据和功能的“概览”视图&#xff0c;这些数据和功能可以直…

如何在 Elasticsearch 中使用 Openai Embedding 进行语义搜索

随着强大的 GPT 模型的出现&#xff0c;文本的语义提取得到了改进。 在本文中&#xff0c;我们将使用嵌入向量在文档中进行搜索&#xff0c;而不是使用关键字进行老式搜索。 什么是嵌入 - embedding&#xff1f; 在深度学习术语中&#xff0c;嵌入是文本或图像等内容的数字表示…

使用GDIView排查GDI对象泄漏导致的程序UI界面绘制异常问题

目录 1、问题说明 2、初步分析 3、查看任务管理器&#xff0c;并使用GDIView工具分析 4、GDIView可能对Win10兼容性不好&#xff0c;显示的GDI对象个数不太准确 5、采用历史版本比对法&#xff0c;确定初次出现问题的时间点&#xff0c;并查看前一天的代码修改记录 6、将…

MySQL架构 InnoDB存储引擎

1. 什么是Mysql&#xff1f; 我们在开发的时候&#xff0c;我们都需要对业务数据进行存储&#xff0c;这个时候&#xff0c;你们就会用到MySQL、Oracal等数据库。 MySQL它是一个关系型数据库&#xff0c;这种关系型数据库就有Oracal、 MySQL&#xff0c;以及最近很火的PgSQL等。…