zoukankan      html  css  js  c++  java
  • mysql常用操作

    退出连接:

    QUIT 或者 Ctrl+D

    二、查看数据库,创建数据库,使用数据库查看数据库: show databases;

    复制代码
    默认数据库:
                 mysql - 用户权限相关数据
                 test - 用于用户测试数据
                 information_schema - MySQL本身架构相关数据
     
    创建数据库:     
    create database db1 DEFAULT CHARSET utf8 COLLATE utf8_general_ci; # utf8编码
                   create database db1 DEFAULT CHARACTER SET gbk COLLATE gbk_chinese_ci; # gbk编码
    使用数据库:     use db1;
    复制代码

     显示当前使用的数据库中所有表:SHOW TABLES;

    三、用户管理

    复制代码
    创建用户
        create user '用户名'@'IP地址' identified by '密码';
    删除用户
        drop user '用户名'@'IP地址';
    修改用户
        rename user '用户名'@'IP地址'; to '新用户名'@'IP地址';;
    修改密码
        set password for '用户名'@'IP地址' = Password('新密码')
    复制代码

    注:用户权限相关数据保存在mysql数据库的user表中,所以也可以直接对其进行操作(不建议)

    四、权限管理

    mysql对于权限这块有以下限制:

     View Code

    对于数据库及内部其他权限如下:

                数据库名.*           数据库中的所有
                数据库名.表          指定数据库中的某张表
                数据库名.存储过程     指定数据库中的存储过程
                *.*                所有数据库

    对于用户和IP的权限如下:

                用户名@IP地址         用户只能在改IP下才能访问
                用户名@192.168.1.%   用户只能在改IP段下才能访问(通配符%表示任意)
                用户名@%             用户可以再任意IP下访问(默认IP地址为%)

    1、查看权限:

    show grants for '用户'@'IP地址' 

    2、授权

    grant  权限 on 数据库.表 to   '用户'@'IP地址'

    3、取消授权

    revoke 权限 on 数据库.表 from '用户'@'IP地址'

    授权实例如下:

    复制代码
    grant all privileges on db1.tb1 TO '用户名'@'IP'
    
    grant select on db1.* TO '用户名'@'IP'
    
    grant select,insert on *.* TO '用户名'@'IP'
    
    revoke select on db1.tb1 from '用户名'@'IP'
    复制代码

    mysql表操作

    1、查看表

    show tables;                    # 查看数据库全部表

    select * from 表名; # 查看表所有内容

    2、创建表

    create table 表名(
        列名  类型  是否可以为空,
        列名  类型  是否可以为空
    )ENGINE=InnoDB DEFAULT CHARSET=utf8

    来一个实例好详解

    复制代码
    CREATE TABLE `tab1` (
      `nid` int(11) NOT NULL auto_increment,                   # not null表示不能为空,auto_increment表示自增
      `name` varchar(255) DEFAULT zhangyanlin,                 # default 表示默认值
      `email` varchar(255),
      PRIMARY KEY (`nid`)                                      # 把nid列设置成主键
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
    复制代码

    注:

    • 默认值,创建列时可以指定默认值,当插入数据时如果未主动设置,则自动添加默认值
    • 自增,如果为某列设置自增列,插入数据时无需设置此列,默认将自增(表中只能有一个自增列)注意:1、对于自增列,必须是索引(含主键)2、对于自增可以设置步长和起始值
    • 主键,一种特殊的唯一索引,不允许有空值,如果主键使用单个列,则它的值必须唯一,如果是多列,则其组合必须唯一。

    3、删除表

    drop table 表名

    3、清空表内容

    delete from 表名
    truncate table 表名

    4、修改表

    复制代码
    添加列:   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;
    复制代码

    对于上述这些操作是不是看起来很麻烦,很浪费时间,别慌!有专门的软件能提供这些功能,操作起来非常简单,这个软件名字叫Navicat Premium ,大家自行在网上下载,练练手,但是下面的即将讲到表内容操作还是建议自己写命令来进行

    5、基本数据类型

    MySQL的数据类型大致分为:数值、时间和字符串

     View Code

    mysql表内容操作

    表内容操作无非就是增删改查,当然用的最多的还是查,而且查这一块东西最多,用起来最难,当然对于大神来说那就是so easy了,对于我这种小白还是非常难以灵活运用的,下面咱来一一操作一下

    1、增

    insert into 表 (列名,列名...) values (值,值,...)
    insert into 表 (列名,列名...) values (值,值,...),(值,值,值...)
    insert into 表 (列名,列名...) select (列名,列名...) from 表
    例:
    insert into tab1(name,email) values('zhangyanlin','zhangyanlin8851@163.com')

    2、删

    delete from 表                                      # 删除表里全部数据
    delete from 表 where id=1 and name='zhangyanlin'   # 删除ID =1 和name='zhangyanlin' 那一行数据

    3、改

    update 表 set name = 'zhangyanlin' where id>1

    4、查

    select * from 表
    select * from 表 where id > 1
    select nid,name,gender as gg from 表 where id > 1

    a、条件判断where

        select * from 表 where id > 1 and name != 'aylin' 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、通配符like

        select * from 表 where name like 'zhang%'  # zhang开头的所有(多个字符串)
        select * from 表 where name like 'zhang_'  # zhang开头的所有(一个字符)

    c、限制limit

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

    d、排序asc,desc

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

     e、分组group by

    复制代码
        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之前

  • 相关阅读:
    帆软查看注册用户的数据库信息
    [已解决]报错:sql server 返回结果出现中文乱码
    消除点击单元格时出现的黑框
    python tcp udp函数装饰器,无需亲自手写socket连接代码。
    介绍一个python代码自动运行在远程机器的三方包。
    python paramiko上传文件夹到linux
    filebeat自定义索引名,filebeat索引模板
    mydumper
    mysql误删ibd文件
    mysql update多字段时引发的一个问题
  • 原文地址:https://www.cnblogs.com/jscai/p/13303426.html
Copyright © 2011-2022 走看看