mysql的相关一些操作

1.显示数据库

SHOW DATABASES;

2.创建数据库

#utf-8
CREATE DATABASE 数据库名称 DEFAULT CHARSET utf8 COLLATE utf8_general_ci;
#gbk
CREATE DATABASE 数据库名称 DEFAULT CHARACTER SET gbk COLLATE gbk_chinese_ci;

3.使用数据库

USE db_name;

显示当前数据库中的所有表:SHOW TABLES;
4.创建表:

create table 表名(
	列名 类型 是否可为空,
	列名 类型 是否可为空,
	列名 类型 是否可为空
)
是否可空,null表示空,非字符串
        not null    - 不可空
        null        - 可空
默认值,创建列时可以指定默认值,当插入数据时如果未主动设置,则自动添加默认值
        create table tb1(
            nid int not null defalut 2,
            num int not null
        )
自增,如果为某列设置自增列,插入数据时无需设置此列,默认将自增(表中只能有一个自增列)
        create table tb1(
            nid int not null auto_increment primary key,
            num int null
        )
        或
        create table tb1(
            nid int not null auto_increment,
            num int null,
            index(nid)
        )
        注意:1、对于自增列,必须是索引(含主键)。
             2、对于自增可以设置步长和起始值
                 show session variables like 'auto_inc%';
                 set session auto_increment_increment=2;
                 set session auto_increment_offset=10;

                 shwo global  variables like 'auto_inc%';
                 set global auto_increment_increment=2;
                 set global auto_increment_offset=10;
   主键,一种特殊的唯一索引,不允许有空值,如果主键使用单个列,则它的值必须唯一,如果是多列,则其组合必须唯一。
        create table tb1(
            nid int not null auto_increment primary key,
            num int null
        )
        或
        create table tb1(
            nid int not null,
            num int not null,
            primary key(nid,num)
        )
外键,一个特殊的索引,只能是指定内容
        creat table color(
            nid int not null primary key,
            name char(16) not null
        )

        create table fruit(
            nid int not null primary key,
            smt char(32) null ,
            color_id int not null,
            constraint fk_cc foreign key (color_id) references color(nid)
        )

5.删除表

drop table 表名;

6.清空表

delete from 表名;
truncate table 表名;

7.修改表

添加列:alter table 表名 add 列名 类型
删除列:alter table 表名 drop column 列名
修改列:
        alter table 表名 modify column 列名 类型;  -- 类型
        alter table 表名 change 原列名 新列名 类型; -- 列名,类型
  
添加主键:
        alter table 表名 add primary key(列名);
删除主键:
        alter table 表名 drop primary key;
        alter table 表名  modify  列名 int, drop primary key;
  
添加外键:alter table 从表 add constraint 外键名称(形如:FK_从表_主表) foreign key 从表(外键字段) references 主表(主键字段);
删除外键:alter table 表名 drop foreign key 外键名称
  
修改默认值:ALTER TABLE testalter_tbl ALTER i SET DEFAULT 1000;
删除默认值:ALTER TABLE testalter_tbl ALTER i DROP DEFAULT;

8.表内容操作

1.增
insert into 表 (列名,列名...) values (值,值,值...)
insert into 表 (列名,列名...) values (值,值,值...),(值,值,值...)
insert into 表 (列名,列名...) select (列名,列名...) from 表
2.删
delete from 表
delete from 表 where id=1 and name='regina'
3.改
update 表 set name = 'regina' where id>1
4.查
select * from 表
select * from 表 where id > 1
select nid,name,gender as gg from 表 where id > 1
5.其他
a、条件
    select * from 表 where id > 1 and name != 'regina' 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 'regi%'  - regi开头的所有(多个字符串)
    select * from 表 where name like 'regi'  - regi开头的所有(一个字符)
 
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 num
    select num,nid from 表 group by num,nid
    select num,nid from 表  where nid > 10 group by num,nid order nid desc
    select num,nid,count(*),sum(score),max(score),min(score) from 表 group by num,nid
 
    select num from 表 group by num having max(id) > 10
 
    特别的:group by 必须在where之后,order by之前
 
f、连表
    无对应关系则不显示
    select A.num, A.name, B.name
    from A,B
    Where A.nid = B.nid
 
    无对应关系则不显示
    select A.num, A.name, B.name
    from A inner join B
    on A.nid = B.nid
 
    A表所有显示,如果B中无对应关系,则值为null
    select A.num, A.name, B.name
    from A left join B
    on A.nid = B.nid
 
    B表所有显示,如果B中无对应关系,则值为null
    select A.num, A.name, B.name
    from A right join B
    on A.nid = B.nid
 
g、组合
    组合,自动处理重合
    select nickname
    from A
    union
    select name
    from B
 
    组合,不处理重合
    select nickname
    from A
    union all
    select name
    from B
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值