一:数据库的相关概念
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基础、女同学 都可以轻松学会!
