一、MySql数据库表操作
1、操作数据库
创建数据库:create database 数据库名;
删除数据库:drop database 数据库名;
修改数据库编码格式:alter database 数据库名 character set 要修改的字符集名称;
查询数据库:show databases; 查看所有数据库名称
选择数据库:use 数据库名;
2、操作表
创建表:create table 表名(
列名1 数据类型1,
列名2 数据类型2,...
);
常用列的数据类型:int double char varchar(字节长度) date:yyyy-MM-dd time: hh:mm:ss datetime: yyyy-MM-dd hh:mm:ss
删除表:drop table 表名;
修改表:
添加列:alter table 表名 add 列名 数据类型;
修改列数据类型:alter table 表名 modify 列名 数据类型;
修改列名:alter table 表名 change 旧表名 新表名 数据类型;
删除列:alter table 表名 drop 列名;
修改表名称:alter table 旧表名 rename to 新表名;
查询表:
show tables; 查询数据库下所有的表的名称
desc 表名; 查询该表的表结构
3、操作表中数据
增加数据:
insert into 表名(列名1,列名2,...) values(值1,值2,....);
insert into 表名 values(按顺序给出所有列对应的值);
删除数据:
delete from 表名 where 限定条件;
delete from 表名; -- 删除全部无法删除自增长约束,可以回滚,而truncate table不可以回滚
truncate table 表名; -- 删除全部重置自增长约束,只能删除全表数据,不能删除单个数据
修改数据:
update 表名 set 列名1 = 值1 , 列名2 = 值2... where 限定条件;
基本查询数据:
select * from 表名; 查看所有列
select 列名1,列名2,...from 表名; 查看所需列
select 列名1 as '别名1',列名2 as '别名2',...from 表名; 查看所需列并给列起别名
select (列名1 + 列名2) as '别名' from 表名;
-- 和并列的时候,两个列的字段要类型一致;null参与的运算,结果都为null;ifnull 字段名称 会将null替换为0
4、表数据查询
1)where限制条件查询
=、!=、<>(不等于)、<、<=、>、>=;
between...and 在什么范围之间
IN(set);
is null 为空
is not null 不为空
and 并且
or 或者
not 非
2)模糊查询 like
通配符
_ 匹配单个任意字符
% 匹配对个任意字符
select * from 表名 where 列名 like '通配符组合';
3)去除重复记录 distinct
select distinct 列名 from 表名;
4)排序 order by ASC 默认升序排列 DESC 降序排列
select * from 表名 order by 列名 asc;
select * from 表名 order by 列名1 desc,列名2 desc;
5)聚合函数 ———— 纵向运算
count(): select count(* 或者不含null值的列名) from 表名;
max(): select max(列名) as '最大值' from 表名;
min(): select min(列名) as '最小值' from 表名;
sum(): select sum(列名) as '和' from 表名;
avg(): select avg(列名) as '平均值' from 表名;
6)分组查询 ———— 配合聚合函数使用 查出的数据才有意义
select 列名1 聚合函数 from 表名 where 限定条件 group by 列名1; 按列名1分组
select 列名1 聚合函数 from 表名 group by 列名1 having 限定条件;
where:在分组之前对条件进行限定 不满足条件,就不会参与分组
having:在分组之后,对结果集的筛选
7)分页查询
select * from 表名 limit 开始的记录索引,每一页显示的条数;
开始的记录索引 = (页码-1)*每一页显示的条数
* oracle:rownum 分页方言
* sqlserver:top 分页方言
5、约束
1)主键约束(primary key)
被修饰的字段唯一且非空;一张表只能有一个主键,这个主键可以包含多个字段
格式一:
create table 表名(
字段名称 字段类型 primary key
);
格式二:
create table 表名(
字段名称 字段类型;
primary key(字段名称)
);
格式三:
alter table 表名 add primary key(字段名1,字段名2..);
2)唯一约束(unique) ———— 被修饰过的字段唯一,对null不起作用
3)非空约束(not null) ———— 被修饰过的字段非空
4)外键约束(foreign key)
1)自增长约束 auto_increment
1.被修饰的字段类型支持自增. 一般int
2.被修饰的字段必须是一个key 一般是primary key
2)在多表的一方添加外键约束
alter table 外表名称 add foreign key(外键字段名称) references 主表名称(主键字段名称);
6、多表查询
1)内连接 a表,b表的连接
格式1:显式的内连接
select a.*,b.* from a [inner] join b on ab的连接条件;
格式2:隐式的内连接
select a.*,b.* from a,b where ab的连接条件;
2)外连接
格式1:左外连接
select a.*,b.* from a left [outer] join b on 连接条件;
先展示join左边的(a)表的所有数据,根据条件关联查询 join右边的表(b),符合条件则展示出来,不符合以null值展示.
格式2:右外连接
select a.*,b.* from b right [outer] join a on 连接条件;
先展示jion右边的表(a)表的所有数据,根据条件关联查询join左边的表(b),符合条件则展示出来,不符合以null值展示.
3)子查询 ———— 一个查询依赖另一个查询
例:SELECT emp_fname,emp_lname FROM employee WHERE emp_no = (SELECT emp_no FROM works_on WHERE enter_date = '1998-01-04 00:00:00');
select 列名 from 表名 where 列名 = (select 列名 from 表名 where 限定条件);
二、储存过程 ———— 带有逻辑的sql语句
1、特点
1)执行效率非常快,储存过程是在数据库的服务器端执行的
2)移植性很差,不同数据库的储存过程是不能移植的
2、语法
创建储存过程
delimiter $
create procedure test(in 输入参数名 数据类型,out 返回值名 数据类型)
-- 也可以没有参数和返回值
begin
-- 多条需要执行的sql语句
if 输入参数名 = 值1 then
set 返回值名 = '返回值1';
if 输入参数名 = 值2 then
set 返回值名 = '返回值2';
else
set 返回值名 = '返回值3';
end if;
end $
调用存储过程:
call tset(输入参数值,@返回值名);
select @返回值名;
3、MySQL中的变量
1)全局变量(内置变量):作用域整个链接
-- 查看所有全局变量;show variables;
-- 查看某个全局变量:select @@变量名;
-- 修改全局变量:set
set @@character_set_client=gbk; 设置服务器端口接收的编码
set @@character_set_results=utf8; 设置显示的编码
2)会话变量:只存在当前一次连接中 如果这次链接断掉 会话变量就消失了
-- 定义会话变量:set @变量 = 值;
-- 查看会话变量:select @变量;
3)局部变量:比如存储过程中的变量 作用域在 begin和end之间
4、begin end间的逻辑sql语句
1)条件判断
if ..then ..set..;
else set..;
end if;
2)循环
whlie 变量名 判断符 值 do
set..;
set 变量名=变量名+1; -- 注意这块没有i++的说法
end whlie;
5、删除储存过程
drop procedure 储存过程名;
三、触发器 ———— 当一个操作发生时会触发另一个行为
创建触发器
create trigger 起个触发器名字 after增/改/删 on要增改删的表名 for each row
insert into 要记录的表名(字段名)values(‘增加了一条记录’);
//after insert on 添加
//after update on 修改
//after delete on 删除
例:
delimiter $
create trigger banji after insert on user for each row
begin
insert into loger values(NULL,'你增加了一条记录',NULL);
end $
insert into user values(NULL,'张三');
四、MySql中的函数
1、系统函数
直接调用即可.任何函数都有返回值,函数的调用是通过select调用.因为有返回值,所以只能用select 调用
1)截取字符串
substring(原字符串,起始位置,截取长度); mysql 中下标从1开始算
2)字符字节长度
set @username='你好世界';
char_length('@username') 字符长度 4 个
length('@username') 字节长度 12个
3)查找字符所在字符串的索引,没有返回0
select instr(@username,'好'); 返回2
4)按照指定长度填充指定字符串
lpad (@username,10,'要填充的字符') 左填充
例如: select lpad(@username,10,'欢迎'); 注意10个长度算上原来'你好世界'的这4个长度,也就是说欢迎填充了6个
rpad 右填充
5)insert 替换字符串
例如: select insert(@username,2,2,'哈哈'); 从第二个字符开始替换两个字符 替换成哈哈
6)strcmp(字符串1,字符串2) 比较两个字符串大小 按照字典顺序去比较
2、自定义函数
1)创建自定义函数
create function 函数名(参数列表可有可无) returns 数据类型 --规定要返回的数据类型
begin
函数体
返回值:return 返回类型(我们指定的类型);
end
2)使用函数
create function show() returns int
return 100;
-- 调用函数
select show();
-- 查看所有函数 show functions status;
-- 查看创建函数 show create function test;
-- 删除函数 drop function test;
3)例:
delimiter $
create function delById(uid int) returns int
begin
delete form user where id = uid;
return (select count(*) from user);
end $
select deById(7);
五、视图
1、概述:有结构的虚拟表,虚拟表的结构来源不是自己定义,而是从对应的基表中产生
视图可以更好的进行权限控制 比如对外隐藏我的一些基表的名称
2、创建视图
create view 视图名称 as select语句;
create view my_v1 as select * from student;
create view my_v2 as select a.字段名,b.字段名 from a,b where a.id=b.id;
3、查看视图
关于查询表的语句对于视图都是可以用的 除过show create view my_v1;
视图的执行:其实本质就是执行封装的select 语句
4、删除视图:drop view 视图名称
5、修改视图,其实是对原表的修改 alter view 视图名字 as 新的select语句
6、视图数据的操作
视图插入数据:
(1)多表视图不能插入数据
(2)单表视图中可以插入数据(如果视图中字段没有基表中不能为空的字段且没有默认值的字段,是插入不成功的)
(3)视图是可以向基表中插入数据的 (视图的操作是影响基表的)
视图删除数据
(1):多表视图不能删除数据
(2):单表视图可以删除数据,也会影响到基表
视图更新数据
单表视图,多表视图都可以更新数据
更新限制:with check option
例如:create view my_v1 as select * from student where age>30 with check option;
表示视图数据的来源都是年龄大于30的,with check option 决定通过视图更新的时候,不能将已得到
数据age>30的学生 改成age<30 的.
那么:update my_v1 set age=20 where id=1; 就会报错 不允许改 因为做了限制