MYSQL 数据库基本操作命令 用户名和密码:123456
创建一个名称为 mydb1 的数据库。
create database mydb1;
查看所有数据库
show databases;
创建一个使用 utf-8 字符集的 mydb2 数据库。
create database mydb2 character set utf8;
创建一个使用 utf-8 字符集,并带校对规则的 mydb3 数据库。
create database mydb3 character set utf8 collateutf8_general_ci;
显示库的创建信息
showcreate database mydb3;
删除前面创建的 mydb1 数据库
dropdatabase mydb1;
查看服务器中的数据库,并把其中某一个库的字符集修改为 gb2312;
alter database mydb2 character set gb2312;show create database mydb2;
备份库
1、 准备库的数据
create databasemydb1;
use mydb1;
create tabletest ( id int );
insert into test(id)values(1);
select * fromtest;
2、 删除库:
drop databasemydb1;
3、 4.1 创建库:create databasemydb1; 4.2 \. test.sql (通过执行脚本文件实现)
5、 创建一个员工表
use mydb1; 进入库
create table employee (
id int,
name varchar(20),
gendervarchar(4),
birthday date,
entry_datedate,
jobvarchar(40),
salary double,
resume text)character set utf8 collate utf8_general_ci;
查看库中所有表 show tables;
查看表的创建细节 show create table employee;
查看表的结构 desc employee;
在上面员工表的基本上增加一个 image 列。 alter tableemployee add image blob;
修改 job 列,使其长度为 60。 alter table employee modify job varchar(60);
删除 sex 列。 alter table employeedrop gender;
表名改为 user。 rename table employeeto user;
修改表的字符集 alter table user character set gb2312; show create table user;
列名 name 修改为 username alter tableuser change column name username varchar(20);
使用 insert 语句向表中插入一个员工的信息。insert into employee(id,username,birthday,entry_date,job,salary,resume)values(1,'aaa','1980-09-09','1980-09-09','bbb',1000,'bbbbbbbb');
查看插入的数据 select * from employee;
使用 insert 语句向表中插入一个员工的信息。insert into
employee(id,username,birthday,entry_date,job,salary,resume)values(2,' 小 李 子 ','1980-09-09','1980-09-09','bbb',1000,'bbbbbbbb');
插入失败后的解决方案 show variables like 'chara%'; set character_set_client=gb2312;
显示失败后的解决方案 set character_set_results=gb2312;
将所有员工薪水修改为 5000 元。 update employee setsalary=5000;
将姓名为’aaa’的员工薪水修改为 3000 元。 update employee set salary=3000 where username='aaa';
将姓名为’aaa’的员工薪水修改为 4000 元,job 改为 ccc update employeeset salary=4000,job='ccc' where username='aaa';
将 aaa 的薪水在原有基础上增加 1000 元。 update employee set salary=salary+1000 where username='aaa';
删除表中名称为’zs’的记录。 delete fromemployee where username='小李子'; 删除表中所有记录。 delete from employee;
使用 truncate 删除表中记录。 truncatetable employee;
查询表中所有学生的信息。 select id,name,chinese,english,math from student; select * fromstudent;
查询表中所有学生的姓名和对应的英语成绩。 select name,english from student;
过滤表中重复数据。 select distinct english from student;
在所有学生的英语分数上加 10 分特长分。 select name,english+10from student;
统计每个学生的总分。 select name,(english+chinese+math) from student;
使用别名表示学生分数。 select name as 姓名,(english+chinese+math)as 总分 from student;
select name 姓名,(english+chinese+math)总分 from student;
查询姓名为王五的学生成绩 select * from student where name='王五';
查询英语成绩大于 90 分的同学 select * fromstudent where english>90;
查询总分大于 200 分的所有同学 select * fromstudent where (english+chinese+math)>200;
查询英语分数在 80-90 之间的同学。 select * from student where english>80 and english<90;select* from student where english between 80 and 90;
查询数学分数为 89,90,91 的同学。 select *from student where math=80 or math=90 or math=91; select * from student wheremath in(80,90,91);
查询所有姓李的学生成绩。 select * from student where name like '李%';
对数学成绩排序后输出。 select name,math from student order by math;
对总分排序后输出,然后再按从高到低的顺序输出 select name from student order by (math+english+chinese) desc;
对姓李的学生成绩排序输出select name 姓名,(math+english+chinese)总分 from student where name like '李%' order by (math+english+chinese) desc;
统计一个班级共有多少学生? select count(*) from student; select count(name) from student;
统计数学成绩大于 90 的学生有多少个? select count(*)from student where math>90;
统计总分大于 250 的人数有多少? select count(*)from student where (math+english+chinese)>250;
统计一个班级数学总成绩? select sum(math) from student;
统计一个班级语文、英语、数学各科的总成绩 select sum(math),sum(chinese),sum(english) from student;
统计一个班级语文、英语、数学的成绩总和 select sum(chinese+math+english) from student;
统计一个班级语文成绩平均分 select sum(chinese)/count(chinese) from student;
求一个班级数学平均分? select avg(math) from student;
求一个班级总分平均分 select avg(chinese+english+math) from student;
求班级最高分和最低分 select max(chinese+english+math),min(chinese+english+math) fromstudent;
对订单表中商品归类后,显示每一类商品的总价 select product from orders group by product; selectproduct,sum(price) from orders group by product;
查询购买了几类商品,并且每类总价大于 100 的商品 select product fromorders group by product having sum(price)>100;
定义带有主键约束的表 create table test1
( id int primary key, name varchar(20), password varchar(20) ); 定义一个主键自动增长的表 create table test2 ( id int primary keyauto_increment, name varchar(20), password varchar(20) ); create table test3 (id int primary key auto_increment, name varchar(20) unique ); create tabletest4 ( id int primary key auto_increment, name varchar(20) unique not null );//什么是外键约束 create table husband ( id int primarykey, name varchar(20) ); create table wife ( id int primary key, namevarchar(20), husband_id int, constraint husband_id_FK foreign key(husband_id)references husband(id) );
//一对多或多对一
create table department ( ) create tableemployee ( )
//多对多 create table teacher ( id int primary key, name varchar(20), salarydouble ); create table student ( id int primary key, name varchar(20) );
create table teacher_student ( teacher_idint, student_id int, primary key(teacher_id,student_id), constraintteacher_id_FK foreign key(teacher_id) references teacher(id), constraintstudent_id_FK foreign key(student_id) references student(id) );
//一对一 create table person ( id int primary key, name varchar(20) );
create table idcard ( id int primary key,address varchar(40), constraint id_FK foreign key(id) references person(id) );