#创建一个名称为mydb1的数据库
CREATE DATABASE mydb1;
#创建一个使用utf8字符集的mydb2数据库
CREATE DATABASE mydb2 CHARACTER SET utf8;
#创建一个使用utf8字符集,并带比较规则的mydb3数据库
CREATE DATABASE mydb3 CHARACTER SET utf8 COLLATE utf8_general_ci;
#修改mydb2字符集为gbk
ALTER DATABASE mydb2 CHARACTER SET gbk;
#删除数据库mydb3
DROP DATABASE mydb3;
USE mydb2;
#查看所有数据库
SHOW DATABASES;
#查看数据库mydb1的字符集
SELECT schema_name,default_character_set_name FROM information_schema.schemata WHERE schema_name = 'mydb2';
##创建一张员工表employee
CREATE TABLE employee(
id INT PRIMARY KEY auto_increment,
name VARCHAR(255) NOT NULL,
gender VARCHAR(255),
birthday datetime,
entry_date datetime,
job VARCHAR(255),
salary FLOAT,
resume TINYTEXT)CHARSET utf8;
#创建一张员工表employee2
CREATE TABLE employee2(
id INT PRIMARY KEY auto_increment,
name VARCHAR(255) NOT NULL,
gender VARCHAR(255),
birthday datetime,
entry_date datetime,
job VARCHAR(255),
salary FLOAT,
resume TINYTEXT)CHARSET utf8;
#删除employee2表
DROP TABLE employee2;
#在上面员工表的基本上增加一个image列。
ALTER TABLE employee ADD image2 VARCHAR(255);
#修改job列,使其长度为60。
ALTER TABLE employee MODIFY job VARCHAR(60);
#删除gender列。
ALTER TABLE employee DROP gender;
#表名改为USER。
RENAME TABLE employee TO USER;
#修改表的字符集为utf8
ALTER TABLE employee CHARACTER SET utf8;
#列名NAME修改为username
ALTER TABLE CHANGE NAME username VARCHAR(20);
# 查看数据库内的所有表
SHOW TABLES;
#查看employee的建表语句
SHOW CREATE TABLE employee;
#查看employee的表结构
DESC employee;
#向employee中插入三个员工信息,要求员工姓名分别是zs,ls,wangwu
INSERT INTO employee(name,gender,birthday,entry_date,job,salary,resume)VALUES('zs','男',NULL,NULL,NULL,NULL,NULL);
INSERT INTO employee(name,gender,birthday,entry_date,job,salary,resume)VALUES('ls','女',NULL,NULL,NULL,NULL,NULL);
INSERT INTO employee(name,gender,birthday,entry_date,job,salary,resume)VALUES('wangwu','男',NULL,NULL,NULL,NULL,NULL);
#将所有员工薪水修改为5000元。
UPDATE employee SET salary=5000;
#将姓名为’zs’的员工薪水修改为3000元。
UPDATE employee SET salary=3000 WHERE NAME='zs';
#将姓名为’ls’的员工薪水修改为4000元,job改为ccc。
UPDATE employee SET salary=4000,job='ccc' WHERE NAME='ls';
#将wangwu的薪水在原有基础上增加1000元。
UPDATE employee SET salary=salary+1000 WHERE NAME='wangwu';
#删除表中名称为’zs’的记录。
DELETE FROM employee WHERE NAME='zs';
#删除表中所有记录。
DELETE FROM employee;
#查询表中所有学生的信息。
SELECT * FROM exam;
#查询表中所有学生的姓名和对应的英语成绩。
SELECT NAME,english FROM exam;
#过滤表中重复数据。
SELECT DISTINCT * FROM exam;
#在所有学生分数上加10分特长分。
SELECT * FROM exam SET chinese=(chinese+10),math=(math+10),english=(english+10);
#统计每个学生的总分。
SELECT *,chinese+math+english FROM exam;
#使用别名表示学生分数。
SELECT *,chinese+math+english AS 总分 FROM exam;
#查询姓名为刘备的学生成绩
SELECT * FROM exam WHERE name='刘备';
#查询英语成绩大于90分的同学
SELECT * FROM exam WHERE english>90;
#查询总分大于200分的所有同学
SELECT * FROM exam WHERE chinese+math+english>200;
#查询英语分数在 80-90之间的同学。
SELECT * FROM exam WHERE english BETWEEN 80 AND 90;
#查询数学分数为89,75,91的同学。
SELECT * FROM exam WHERE math IN(89,75,91);
#查询所有姓刘的学生成绩。
SELECT * FROM exam WHERE name LIKE '刘%';
#查询所有姓刘两个字的学生成绩。
SELECT * FROM exam WHERE name LIKE '刘_';
#查询数学分>80并且语文分>80的同学。
SELECT * FROM exam WHERE math>80 AND chinese>80;
#查询数学分>80 或者 语文分>80的同学。
SELECT * FROM exam WHERE math>80 OR chinese>80;
#使用order by 排序
#对数学成绩排序后输出。
SELECT * FROM exam ORDER BY math;
#对总分排序按从高到低的顺序输出
SELECT *,chinese+math+english AS 总分 FROM exam ORDER BY 总分 DESC;
#对姓刘的学生成绩排序输出
SELECT * FROM exam WHERE name LIKE '刘%' ORDER BY math DESC;
#使用count(函数)
#统计一个班级共有多少学生?
SELECT count(id) FROM exam;
#统计数学成绩大于或等于90的学生有多少个?
SELECT count(math) FROM exam WHERE math>=90;
#统计总分大于250的人数有多少?
SELECT count(id) FROM exam WHERE chinese+math+english>250;
#使用sum函数
#统计一个班级数学总成绩?
SELECT SUM(math) FROM exam;
#统计一个班级语文、英语、数学各科的总成绩
SELECT SUM(chinese),SUM(math),SUM(english) FROM exam;
#统计一个班级语文、英语、数学的成绩总和
SELECT SUM(chinese)+SUM(math)+SUM(english) FROM exam;
#统计一个班级语文成绩平均分
SELECT SUM(chinese)/COUNT(id) FROM exam;
#使用avg函数
#求一个班级数学平均分?
SELECT AVG(math) FROM exam;
#求一个班级总分平均分
SELECT AVG(ifnull(chinese,0))+AVG(ifnull(math,0))+AVG(ifnull(english,0)) FROM exam;
#使用max,min函数
#求班级最高分和最低分(数值范围在统计中特别有用)
SELECT MAX(ifnull(chinese,0)+ifnull(math,0)+ifnull(english,0)) FROM exam;
SELECT MIN(ifnull(chinese,0)+ifnull(math,0)+ifnull(english,0)) FROM exam;
SELECT product,sum(price) FROM orders WHERE price>100 GROUP BY product;