【编测编学】MySQL数据库基础知识

来源:这里教程网 时间:2026-03-01 15:33:34 作者:

一:数据库的相关概念  

1、 数据库的好处

 

可以持久化数据到本地

结构化查询

 

2、 数据库的常见概念

 

DB :数据库、存储数据的容器

DBMS :数据库管理系统,又称之为数据库软件或数据库产品,用于创建和管理DB

SQL :结构化查询语言,用于和数据库通讯的语言,不是某个数据库软件特有的,而是几乎所有主流的数据库软件通用的语言

 

3、 数据库存储数据的特点

 

数据存放到表中,表在放到库中

一个库可以由多张表,每张表具有唯一的表名来标识自己

表中有一个或多个列,列又称之为字段,相当于java中得属性

表中每一行数据,相当于Java中对象

 

4、 常见的数据库管理系统

Mysql   oracle     db2    sqlserver

  二:MySQL  

1、 优点

 

开源、免费、成本低

性能高、移植性好

体积小、便于安装

 

2、 MySQL 的安装

属于C\S架构的软件,一般来讲安装服务端

 

3、 MySQL 服务的启动和停止

 

通过命令

net start 服务名

net stop 服务名

计算机管理--------服务

 

4、 MySQL 服务的登录和退出

登录:mysql h 主机名 P 端口号 u 用户名 p 密码(默认端口3306,用户root)

退出:exit或者Ctrl+c

 

5、 mysql 的语法规范

 

不区分大小写,但是建议关键字大写,表名、列名小写

每条命令最好用分号结尾

每条命令根据需要,可以惊醒缩进,或者换行(建议关键字放一行,要查询的放一行)

注释

单行注释:#注释文字、--注释文字

多行注释:/*注释文字*/

show database();// 查看当前所有的数据库

use+ 库名;//打开指定的库

(只要用了use你就在那个库中了)

show tables;// 查看当前库所有的表

show tables from 库名;//查看其他库所有的表

create table 表名(

    列名 列类型,

    列名 列类型,

    ...

)// 创建表

desc 表名;//查看表的结构

查看服务器的版本:

方式一:登录到mysql服务端

select version();

方式二:没有登录到mysql服务端

mysql --version 或mysql --V   三、 MySQL 一些基础的查询 1 、基本要掌握的 select 查询列表 from 表名 USE manba;   #1. 查询表中的单个字段 SELECT last_name FROM manba;   #2. 查询表中的多个字段 SELECT last_name,salary,email FROM manba;   #3. 查询表中所有字段(双击左侧) # 方式一 SELECT   `department_id`,   `department_name`,   `manager_id`,   `location_id`  FROM   manba; # 方式二 SELECT * FROM manba ;   #4. 查询常量值 SELECT 100; SELECT 'john'; # (不区分字符和字符串)   #5. 查询表达式 SELECT 100%98;   #6. 查询函数 SELECT VERSION();   #7. 起别名 /* ①便于理解 ②如果要查询的字段有重名的情况,使用别名可以区分开来 */ # 方式一 : as SELECT 100%98 AS 结果 ; SELECT last_name AS ,first_name AS FROM manba;   # 方式二 : 空格 SELECT last_name 姓, first_name FROM manba; # 案例:查询 salary ,显示结果为 output SELECT salary AS "out put" FROM manba;     #8. 去重   # 案例:查询员工表涉及到的所有部门编号 SELECT DISTINCT department_id FROM manba;     #9. + 号的作用   /* java 中的 + 号: ①运算符:两个操作数都为数值型 ②连接符:只要有一个操作数为字符串   mysql 中的 + 号: 仅仅只有一个功能:运算符   select 100+90 select '123'+90; 其中一方为字符型,会试图将字符型数值转换成数值型                 如果转换成功则继续加法运算 select 'john'+90; 如果转换失败,则字符型数组值转换成 0   select null+10; 只要其中一方为 null ,则结果为 null */   # 案例:查询员工名和姓连接成一个字段,并显示为 姓名   SELECT CONCAT(last_name,first_name) AS 姓名 FROM manba;   #10. 判断是否为空 #commission_pct 是否为空?为空返回 0 SELECT        IFNULL(commission_pct,0) AS 奖金率 ,        commission_pct FROM        manba;   2 、条件查询2.1 按条件表达式查询 # 案例 1 :查询工资 >12000 的员工信息   SELECT * FROM manba WHERE salary>12000;        # 案例 2 :查询部门编号不等于 90 号的员工名和部门编号   SELECT last_name,department_id FROM manba WHERE department_id!=90;   2.2 按逻辑表达式查询 案例 1 :查询工资在 10000 20000 之间的员工名,工资和奖金   SELECT last_name, salary,commission_pct FROM manba WHERE salary>=10000 and salary<=20000        案例 2 :查询部门编号不在 90-110 之间,或者工资高于 15000 的员工信息 SELECT * FROM manba WHERE department_id<90 OR department_id>110 OR salary>15000;   2.3 模糊查询 2.3.1 一般和通配符搭配使用        通配符: % 任意多个字符,包含 0        _ 任意单个字符 案例 1 :查询员工名中包含字符 a 的员工信息 SELECT * from manba where last_name like '%a%'; % 代表通配符,代表任意个字符   案例 2 :查询员工名中第 3 个字符为 n ,第五个字符为 l 的员工名和工资 SELECT last_name salary  from manba where last_name like '__n_l%';         # 案例 3 :查询员工名中第二个字符为 _ 的员工名(转义字符)      SELECT last_name FROM manba WHERE  last_name LIKE '_\_%';              2.3.2between and ①使用 between and 可以提高语句的简洁度 ②包含临界值 ③两个临界值顺序不能调换   # 案例 1 :查询员工编号在 100 120 之间的员工信息   SELECT * from manba where manba_id between 100 and 200;   2.3.3.in 含义:用于判断某字段的值是否属于 in 列表中的某一项 特点:        ①使用 in 提高语句简洁度        in 列表的值类型必须统一或者兼容        ③不支持通配符   # 案例:查询员工的工种编号是 IT_PROT, AD_VP, AD_PRES 中的一个的员工名和工种编号 SELECT last_name,job_id FROMmanba WHERE job_id='IT_PROT' OR job_id='AD_VP' OR job_id='AD_VP';   SELECT last_name,job_id FROMmanba WHERE job_id IN ('IT_PROT' ,'AD_VP' , 'AD_VP');   2.3.4. is null(is not null) = 或者 <> 不能用于判断 null   # 案例 1 :查询没有奖金的员工名和奖金率 SELECT last_name,commission_pct FROM manba WHERE commission_pct IS NULL;   # 安全等于   <=>  is null 可以换成 <=> null   # 案例 1 :查询没有奖金的员工名和奖金率 SELECT last_name,commission_pct FROM manba WHERE commission_pct <=> NULL;        # 案例 12 :查询工资为 12000 的员工信息 SELECT last_name,salary FROM manba WHERE salary <=> 12000;   3 、排序查询 引入:        select * from manba; 语法:        SELECT 查询列表        from        [where 筛选条件 ]        order by 排序列表 [asc|desc] 特点: asc 代表升序, desc 代表降序,默认不写是升序 order by 子句中可以支持单个字段、多个字段、表达式、函数、别名 order by 子句一般是放在查询语句的最后面, limit 子句除外     # 案例 1 :查询员工信息,要求工资从高到低排序 SELECT * FROM manba ORDER BY salary DESC; SELECT * FROM manba ORDER BY salary ASC;   # 案例 2 :查询部门编号 >=90 的员工信息,按入职时间的先后进行排序   SELECT * FROM manba WHERE department_id>=90 ORDER BY hiredate ASC;   # 案例 3 :按年薪高低显示员工的信息和年薪 [ 按表达式排序 ] SELECT *, salary*12*(1+IFNULL(commission_pct,0)) AS 年薪 FROM manba ORDER BY salary*12*(1+IFNULL(commission_pct,0)) DESC;   # 案例 4 :按年薪高低显示员工的信息和年薪 [ 按别名排序 ] SELECT *, salary*12*(1+IFNULL(commission_pct,0)) AS 年薪 FROM employees ORDER BY 年薪 DESC;   # 案例 5 :按姓名的长度显示员工的姓名和工资 [ 按函数排序 ] SELECT LENGTH(last_name) AS 字节长度 , last_name,salary FROM manba ORDER BY LENGTH(last_name) DESC;   # 案例 6 :查询员工信息,要求先按工资升序,再按员工编号降序 [ 按多个字段排序 ] SELECT * FROM manba ORDER BY salary ASC,employee_id DESC; # 整体按工资排序,工资相同时,按员工编号降序     4. 常见函数的运用 概念:类似 java 的方法,将一组逻辑语句封装在方法体中,对外暴露方法名 好处:隐藏了实现细节、提高代码的重用性 调用: select 函数名 ( 实参列表 ) [from ( 根据需要 )]; 特点:        ①叫什么(函数名)        ②干什么(功能) 分类:        字符函数 :length  concat substr instr trim upper lower lpad rpad replace               数学函数: round ceil floor truncate mod               日期函数: now curdate curtime year month monthname        day hour minute second str_to_date  date_format               其他函数: version database user               控制函数 : if case          下期我们就函数的应用,还有其他的查询做一个汇总

【编测编学】  教学内容为:

 

测试基础知识、项目实战、测试管理、敏捷测试、探索式测试、APP测试、Linux、数据库、测试环境搭建、Python编程、WEB端UI自动化测试、APP端UI自动化、接口功能测试、性能测试、接口自动化测试、Jenkins持续集成  等内容。

通过学习,学员能  掌握软件测试企业最新技术,对标一线互联网企业项目要求,使学员达到中高级测试工程师的水平,毕业后可快速融入企业实际工作中。

 

不管你是  文科生、专科生、0基础、女同学  都可以轻松学会!

相关推荐