1 数据库操做mysql
一:建立数据库正则表达式
用法:create database 库名;sql
例子:数据库
create database feng; #建立一个风数据库函数
二:查看数据库排序
show tables; 显示表名称it
show database; -- 显示全部数据库table
例子:date
show create database feng;#查看数据库信息
show DATABASEs;#查看全部数据库信息
select database();#查询当前操做数据库名称select
三:选择数据库
use 库名;
例子:
use feng; #选择数据库
四: 删除数据库
drop database 库名;
前面说了那么多,总结总结就是这一段代码
不明白直接上这个
2 表格操做
一:新建表
语法:
create table 表名(
字段1 数据类型 约束条件,
字段1 数据类型 约束条件,
)
例子:
create table student(name varchar(250) not null);
二:删除表格:
drop table student
三: 对表格字段的修改
ALTER table student add id int not null; 对student 表格添加id字段 数据类型不能为空
ALTER TABLE t1 MODIFY salary double(10,3) not null DEFAULT 10; -- 修改字段类型与约束条件
ALTER TABLE t1 CHANGE salary sal double(10,3) not null DEFAULT 10; --修改字段名称和类型与约束条件
ALTER TABLE t1 DROP COLUMN sal; -- 删除指定字段
四:查询
1 * select * from t1; -- 查询表中全部数据
2 desc student -- 显示表结构 student是标的名字
3 show create table t1; -- 显示表的建立信息
五:复制表
create table t1 select * from student; 复制student表结构和表数据
create table t3 like student 只复制表结构
六:数据库操做:
增: insert into 代表(属性) 值()
insert into t3 (name,age) values ('小三',18); 指定字段插入
insert into t3 vlaues('化工',28,2.5);整表插入字段
insert into t3 vlaues('化工',28,2.5),('化工',28,2.5),('化工',28,2.5); 插入多条字段
insert into t1 SELECT id,name from t2; -- 复制表数据
删:
delete from t2 where age = 1113;
改
update t2 set name ='祝小凤' , salary = 100 where age =13;
查:
select * from T1;
1.简单查询
-- 查询全部
select * from person;
--查询指定字段
select name,age FROM person;
-- 别名+字段运算
select p.name,p.salary,p.salary+p.salary*0.1 as 'sum' from person as p
-- 去重复查询
select DISTINCT salary,name from person;
2.条件查询
-- 逻辑运算符 < > <= >= != <> =
-- is null ,is not null
-- and OR ()
SELECT * from person where salary >5000 or ( age <=30 AND NAME ='');
3.区间查询
SELECT * FROM person where salary >=5000 and salary<=10000;
-- 推荐使用 :
--ps:先后包含
SELECT * FROM person where salary between 5000 and 10000;
4.集合查询 in not in
SELECT * FROM person where age = 20 or age = 23 or age =30 ;
SELECT * FROM person where age not in(20,23,30);
5.模糊查询 like
SELECT * FROM person where name LIKE '%月'; -- 以什么结尾
SELECT * FROM person where name LIKE '月%'; -- 以什么开头
SELECT * FROM person where name LIKE '%月%'; -- 包含
SELECT * FROM person where name LIKE '_l%'; -- "_"表示占位符
6.排序
select * from person ORDER BY salary ASC,age desc;
-- 强制中文[排序
select * FROM person ORDER BY CONVERT(name USING GBK) ;
7.聚合函数
select MAX(salary) from person;
select MIN(salary) from person;
select AVG(salary) from person;
select SUM(salary) from person;
select COUNT(*) from person;
8.分组查询 GROUP BY HAVING
select count(id),dept_id,avg(salary) from person GROUP BY dept_id HAVING avg(salary) >=5000 ;
where 与 having区别:
#执行优先级从高到低:where > group by > having
#1. Where 发生在分组group by以前,于是Where中能够有任意字段,可是绝对不能使用聚合函数。
#2. Having发生在分组group by以后,于是Having中能够使用分组的字段,没法直接取到其余字段,能够使用聚合函数
9.分页查询 LIMIT
SELECT * FROM person LIMIT 2,2
10.正则表达式
SELECT * FROM person where name REGEXP '^a';
SELECT * FROM person where name REGEXP 'n$';
SELECT * FROM person where name REGEXP '.a';
SELECT * FROM person where name REGEXP '[a,e,n]';
SELECT * FROM person where name REGEXP '[^alex]';
SELECT * FROM person where name REGEXP 'a|e';
SELECT * FROM person where name REGEXP '^w.*i$';
11. SQL 语句关键字的执行顺序
执行顺序: FROM -> WHERE -> GROUP BY -> HAVING -> SELECT -> ORDER BY ->limit
4.权限
create user 'alex'@'127.0.0.1' IDENTIFIED by '123'; -- 建立用户
grant SELECT,UPDATE,DELETE ON db1.* to 'alex'@'127.0.0.1';
GRANT all PRIVILEGES ON db1.* to 'alex'@'127.0.0.1'; -- 全部权限
FLUSH PRIVILEGES; -- 刷新权限 update mysql.user set password=password('123456') where user='root';