数据库的增删改查操作
注意的几点:
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 t1\G; #查看表详细结构,可加\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%'; 查看编码
Aiden的技术屋 文章被收录于专栏
虽然还是个菜鸟,但是总有一天会长大,翱翔于天空,热爱技术