重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
1、首先通过运行数据库客户端管理软件SQLyogEnt进行查询,第一步运行SQLyogEnt,在桌面找到SQLyogEnt的软件图标,用户双击这个图标。
创新互联建站专注于莘县网站建设服务及定制,我们拥有丰富的企业做网站经验。 热诚为您提供莘县营销型网站建设,莘县网站制作、莘县网页设计、莘县网站官网定制、成都小程序开发服务,打造莘县网络公司原创品牌,更为您提供莘县网站排名全网营销落地服务。
2、然后输入数据库的信息,在界面左下角点击【连接】按钮,连接数据库。
3、连接上数据库后就进入了数据库管理软件的控制台,控制台的左侧以目录的形式显示了当前登录的用户和数据库以及数据库的表。目录的右边从上到下有2个空白的长方形框,上方的是SQL查询语言的输入框,下方显示的是查询所得到的结果。
4、有时候一个数据库IP新建了多个数据库,在查询前要用数据在控制台左侧目录上选择需要操作的数据库,然后在进行查询。
5、上面说道了SQL的长方形空白的输入框,现在我们对数据库表进行一次查询吧。如果要查询一个表中所有的信息可以输入:SELECT * FROM TABLE_Name
6、查询表中的某一条数据:SELECT * FROM Table_Name WHERE id=XXXX 注意这里的id选择表中的唯一键,就是用于标识这条数据与其他数据不同的字段
显示某个字段的数据信息:如name
SELECT name FROM Table_Name WHERE id=XXXX
数据查询语言(凡是带有 select 关键字的都是查询语句)
select...
数据操作语言(凡是对表中的 数据 进行增删改的都是 DML)
insert 增 delete 删 update 改
数据定义语言(凡是带有 create、drop、alter 的都是 DDL)
主要操作的是 表的结构 ,不是表的数据
事务控制语言(包括:事务提交 commit、事务回滚 rollback)
数据控制语言(授权 grant、撤销权限 revoke)
select 字段 from 表名 where 条件;
in(具体值,具体值,......) 不是区间
一个输入对应一个输出,和其对应的是多行处理函数(多个输入,对应一个输出)
输入多行,最终输出一行
如果你 没有对数据进行分组,整张表默认为一组 。
在实际的应用中,可能需要先进行分组,然后对每一组的数据进行操作
案例: 查询每个员工所在部门的名称,显示员工名和部门名?
emp e 和 dept d 表进行连接。条件是:e.deptno = d.deptno
SQL92语法:(结构不够清晰,表的连接条件和后期进一步筛选的条件,都放到了 where 子句中)
SQL99语法:(表连接的条件是独立的,连接之后,如果还需要进一步筛选,再往后继续添加 where 子句)
技巧: 把一张表看成两张表
思考: 外连接的查询结果条数 = 内连接的查询结果条数
select 语句中 嵌套 select 语句,被嵌套的 select 语句称为 子查询。
将查询结果集的一部分取出来。(通常使用在分页查询当中)
将字符串 varchar 类型转换成 date 类型
将日期转换成字符串
可以获取当前系统的时间,并且获取的时间是 datetime 类型的
注意:若没有条件限制将会导致所有数据全部更新。
注意:若没有条件,会删除整张表的数据。
constraint
not null 约束的字段 不能为 NULL (只有列级约束)
unique 约束的字段 不能重复 ,但是可以为 NULL
primary key
foreign key
transaction
实现原理 :缩小扫描的范围(形成树),避免全表扫描
Database Administrator 数据库管理员
数据库表的设计依据。教你怎么进行数据库表的设计。
免费领取有关于java面试题材料和讲解!
方法/步骤
第一步,双击打开MySQL Workbench,新建一个数据库worker,设置数据库编码格式是utf-8,点击“Apply”,创建数据库编码
CREATE SCHEMA `worker` DEFAULT CHARACTER SET utf8 ;
如下图所示:
第二步,使用worker数据库,查看数据库表情况,可以使用show命令,如下图所示:
第三步,新建一张worker信息表,创建数据库表SQL语句具体如下:
create table t_worker_info(
id int(8) primary key,
worker_id int(6) not null,
worker_name varchar(20) not null,
worker_age int(2),
worker_sex varchar(2),
worker_addr varchar(100)
);
如下图所示:
第四步,数据库表t_worker_info建好了后,向表里插入一些数据,插入数据SQL语句
insert into t_worker_info (id,worker_id,worker_name,worker_age,worker_sex,worker_addr)
values (20150101,100,'zhangsan',34,'M','hubei');
如下图所示:
第五步,创建数据库查询存储过程query_procedure,具体实现如下图所示:
第六步,编写完了存储过程后,在查询窗口调用存储过程
call query_procedure(30,'M');
如下图所示:
# SELECT 数据查询
## 基础
显示如何使用简单的`select`语句查询单个表中的数据 使用`SELECT`语句从表或视图获取数据。
表由行和列组成,如电子表格。 通常,我们只希望看到子集行,列的子集或两者的组合。
SELECT语句的结果称为结果集,它是行列表,每行由相同数量的列组成。
select 语法
SELECT语句由以下列表中所述的几个子句组成:
1. SELECT 之后是逗号分隔列或星号(*)的列表,表示要返回所有列。
2. FROM 指定要查询数据的表或视图。
3. JOIN 根据某些连接条件从其他表中获取数据。
4. WHER E过滤结果集中的行。
5. GROUP BY将一组行组合成小分组,并对每个小分组应用聚合函数。
6. HAVING 过滤器基于GROUP BY子句定义的小分组。
7. ORDER BY 指定用于排序的列的列表。
8. LIMIT 限制返回行的数量。
语句中的`SELECT`和`FROM`语句是必须的,其他部分是可选的。
`SELECT`语句允许通过在`SELECT`子句中指定逗号分隔列的列表来查询表的部分数据
建议显式获取数据的列,原因如下:
1. 使用星号(*)可能会返回不使用的列的数据。 它在MySQL数据库服务器和应用程序之间产生不必要的I/O磁盘和网络流量。
2. 如果明确指定列,则结果集更可预测并且更易于管理。 想象一下,当您使用星号(*)并且有人通过添加更多列来更改表格数据时,将会得到一个与预期不同的结果集。
3. 使用星号(*)可能会将敏感信息暴露给未经授权的用户
格式 `select 列筛选 form table where 行筛选`
还有一些有用的运算符可以在WHERE子句中使用来形成复杂的条件,例如:
BETWEEN 选择在给定范围之内的值。
LIKE 匹配基于模式匹配的值。
IN 指定值是否匹配列表中的任何值。
IS NULL 检查该值是否为NULL。
## SELECT 子查询
在一个查询过程中 嵌套另一个查询,子查询的结果作为外部查询的条件或者数据范围来使用。
分为 3 类:
1. where 型
- `select展示列名 from 表名 where 列名 运算符[in...] (select 对应列名 from ...)`
- 这个列名 和 对应列名 应该做到类型相同
- 如果不加入运算符 也可使用IN 这些类似的符号 - `select 展示列名 from 表名 where 列名 in (select 对应列名 from ...)`
- ex:
`select 展示列名 from 表名 where 列名 ALL(select 对应列名 from ....)`;
比子查询的值都大
`select 展示列名 from 表名 where 列名 ANY(select 对应列名 from ....);`
比子查询的任意一个值大
2. from 型
- `select 展示列名 from 表名 inner join (select 列名 from ...) 临时表名 on 条件;`
- 其中,select的子查询所得的表 为临时表,后跟临时表名,可在条件判断中指代
3. exist 型
- `select 展示列 from 表名 where exists (select 列名 from 表名 where 条件);`
- 将主查询的结果带入子查询进行条件判断和匹配,如果查询出结果即保留。
## 去重 DISTINCT
SELECT 语句执行简单的数据查询时,返回的是所有匹配的记录。`distinct` 实现查询不重复的数据
**DISTINCT 关键字的主要作用就是对数据表中一个或多个字段重复的数据进行过滤,只返回其中的一条数据给用户。**
使用 `DISTINCT` 关键字时需要注意以下几点:
- `DISTINCT` 关键字只能在 `SELECT` 语句中使用。
- 在对一个或多个字段去重时,`DISTINCT` 关键字必须在所有字段的最前面。
- 如果 `DISTINCT` 关键字后有多个字段,则会对多个字段进行组合去重,也就是说,只有多个字段组合起来完全是一样的情况下才会被去重。
## 指定别名 AS
### 1. 为表指定别名
1. 当表名很长的时候 或者 执行了一些特殊的查询的时候,为方便操作,可以为表指定一个别名,用以替代原来的名称
2. 语法.
3. `表名 as 别名` - 含义: - `表名` : 数据库中存储的数据表名称。
- `别名` : 查询的时候指定的新的名称。
- `as` : 此关键字 可以 省略,省略之后要将 `表名`与`别名`用 `空格` 分开
** *注意:表的别名不能与该数据库的其它表同名。字段的别名不能与该表的其它字段同名。在条件表达式中不能使用字段的别名,否则会出现“ERROR 1054 (42S22): Unknown column”这样的错误提示信息。* **
*** ex1:
***
### 2. 为字段指定别名
1. 在使用 SELECT 语句查询数据时,MySQL 会显示每个 SELECT 后面指定输出的字段。有时为了显示结果更加直观,我们可以为字段指定一个别名。
2. 语法:
3. `字段名 [AS] 别名`
- 含义:
- `字段名`:为数据表中字段定义的名称。
- `字段别名`:字段新的名称。
- `AS` 关键字可以省略,省略后需要将字段名和别名用空格隔开
** *注意:表别名只在执行查询时使用,并不在返回结果中显示。而字段定义别名之后,会返回给客户端显示,显示的字段为字段的别名* ** ***
ex2:
***
## 限制查询条数 LIMIT
1. LIMIT 关键字有 3 种使用方式,即
- `指定初始位置`、
- `不指定初始位置`
- `OFFSET 组合`使用
(。。。。。 我之前一直不知道, 只会使用 `limit 200`。。。。。)
### 指定初始位置
1. 语法
- `LIMIT 初始位置,记录数`
- 初始位置”表示从哪条记录开始显示;第一条记录的位置是 0,第二条记录的位置是 1。后面的记录依次类推。
- “记录数”表示显示记录的条数。
- *LIMIT 后的两个参数必须都是正整数。
* ex:tb_students_info 表中,使用 LIMIT 子句返回从第 4 条记录开始的行数为 5 的记录,SQL 语句和运行结果如下。
### 不指定初始位置
记录从第一条记录开始显示。显示记录的条数由 LIMIT 关键字指定。
1. 语法
- `LIMIT 5`
- `SELECT * FROM tb_students_info LIMIT 15;`
### LIMIT 和 OFFSET 组合使用
1. 语法
- `LIMIT 记录数 OFFSET 初始位置`
- 参数和 LIMIT 语法中参数含义相同,“初始位置”指定从哪条记录开始显示;“记录数”表示显示记录的条数。
该语句返回的是从第 4 条记录开始的之后的 5 条记录。即“ LIMIT 5 OFFSET 3 ”意思是获取从第 4 条记录开始的后面的 5 条记录,和“ LIMIT 3 , 5 ”返回的结果相同。
*** 2021-12-22 今天先学到这里 明天继续 MySql 的查询 学习
# SELECT 数据查询(二)
## 对查询结果排序 ORDER BY
ORDER BY 关键字主要用来将查询结果中的数据按照一定的顺序进行排序
1. 语法: - `order by 字段名 [asc|desc]`
- 说明 asc 按照升序排序【默认】, desc 按照降序排序
2. 注意:
- ORDER BY 关键字后可以跟子查询 - 当排序的字段中存在空值时,ORDER BY 会将该空值作为最小值来对待
- 当排序的字段中存在空值时,ORDER BY 会将该空值作为最小值来对待查询数据按字母升序进行排序(A Z),但数据的排序并不仅限于此,还可以使用 ORDER BY 中的 DESC 对查询结果进行降序排序(Z A)。
## 条件查询数据 WHERE
如果需要有条件的从数据表中查询数据,可以使用 WHERE 关键字来指定查询条件。
1. 语法 - `WHERE conditons`
- 带比较运算符和逻辑运算符的查询条件
- 带 BETWEEN AND 关键字的查询条件
- 带 IS NULL 关键字的查询条件
- 带 IN 关键字的查询条件 - 带 LIKE 关键字的查询条件
### 单条件查询
### 多条件查询
在 WHERE 关键词后可以有多个查询条件,这样能够使查询结果更加精确。
多个查询条件时用逻辑运算符 `AND()、OR(||)` 或 `XOR` 隔开。
1. AND :记录 满足所有条件,才会被查询出结果
2. OR : 记录 满足任意一个查询条件,才会被查询出结果
3. XOR : 记录 满足其中一个条件,并且不满足另外一个条件是,才会被查询出结果
OR、AND 和 XOR 可以一起使用,但是在使用时要注意运算符的优先级。
### 模糊查询 LIKE [新知识 4me]
1. 语法:
- `[NOT]LIKE`
- NOT :可选参数,字段中的内容与指定的字符串不匹配时满足条件。
- 字符串:指定用来匹配的字符串。“字符串”可以是一个很完整的字符串,也可以包含通配符。
LIKE 关键字支持百分号` % `和下划线` _ `通配符。
#### 带有“%”通配符的查询
“%”是 MySQL 中最常用的通配符,它能代表 **任何长度的字符串** ,字符串的长度可以为 0。
例如,a%b表示以字母 a 开头,以字母 b 结尾的任意长度的字符串。该字符串可以代表 ab、acb、accb、accrb 等字符串。
注意:匹配的字符串必须加 *单引号* 或 *双引号* 。
#### 带有“_”通配符的查询
“_”只能代表单个字符,字符的长度不能为 0。 例如,a_b可以代表 acb、adb、aub 等字符串。
#### LIKE 区分大小写(默认不区分)
默认情况下,LIKE 关键字匹配字符的时候是 不 区分大小写的。如果需要 可以加入`BINARY`关键字
#### 使用通配符的注意事项和技巧
1. 注意事项:
- 注意大小写。MySQL 默认是不区分大小写的。如果区分大小写,像“Tom”这样的数据就不能被“t%”所匹配到。
- 注意尾部的空格 尾部空格会干扰通配符的匹配。例如,“T% ”就不能匹配到“Tom”。
- 注意NULL。”%”通配符可以到匹配任意字符,但是不能匹配 NULL。也就是说 “%”匹配不到 tb_students_info 数据表中值为 NULL 的记录。
2. 使用技巧:
- 不要过度使用通配符,如果其它操作符能达到相同的目的,应该使用其它操作符。因为 MySQL 对通配符的处理一般会比其他操作符花费更长的时间。
- 在确定使用通配符后,除非绝对有必要,否则不要把它们用在字符串的开始处。把通配符置于搜索模式的开始处,搜索起来是最慢的。
- 仔细注意通配符的位置。如果放错地方,可能不会返回想要的数据。 ** *拓展* ** 如果查询内容中包含通配符,可以使用“”转义符。
*** 2021-12-23 今天先学到这里 明天继续 MySql 的查询 学习