MySQL 的连接查询,通常都是将来自两个或多个表的记录行结合起来,基于这些表之间的共同字段,进行数据的拼接
首先,要确定一个主表作为结果集,然后将其他表的行有选择性的连接到选定的主表结果集上
使用较多的连接查询包括:内连接、左连接和右连接
-- 创建表模板
mysql> create table yaling(a_id int(10) default null,a_name varchar(30) default null,a_level int(10) default null);
mysql> create table galing(a_id int(10) default null,a_name varchar(30) default null,a_level int(10) default null);
mysql> insert into gangling values(2,'bbb',20),(3,'ccc',30),(5,'eee',50),(6,'fff',60);
mysql> insert into galing values(2,'bbb',20),(3,'ccc',30),(5,'eee',50),(6,'fff',60);
mysql> select * from yaling;
+------+--------+---------+
| a_id | a_name | a_level |
+------+--------+---------+
| 1 | aaa | 10 |
| 2 | bbb | 20 |
| 3 | ccc | 30 |
| 4 | ddd | 40 |
+------+--------+---------+
4 rows in set (0.00 sec)
mysql> select * from galing;
+------+--------+---------+
| a_id | a_name | a_level |
+------+--------+---------+
| 2 | bbb | 20 |
| 3 | ccc | 30 |
| 5 | eee | 50 |
| 6 | fff | 60 |
+------+--------+---------+
4 rows in set (0.01 sec)
左表对右边进行匹配,只返回两个表中联接字段相等的行
SELECT 字段 FROM 表1 INNER JOIN 表2 ON 表1.字段 = 表2.字段;
mysql> select a_id,b_name from yaling inner join galing on a_name=b_name;
+------+--------+
| a_id | b_name |
+------+--------+
| 2 | bbb |
| 3 | ccc |
+------+--------+
2 rows in set (0.00 sec)
返回左表中所有的记录+右表中和左表相同的数据,不同的地方均为null补足
SELECT 字段 FROM 表1 LEFT JOIN 表2 ON 表1.字段 = 表2.字段;
mysql> select * from yaling left join galing on a_name=b_name;
+------+--------+---------+------+--------+---------+
| a_id | a_name | a_level | b_id | b_name | b_level |
+------+--------+---------+------+--------+---------+
| 2 | bbb | 20 | 2 | bbb | 20 |
| 3 | ccc | 30 | 3 | ccc | 30 |
| 1 | aaa | 10 | NULL | NULL | NULL |
| 4 | ddd | 40 | NULL | NULL | NULL |
+------+--------+---------+------+--------+---------+
4 rows in set (0.00 sec)
返回右表中所有的记录+左表中和右表相同的数据,不同的地方均为null补足
SELECT 字段 FROM 表1 RIGHT JOIN 表2 ON 表1.字段 = 表2.字段;
mysql> select * from yaling right join galing on a_name=b_name;
+------+--------+---------+------+--------+---------+
| a_id | a_name | a_level | b_id | b_name | b_level |
+------+--------+---------+------+--------+---------+
| 2 | bbb | 20 | 2 | bbb | 20 |
| 3 | ccc | 30 | 3 | ccc | 30 |
| NULL | NULL | NULL | 5 | eee | 50 |
| NULL | NULL | NULL | 6 | fff | 60 |
+------+--------+---------+------+--------+---------+
4 rows in set (0.00 sec)
MySQL数据库函数提供了能够实现各种功能的方法,使我们在查询记录时能够更高效的输出
常用的包括:数学函数、聚合函数、字符串函数和日期时间函数
数学函数 | 描述 |
---|---|
abs(x) | 返回 x 的绝对值 |
rand() | 返回 0 到 1 的随机数 |
mod(x,y) | 返回 x 除以 y 以后的余数 |
power(x,y) | 返回 x 的 y 次方 |
round(x) | 返回离 x 最近的整数 |
round(x,y) | 保留 x 的 y 位小数四舍五入后的值 |
sqrt(x) | 返回 x 的平方根 |
truncate(x,y) | 返回数字 x 截断为 y 位小数的值 |
ceil(x) | 返回大于或等于 x 的最小整数 |
floor(x) | 返回小于或等于 x 的最大整数 |
greatest(x1,x2…) | 返回集合中最大的值 |
least(x1,x2…) | 返回集合中最小的值 |
聚合函数 | 描述 |
---|---|
avg() | 返回指定列的平均值 |
count() | 返回指定列中非 NULL 值的个数 |
min() | 返回指定列的最小值 |
max() | 返回指定列的最大值 |
sum(x) | 返回指定列的所有值之和 |
select avg(id) from xjj;
select count(id) from xjj;
select min(id) from xjj;
select max(id) from xjj;
select sum(id) from xjj;
字符串函数 | 描述 |
---|---|
trim() | 返回去除指定格式的值 |
concat(x,y) | 将提供的参数 x 和 y 拼接成一个字符串 |
substr(x,y) | 获取从字符串 x 中的第 y 个位置开始的字符串,跟substring()函数作用相同 |
substr(x,y,z) | 获取从字符串 x 中的第 y 个位置开始长度为 z 的字符串 |
length(x) | 返回字符串 x 的长度 |
replace(x,y,z) | 将字符串 z 替代字符串 x 中的字符串 y |
upper(x) | 将字符串 x 的所有字母变成大写字母 |
lower(x) | 将字符串 x 的所有字母变成小写字母 |
left(x,y) | 返回字符串 x 的前 y 个字符 |
right(x,y) | 返回字符串 x 的后 y 个字符 |
repeat(x,y) | 将字符串 x 重复 y 次 |
space(x) | 返回 x 个空格 |
strcmp(x,y) | 比较 x 和 y,返回的值可以为-1,0,1 |
reverse(x) | 将字符串 x 反转 |
select trim(' 123abc');
select concat('abc',123);
select substr('abcdefg',3);
select substr('abcdefg',3,2);
select length('abcdefg');
select replace('abcdefg','a','1');
select upper('abc');
select lower('ABC');
select left('abcdefg',3);
select right('abcdefg',3);
select repeat('abc',2);
select length(space(3));
select strcmp(1,2),strcmp(2,2),strcmp(3,2);
select reverse('abcdefg');
日期时间函数 | 描述 |
---|---|
curdate() | 返回当前时间的年月日 |
curtime() | 返回当前市价你的时分秒 |
now() | 返回当前时间的日期和时间 |
month(x) | 返回日期x中的月份值 |
week(x) | 返回日期x是年度的第几个周 |
hour(x) | 返回x中的小时值 |
minute(x) | 返回日期x中的分钟值 |
second(x) | 返回日期x中的秒数值 |
dayotweek(x) | 返回x是星期几,1为星期日,2为星期一 |
replace(x,y,z) | 将字符z替代字符串x中的字符串y |
dayotmonth(x) | 计算日期x是本月的第几天 |
select dayofweek(curtime());
select dayofmonth(curtime());
select dayofyear(curtime());
select curdate();
select curtime();
select now();
create procedure <过程名> ([过程参数……]) <过程体>
[过程参数……] 格式
<过程名>:尽量避免与内置的函数或字段重名
<过程体>:语句
[in|out|inout] <参数名><类型>
示例(不带参数的创建)
##创建存储过程##
delimiter && #将语句的结束符号从分号;临时改为两个$$(可以自定义)
create procedure meinv() #创建存储过程,过程名为club,不带参数
-> BEGIN #过程体以关键字 BEGIN 开始
-> create table jiang (id int (10), name char(10),score int (10));
-> insert into jiang values (1,'wang',33);
-> select * from jiang; #过程体语句
-> end && #过程体以关键字 END 结束
delimiter ; #将语句的结束符号恢复为分号
call meinv()
show create procedure meinv\G #查看meinv储存过程的具体信息
mysql> show procedure status like '%meinv%'\G
*************************** 1. row ***************************
Db: puxin
Name: meinv
Type: PROCEDURE
Definer: root@localhost
Modified: 2021-10-29 22:05:13
Created: 2021-10-29 22:05:13
Security_type: DEFINER
Comment:
character_set_client: utf8
collation_connection: utf8_general_ci
Database Collation: utf8_general_ci
1 row in set (0.00 sec)
mysql> delimiter @@
mysql> create procedure yj (in inname varchar(10))
-> begin
-> select * from jiang where name=inname;
-> end @@
Query OK, 0 rows affected (0.00 sec)
mysql> call yj('wang');
-> @@
+------+------+-------+
| id | name | socre |
+------+------+-------+
| 1 | wang | 33 |
+------+------+-------+
1 row in set (0.00 sec)
ps:调用的时候,调用值一定和传入的表中对应的值一样,如果传入表中没有,是调用不出来的
alter procedure <过程名> [<特征>……]
alter procedure qisi modifies sql data sql security invoker;
modifies sql data:表名子程序包含写程序的语句
security:安全等级
invoker:当定义为 invoker 时,只要执行者有执行权,就可以成功执行
drop procedure if exists qisi;