MySQL数据库

常见的DBMS介绍

​ 1.MySQL:Oracle公司的产品,MySQL在08年被Sun公司收购,09年Sun公司被

Oracle公司收购,开源软件。被收购后MySQL创始人从Oracle离开创建了MariaDB,

MariaDB就是MySQL软件的一个分支,市占率第一。

​ 2.Oracle:Oracle公司产品,性能最高价格最贵,不是开源的,市占率第二。

​ 3.SQLServer:微软公司产品, .net语言使用此数据库,市占率第三。

​ 4.DB2:IBM公司产品

​ 5.SQLite:轻量级数据库软件,安装包几十k,主要用于移动设备和嵌入式设备中

常见的MySQL命令

一丶常见的数据库命令

1.查询所有数据库:

show databases;

2.创建数据库

*创建数据库:
	create database 数据库名;
*创建数据库,判断不存在时在创建
	create database if not exists 数据库名;
*创建数据库,判断不存在是在创建,且指定字符集
	create database if not exists 数据库名 character set 字符集;

3.使用数据库

use 数据库名;

4.查询数据库详情

show create database 数据库名;

5.删除数据库

drop database 数据库名;

6.修改数据库字符集

alter database 数据库名 character set 字符集名称;

7.查询当前正在使用的数据库

select database();

二丶表相关的SQL语句

1.创建表

create table 表名(字段1 类型,字段2 类型,...);
create table 表名(字段1 类型,字段2 类型,...) charset=utf8;
例如:
create table person(name varchar(5),age int);
create table student(name varchar(10),score int) charset=utf8;
create table hero(name varchar(10),money int) charset=default;

2.查询表

*查询所有表
	show tables;
*查询表的详情
	show create table 表名;
*查询表字段
	desc 表名;

3.删除表

drop table 表名;

4.修改表

*修改表名
	rename table 表名 to 新表名;
	例如:
	rename table person to t_person;
*添加表字段
	*添加到表字段的最后面
        alter table 表名 add 字段名 类型;
        例如:
        alter table student add gender varchar(5);
    *添加到表字段的最前面
        alter table 表名 add 字段名 类型 first;
        例如:
        alter table student add id int first;
    *添加到某个字段的后面
    	alter table 表名 add 新字段名 类型 after 字段名;
        例如:
        alter table student add money int after name;
*删除表字段
	alter table 表名 drop 字段名;
	例如:
	alter table student drop money;
*修改表字段
	alter table 表名 change 原字段名 新字段名 新类型;
	例如:
	alter table student change gender money int;

二丶DML数据操作语言

1.DML数据操作语言:执行操作数据库的SQL必须保证已经使用了某个数据库,并且存在数据所对应的表

2.插入数据(增)

*全表插入格式(要求值的数量和顺序和表字段保持一致)
	insert into 表名 values(值1,值2,值3,...);
	例如:
	insert into person values('tom',18);
*指定字段插入格式(要求值的数量与顺序和指定的一值)
	insert into 表名(字段名1,字段名2) values(值1,值2);
	例如:
	insert into person(name) values('Jerry');
*批量插入
	insert into 表名 values(值1,值2),(值1,值2);
	insert into 表名(字段名) values(值1),(值1);
	例如:
	insert into person values('Lucy',20),('Lily',21);
	insert into person(name) values("Lilei"),('Hanmeimei');
*插入中文
	insert into person values('刘德华',50);
	如果执行上面SQL语句出现错误,提示中包含16进制内容,执行以下SQL
	set names gbk;
	

3.查询数据

select 字段信息 from 表名 where 条件;
例如:
    select name from person;//查询所有name信息
    select name,age from person where age>20;//查询age大于20的所有name
    select * from person;//查询所有表内容信息

4.修改数据

update 表名 set 字段名=xxx,字段名=xxx where 条件;
例如:
	update person set age=8 where name ='Tom';
	update person set age=10 where age is null;//如果age为null的情况下,把age改为10

5.删除数据

delete from 表名 where 条件;//如果不写where后面条件,则把表的全部内容删除
例如:
	delete from person where age=10;//删除age等于10的
	delete from person where name='刘德华';//删除表中name为刘德华的数据
	delete from person where age<20;//删除表中age小于20的数据
	delete from person;//删除表中全部内容
*如果要删除所有记录:
	delete from 表名;//不推荐使用,有多少条记录就会执行多少次删除操作
	truncate table 表名;//推荐使用,效率更高,先删除表,在创建一张一模一样的空表

三 数据类型

1.整数类型:

​ * int(m)和bigint(m)等效java中的long, m代表显示长度,位数不够,前面补0.

create table t1(name varchar(10),age int(10) zerofill);
insert into t1 values('aaa',18);
select * from t1; //name='aaa' age=0000000018

2.浮点数:

​ * double(m,d) : m代表总长度,d代表小数长度 53.234 double(5,3),超高精度浮点数 decimal(m,d)精度远远高于double,只有涉及超高精度时使用.

3.字符串:

​ * char(m):固定长度,m=10 存abc 占10,优点:执行效率略高,最大长度255

​ * varchar(m):可变长度,m=10,存abc,占3, 优点:更节省空间,最大长度65535,但建议存255以下

​ * text(m):可变长度,最大长度65535,建议保存长大于255的。

4.日期:

​ * date: 只能保存年 月 日

​ * time: 只能保存时 分 秒

​ * datetime: 默认值为null,最大值9999-12-31

​ * timestamp: (时间戳:距1970年1月1号的毫秒数): 默认值为当前系统时间最大值2038-1-19

​ 例如:

create table t_date(t1 date,t2 time,t3 datetime,t4 timestamp);
insert into t_date values(null,null,'2020-6-12 16:19:20',null);
insert into t_date values('2018-10-12','15:30:20',null,null);

四、SQL练习

导入emp.sql 命令行界面: source C:\Users\Administrator\Desktop\emp\emp.sql;

1.emp表

MySQL数据库_第1张图片

2.dept表

MySQL数据库_第2张图片

1.去重distinct

select distinct 字段名 from 表名;

(1).查询员工表中有哪些工作(去重)

select distinct job from emp;

(2).查询员工表中的部门编号deptno有哪些

select distinct deptno from emp;

2.is null和is not null

(1).查询没有上级领导的员工信息

select * from emp where mgr is null;

(2).查询有上级领导的员工姓名,工资和工作

select ename,sal,job from emp where mgr is not null;

3.比较运算符 > < >= <= = != 和<>(相当于不等于)

(1) 查询工资小于等于3000的员工姓名和工资

select ename,sal from emp where sal<=3000;

(2)查询不是程序员的员工姓名和工作(两种写法)

select ename,job from emp where job!='程序员';
select ename,job from emp where job<>'程序员';

4.and和or

(1)and类似于java中的&& ,当需要同时满足多个条件的时候使用

(2)or类似于java总的|| ,当多个条件满足一个就行的时候使用

​ *查询1号部门工资大于2000的员工信息

select * from emp where deptno=1 and sal>2000;

​ *查询工作是人事或者工资大于3000的员工姓名,工作,工资

select ename,job,sal from emp where job='人事' or sal>3000;

5.in

(1)当查询某个字段的值为多个值的时候使用

​ *查询工资为3000/1500/5000的员工信息

select * from emp where sal in(3000,1500,5000);

6.between x and y (包含x和y)

(1) 当查询某个字段的值在某两个值之间的时候使用

​ * 查询工资在1000-2000之间的员工姓名和工资

select ename,sal from emp where sal between 1000 and 2000;

7.综合练习

*查询有上级领导并且是3号部门的员工信息
	select * from emp where mgr is not null and deptno=3;
*查询2号部门工资在1000到2000之间的员工姓名,工资和部门编号
   select ename,sal,deptno from emp where deptno=2 and sal between 1000 and 2000;
*查询1号部门工资为800和1600的员工信息
    select * from emp where deptno=1 and sal in(800,1600);
*查询1号和2号部门工资高于2000的员工信息
    select * from emp where deptno in(1,2) and sal>2000;
*查询员工表中出现的部门编号有哪几个
    select distinct deptno from emp;

你可能感兴趣的:(MySQL数据库)