zoukankan      html  css  js  c++  java
  • 数据库的增删改查操作

    注意的几点:
    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数据库
    二、操作文件(表)

     1 切换到文件夹下:use db1
     2 增:create table t1(id int,name char(10)) engine=innodb;
     3 删:drop table t1;
     4 改:alter table t1 add age int;
     5     alter table t1 modify name char(12);
     6 查:show tables; #查看所有表
     7     show create table t1; #查看t1表
     8     desc t1;#查看表结构
     9 
    10     show create table t1G; #查看表详细结构,可加G
    11     select * from t1; #查看所有的表数据
    三、操作文件的一行行内容(记录)

     1 增:insert into db1.t1 values(1,'haiyan'),(2,'yaling'),(3,'xiaoxiao'); #如果t1不给参数,默认按照位置参数依次传参
     2 删:delete from t1 where id = 2;
     3     #对于清空记录有两种方式,但是推荐后者
     4     delete from t1;
     5     truncate t1; #当数据量比较大的情况下,使用这种方式,删除速度快
     6 改:update t1 set name = 'SB' where id=3;
     7     update t1 set name= 'SB'  where name = 'xiaoxiao';
     8     alter table t7 modify id int primary key auto_increment;  修改id为主键并且自增
     9 查:select * from t1; #查看t1里所有的数据
    10     select name from t1;  #查看t1里所有的name
    11     select id,name from t1; #查看t1里所有的id,name
    四、自增id的方法

    1 create table t5(id int primary key auto_increment,name char(10));
    2 #create table t4(id int not null unique auto_increment,name char(10));  (不空且是唯一的)#这个和上面的是一回事
    3 insert into xx(name) values ('haiyan1'),
    4                                 ('haiyan2'),
    5                                 ('haiyan3'),
    6                                 ('haiyan4'),
    7                                 ('haiyan5');
    五、拷贝表结构

    1 create table t7(id int,name char(10));
    2 create table t8 select * from t7;  #拷贝表结果(如果有数据就把数据一起拷贝了)
    3 create table t8 select * from t5 where 1=2; #拷贝表结构,不拷贝表数据(条件为假时,查不到任何记录)
    4 alter table t7 modify id int primary key auto_increment;  修改id为主键并且自增
    5 insert into t7(name) values   ('egon1'),
    6                               ('egon1'),
    7                               ('egon1'),
    8                               ('egon1');
    6.delete from t7 where id = 1; #删记录(只是删除一行当id=1的时候)
    7.update t7 set name = '';#修改字段对应的值

    修改id为主键并且递增

    六、创建账号
    1 8.select user()#查看当前用户
    2   select * from mysql.user; 查看所有的用户
    3 
    4 9.创建账号 identifity
    5 create user 'haiyan'@'localhost' identified by '147852' # 名为haiyan的本机账号
    6 create user 'alex'@'%' identified by '123' #代表只要ip地址能拼通,那么所有的用户都可以远程登录alex
    7 create user 'susan'@'192.168.20.%' identified by '123' #创建远程账号,只要是192.168.20.?开头的ip都可以登录susan
    8 #如果你要远程登录alex的账户,那么客户端得这样登录  :mysql -h192.168.20.97 -ualex -p123
    七、数据库的权限操作

     1 #insert ,select ,update,delete #有这么几个可以设置权限的操作,那么我们先以select为例吧。
     2 分四个级别:
     3 级别1:对所有的库,下的所有的表,下的所有的字段
     4 '''*.*代表所有的库下的所有的表'''
     5 同意select权限开放,开放的是*.*的select权限开放给用户
     6 grant select on *.* to 'zhang'@'localhost' identified by '123';  #让创建用户的时候赋予权限
     7 级别2:对db1库,下的所有的表,下的所有的字段
     8 grant select on db1.* to 'wang'@'localhost' identified by '123';
     9 级别3:对表db1.t1,下的多有字段
    10 grant select on db1.t1 to 'li'@'localhost' identified by '123';
    11 级别4:对表db1.t1,下的id,name,字段
    12 grant select (id ,name)  on db1.t1 to 'zhao'@'localhost' identifitied by '123';
    13 grant select (id ,name),update(name) on db1.t1 to 'zhao'@'localhost' identifitied by '123';
    14 修改完权限后要记得刷新权限
    15 flush privileges;
    16 
    17 删除权限:
    18 revoke select on *.* from 'zhang'@'localhost'
    19 revoke select on db1.* from 'wang'@'localhost'
    20 revoke select on db1.t1 from 'li'@'localhost'
    21 revoke select (id ,name),update(name) on db1.t1 from 'zhao'@'localhost'
    1.创建本地用户并赋予权限

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

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

    客户登录

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

    八、 解决乱码问题

     1 #1. 修改配置文件
     2 [mysqld]
     3 default-character-set=utf8 
     4 [client]
     5 default-character-set=utf8 
     6 [mysql]
     7 default-character-set=utf8
     8 
     9 #mysql5.5以上:修改方式有所改动
    10     [mysqld]
    11     character-set-server=utf8
    12     collation-server=utf8_general_ci
    13     [client]
    14     default-character-set=utf8
    15     [mysql]
    16     default-character-set=utf8
    17 
    18 #2. 重启服务
    19 #3. 查看修改结果:
    20 s
    21 show variables like '%char%'
    22 
    23 永久解决编码问题

     show variables like 'char%';  查看编码 

  • 相关阅读:
    ssh 无密码互通
    React之jsx转js
    分布式事务参考
    js跨域解决方案
    idea编译时JDK版本变化
    计数算法
    Rocketmq消息持久化
    rocketmq安装
    nginx高可用配置
    nginx负载均衡设置
  • 原文地址:https://www.cnblogs.com/intruder/p/11555251.html
Copyright © 2011-2022 走看看