数据库常用基本命令:

show  databases; #查看数据库

use + 数据库名称; #进入数据库

show tables;        #查看对应数据库中的表

select  * from info; #查看info表中的数据, * 代表所有数据

select 字段 from 表; #查看指定的数据,从表中查看

创建数据库

create database school ;    #创建school数据库

创建表:一定要进入到数据库中

举例:

create table info (id int not null primary key auto_increment,name char (10) not null,score decimal(5,2),hobby int (2)) ;

#创建一个名为info的数据表,表的属性(id 类型为int 不能为空null 为主键 自增列,name char(字符串长度为10)不为null空值,成绩 最大5位数字其中两位小数,hobby 类型为int(2字节));

PS详解

创建表(表的属性)

not null:不为空值

primary key:主键

auto_increment: 自增列

char:定长字符串类型

说明:M为最大可存储字节数 汉子占两个字节,通过指定m,来限制存储的最大字符数长度,char(20)和varchar(20)将最多只能存储20个字符,超过的字符将会被截掉。m必须小于该类型允许的最大字符数。

decimal(5,2):定点精度和小数位数。【最大5位数字,其中两位小数】

5是(有效位数:可储存的最大十进位数总数,小数点左右两侧都包括在内。有效位数必须是 1 至最大有效位数 38 之间的值。)

2是 (小数位数:小数点右侧所能储存的最大十进位数。小数位数必须是从 0 到 4 的值。只有在指定了有效位数时,才能指定小数位数。预设小数位数是 0;因此,0 <= 1 <= 4。最大储存体大小会随著有效位数而不同。)

常用基本命令

insert into info(id,name,score,hobby) values(1,'zhangsan',95,1);     #表后面插入数据

语法 :insert into 表名(列,列,列) values(填入的数据,‘填入的数据’, 填入的数据);

select * from info where id=2;                          #条件筛选,where代表的是条件

update info set score=75 where id=6;           #修改表中的信息 ,set代表的是列,where代表的是条件

delete from info where name=’test’;   #删除条件为name=‘test’的行

alter table test01 rename info01;             #修改表名

alter table info change name username varchar(10) unique key;     #修改信息名,并设置约束

insert into info(id,name,score) values(6,’test’,null);                #插入数据

insert into hob (sid,hobname) values (2,’聊天’),(3,’运动’),(4,’游戏’);      #连续添加

Select * from info where id=6;             #条件筛选

delete from info where name=’test’;          #删除条件为name=’test’的那一行的全部信息。

select * from info where 1=1 order by score(asc升序)(desc降序);                    #排序(升序/降序)

desc info;                   #查看表结构

select info.name,info.score,hob.hobname from info inner join hob where info.hobby=hob.id;

select username from info where hobby=(select sid from hob where hobname='游泳');         #多表查询

select a.name,a.score,b.hobname from info a inner join hob b where a.hobby=b.id;         #别名查询

create table infos select a.name,a.score,b.hobname from info a inner join hob b where a.hobby=b.id;           #新建表infos内容为多表查询结果

drop database infos;                  #删除infos表

排序:

升序 order by asc

select * from info where 1=1 order by score asc;  # where 1=1 order by  score 默认是asc升序。

降序order by desc

select * from info where 1=1 order by score desc;

===========查询============

desc info ;  查看info表结构

select  #查询

多表相连查询

select * from info inner join hob where info.hobby=hob.id;

#表示查询info表和hob表,inner join是固定语法。

#多表查询,查看info的name列和红包列

select info.name,info.score,hob.hobname from info inner join hob where info.hobby

#多表查询结果创建为新的表格 名为infos

create tables infos select info.name,info.score,hob.hobname from info inner join hob where info.hobby

#创建别名查询

select a.name,a.score,b.hobname from info a inner join hob b where a.hobby=b.id;