mysql 自增字段 修改值 navicat innodb_数据库之MySQL进阶

MySQL之自增

我们发现,当我们的mysql表插入一些数据然后删除这些数据后,我们下一次插入数据时,表的id仍然是接着数据删除之前id后面增长的,这是MySQL默认的,但是我们能不能修改呢,当然是可以的。当我们输入语句show create table 表名\G;时,可以查看表的创建语句,我们插入一些数据后,比如五条数据,我们查看表的创建语句会发现多了一个AUTO_INCREMENT=6,再次插入一条数据会发现这个值变成了7,我们会发现这个值,和下一条数据的id值是一样的,经过验证,果然可以通过修改这个值来修改id,修改语句如下:

alter table 表名 AUTO_INCREMENT=数字;

经过查阅资料发现,MySQL可以修改自增字段的自增步长,并且有基于会话级别和全局级别两种,会话级别就是当前会话登录,重新登录一下失效了,全局级别就是只要修改了,那么每一次修改的自增步长都是修改的值,一般不建议修改全局级别的自增步长。

注意:1、对于自增列,必须是索引(含主键)2、对于自增可以设置步长和起始值

show session variables like'auto_inc%'; #查看当前会话的步长和起始值set session auto_increment_increment=2; #设置当前会话的步长set session auto_increment_offset=10;      #设置当前会话的起始值

showglobal variables like 'auto_inc%'; #查看全局的步长和起始值set global auto_increment_increment=2;     #设置全局的步长set global auto_increment_offset=10;       #设置全局的起始值

唯一索引

create table t1(

idintprimary key auto_increment,

numint,

cidint,

unique 唯一索引名称 (列名), #()里面可以写多列,作为联合唯一索引

)

PS:唯一索引作用:1、约束不能重复

2、加速查找

外键的变种

一对多(MySQL默认创建的外键就是一对多)

566c5ac07ad6445ce14e7a2e5a0992e9395.jpg

c5cc998f4f89a10859843e261264e556af1.jpg

create table userinfo1(

idintprimary key auto_increment,

namechar(32),

ageint,

genderenum('男','女')

)engine=innodb default charset=utf8;

create table admin(

idintprimary key auto_increment,

usernamechar(32),

passwordchar(32),

user_idint,

constraint fk5 foreign key (user_id) references userinfo1(id)

)engine=innodb default charset=utf8;

一对多

一对一(一对一就是在一对多的基础上加入了唯一索引的约束)

161ec019444dc8256b17997de9e833e23d7.jpg

25d16f9e52d1a9ee7ec2bedb6e67c3dfad5.jpg

create table userinfo1(

idintprimary key auto_increment,

namechar(32),

ageint,

genderenum('男','女')

)engine=innodb default charset=utf8;

create table admin(

idintprimary key auto_increment,

usernamechar(32),

passwordchar(32),

user_idint,

unique uq1(user_id),

constraint fk5 foreign key (user_id) references userinfo1(id)

)engine=innodb default charset=utf8;

一对一

多对多(多对多需要创建第三张表来维护表的关系)

5e8cd6e66ddf8727ba78a453cb2f7f79913.jpg

bfc9179eadcc48214c03436b0198d4e905c.jpg

create table userinfo2(

idintprimary key auto_increment,

namechar(32),

ageint,

genderenum('男','女')

)engine=innodb default charset=utf8;

create table host(

idintprimary key auto_increment,

hostnamechar(32)

)engine=innodb default charset=utf8;

create table userhost(

idintprimary key auto_increment,

user_idint,

host_idint,

unique uq2(user_id,host_id),

constraint fk6 foreign key (user_id) references userinfo2(id),

constraint fk7 foreign key (host_id) references host(id)

)engine=innodb default charset=utf8;

多对多

MySQL语句的补充

insert into tb11(name,age) values('wusir',12); #插入单条数据

insert into tb11(name,age) values('wusir',12),('root',18); #插入多条数据

insert into tb12(name,age)select name,age from tb11; #从另一张表中查出数据插入这张表

delete fromtb12; #清空整个表

deletefrom tb12 where id !=2;#清空id不为2的数据

deletefrom tb12 where id =2;#清空id为2的数据

deletefrom tb12 where id > 2;#清空id大于2的数据

deletefrom tb12 where id >=2;#清空id大于等于2的数据

deletefrom tb12 where id >=2 or name='wusir'; #清空id大于等于2或者name为wusir的数据delete from tb12 where id >=2 and name='wusir'; #清空id大于等于2并且name为wusir的数据

update tb12 set name='wusir' where id>12 and name='xx'update tb12set name='wusir',age=19 where id>12 and name='xx'

a、条件select * from 表 where id > 1 and name != 'wusir' and num = 12;select * from 表 where id between 5 and 16;select * from 表 where id in (11,22,33)select * from 表 where id not in (11,22,33)select * from 表 where id in (select nid from表)

b、通配符select * from 表 where name like 'ale%' #ale开头的所有(多个字符串)select * from 表 where name like 'ale_' #ale开头的所有(一个字符)

c、限制select * from 表 limit 5; -前5行select * from 表 limit 4,5; -从第4行开始的5行select * from 表 limit 5 offset 4 -从第4行开始的5行

d、排序select * from 表 order by 列 asc -根据 “列” 从小到大排列select * from 表 order by 列 desc -根据 “列” 从大到小排列select * from 表 order by 列1 desc,列2 asc -根据 “列1” 从大到小排列,如果相同则按列2从小到大排序

e、分组select num from表 group by numselect num from 表 where id > 10group by num order by nid descselect num,min(score) from表 group by num

group分组经常配合下面的聚合函数使用:

count()

max()

min()

sum()

avg()select num from 表 group by num having max(id) > 10特别的:group by 必须在where之后(where中不能有聚合函数),order by之前,如果二次筛选用到了聚合函数,就不能使用where,要使用having,且having要放在group by之后。

连表查询

select * from userinfo5,department5 where userinfo5.part_id =department5.id; #一般不推荐使用这种连表查询的方式select * from userinfo5 left join department5 on userinfo5.part_id =department5.id; #左连接(调换两个表的顺序相当于右连接)#左边的表全部显示,如果对应右边的表有空数据的话显示nullselect * from userinfo5 right join department5 on userinfo5.part_id =department5.id; #右连接(调换两个表的顺序相当于左连接)

#右边的表全部显示,如果对应左边的表右空数据的话显示nullselect * from userinfo5 innder join department5 on userinfo5.part_id =department5.id #内连接

将出现null时的一行隐藏

PS:一般连表查询不用*,需要查哪个字段就写哪个字段,字段前最好加上表名,避免不同的表中出现相同的字段,连表后还可以接着连表。

数据库的导入导出

作用:作数据备份

导出现有数据库数据:

mysqldump-u用户名 -p密码 数据库名称 > 导出文件路径 # 导出结构+数据

mysqldump-u用户名 -p密码 -d 数据库名称 > 导出文件路径 # 只导出结构

导入现有数据库数据:

mysqldump-uroot -p密码 数据库名称 < 文件路径 #导入之前先要保证要导入的数据库存在

MySQL之临时表

select num from (select * from t1 where id > 5) as B;

3cf1dd946012bafa972f7f534c3483fd.png

MySQL补充用法

select course_id,avg(num),sum(case when num <60 THEN 0 ELSE 1 END)/sum(1) as jgl from score GROUP BY course_id;

afef8e96968b89b44179446a3cfda520.png

select avg(if(isnull(score.num),0,score.num)),teacher.tname fromcourse left join score on course.cid=score.course_id

left join teacher on course.teacher_id=teacher.tid group by score.course_id

38273a7076a90e0418ade21b1ea805ee.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值