zoukankan      html  css  js  c++  java
  • MySQL数据库----数据操作

    注意的几点:
    1.如果你在cmd中书命令的时候,输入错了就用c跳出

      2.s查看配置信息

    一、操作文件夹(库)
    增:create database db1 charset utf8;
    删:drop database db1;
    改:alter database db1 charset gbk;
    查:show databases; #查看所有的数据库
        show create database db1; #查看db1数据库
    二、操作文件(表)
    切换到文件夹下:use db1
    增:create table t1(id int,name char(10)) engine=innodb;
    删:drop table t1;
    改:alter table t1 add age int;
        alter table t1 modify name char(12);
    查:show tables; #查看所有表
        show create table t1; #查看t1表
        desc t1;#查看表结构
        show create table t1G; #查看表详细结构,可加G
        select * from t1; #查看所有的表数据
    三、操作文件的一行行内容(记录)
    增:insert into db1.t1 values(1,'haiyan'),(2,'yaling'),(3,'xiaoxiao'); #如果t1不给参数,默认按照位置参数依次传参
    -- INSERT into info values(1,'韩涉','');
    
    -- INSERT into info(id,NAMES) values(2,'韩涉');
    
    -- INSERT into info(id,NAMES) values(3,'韩涉'),(4,'韩涉'),(5,'韩涉');
    
    -- INSERT into info(names,sex) select nameS,sex from info ;
    删:delete from t1 where id = 2;
        #对于清空记录有两种方式,但是推荐后者
        delete from t1;
        truncate t1; #当数据量比较大的情况下,使用这种方式,删除速度快
    改:update t1 set name = 'SB' where id=3;
        update t1 set name= 'SB'  where name = 'xiaoxiao';
        alter table t7 modify id int primary key auto_increment;  修改id为主键并且自增
    查:select * from t1; #查看t1里所有的数据
        select name from t1;  #查看t1里所有的name
        select id,name from t1; #查看t1里所有的id,name
    select * from person; -- 查询所有
    
    select name,SEX from person; -- 按指定字段查询
    
    select name,SEX as'性别' from person; -- as 表示为字段起别名
    
    select salary+200 from person; -- 可以进行数据列运算
    
    select DISTINCT age,name FROM person;  -- 去重复查询
    3.1 简单查询
    1.运算符
    
    select * FROM person WHERE age >20;
    
    select * FROM person WHERE age <=20;
    
    select * FROM person WHERE age <>20;
    
    select * FROM person WHERE age !=20;
    
    2.null 关键字
    
    select * FROM person where dept_id is null;
    
    select * FROM person where dept_id is not null;
    
    select * FROM person where name ='';
    
    3.逻辑运算符 and or
                
    
    select * from person where age = 28 and salary =53000;
    
    select * from person where age = 23 or salary =2000;
                    
    select * from person where not(age = 28 and salary =53000);
    3.2 条件查询
    select * from person where age BETWEEN 18 and 20;
    ps: between...and 前后包含所指定的值
    等价于 select * from person where salary >= 4000 and salary <= 8000;
    3.3 区间查询
    select * from person where id = 1 or id = 3 or id = 5;
    
    select * from person where id not in(1,3,5);
    3.4集合查询
    select * from person where name like '%e%'; -- 包含指定参数
    select * from person where name like '%e'; -- 以什么结尾
    select * from person where name like 'e%'; -- 以什么开头
    select * from person where name like '__e%'; -- _表示单个字符站位符
    select * from person where name like '__';
    3.5 模糊查询
    select * from person where age >30 ORDER BY salary desc; -- ASC正序 DESC倒序
                
    select * from person ORDER BY CONVERT(name USING gbk);-- 中文排序
    3.6 排序查询
    四、自增id的方法
    create table t5(id int primary key auto_increment,name char(10));
    #create table t4(id int not null unique auto_increment,name char(10));  (不空且是唯一的)#这个和上面的是一回事
    insert into xx(name) values ('haiyan1'),
                                    ('haiyan2'),
                                    ('haiyan3'),
                                    ('haiyan4'),
                                    ('haiyan5');
    五、拷贝表结构
    create table t7(id int,name char(10));
    create table t8 select * from t7;  #拷贝表结果(如果有数据就把数据一起拷贝了)
    create table t8 select * from t5 where 1=2; #拷贝表结构,不拷贝表数据(条件为假时,查不到任何记录)
    alter table t7 modify id int primary key auto_increment;  修改id为主键并且自增
    insert into t7(name) values   ('egon1'),
                                  ('egon1'),
                                  ('egon1'),
                                  ('egon1');
    6.delete from t7 where id = 1; #删记录(只是删除一行当id=1的时候)
    7.update t7 set name = '';#修改字段对应的值

    修改id为主键并且递增

    六、创建账号
     
    8.select user()#查看当前用户
    select * from mysql.user; 查看所有的用户
    9.创建账号 identifity create user 'haiyan'@'localhost' identified by '147852' # 名为haiyan的本机账号 create user 'alex'@'%' identified by '123' #代表只要ip地址能拼通,那么所有的用户都可以远程登录alex create user 'susan'@'192.168.20.%' identified by '123' #创建远程账号,只要是192.168.20.?开头的ip都可以登录susan #如果你要远程登录alex的账户,那么客户端得这样登录 :mysql -h192.168.20.97 -ualex -p123
     
    七、修改密码
    1.方式一:使用mysqladmin命令
        mysqladmin  -u用户名 -p原密码 password 新密码
    2.方式二:直接设置密码
        set password for 'hanshe'@'%' = password('166')
    3.方式三:直接修改
        updata mysql.user set password = password('123') where user =' hanshe' and host = '%'
        flush PRIVILEGES;
    八、数据库的权限操作
    #insert ,select ,update,delete #有这么几个可以设置权限的操作,那么我们先以select为例吧。
    分四个级别:
    级别1:对所有的库,下的所有的表,下的所有的字段
    '''*.*代表所有的库下的所有的表'''
    同意select权限开放,开放的是*.*的select权限开放给用户
    grant select on *.* to 'zhang'@'localhost' identified by '123';  #让创建用户的时候赋予权限
    级别2:对db1库,下的所有的表,下的所有的字段
    grant select on db1.* to 'wang'@'localhost' identified by '123';
    级别3:对表db1.t1,下的多有字段
    grant select on db1.t1 to 'li'@'localhost' identified by '123';
    级别4:对表db1.t1,下的id,name,字段
    grant select (id ,name)  on db1.t1 to 'zhao'@'localhost' identifitied by '123';
    grant select (id ,name),update(name) on db1.t1 to 'zhao'@'localhost' identifitied by '123';
    修改完权限后要记得刷新权限
    flush privileges;
    
    删除权限:
    revoke select on *.* from 'zhang'@'localhost'
    revoke select on db1.* from 'wang'@'localhost'
    revoke select on db1.t1 from 'li'@'localhost'
    revoke select (id ,name),update(name) on db1.t1 from 'zhao'@'localhost'
    1.创建本地用户并赋予权限

    用户本地登录,就无需IP地址了

    2.创建用户只要Ip能配通,所有的用户都能登录

    客户登录

    其他的都一样,就不一一的说了

    九、 解决乱码问题

    #1. 修改配置文件
    [mysqld]
    default-character-set=utf8 
    [client]
    default-character-set=utf8 
    [mysql]
    default-character-set=utf8
    
    #mysql5.5以上:修改方式有所改动
        [mysqld]
        character-set-server=utf8
        collation-server=utf8_general_ci
        [client]
        default-character-set=utf8
        [mysql]
        default-character-set=utf8
    
    #2. 重启服务
    #3. 查看修改结果:
    s
    show variables like '%char%'
    
    永久解决编码问题
     show variables like 'char%';  查看编码 
  • 相关阅读:
    《c程序设计语言》读书笔记--大写转小写
    《c程序设计语言》读书笔记--字符串比较
    《c程序设计语言》读书笔记--反转字符串
    spring接收json字符串的两种方式
    logback的使用
    初识Vim
    Chrome控制台
    构造有层次的大纲
    让chrome浏览器快的不要不要的
    排序算法Java版
  • 原文地址:https://www.cnblogs.com/TheLand/p/8473904.html
Copyright © 2011-2022 走看看