MySQL数据库的权限问题操作及基本增删改查操作
前面我们讲了mysql的基本内容,现在我们详细的了解一下 MySQL 中的具体操作。
what's the SQL
SQL(Structured Query Language 即结构化查询语言)
SQL 语言主要用于存储数据、更新数据和管理关系数据系统,由 IBM 开发。
SQL语句分为三种:
- DDL 语句 数据库定义语言:数据库、表、视图、索引、存储过程,例如create、alter
- DML 语句 数据库操纵语言:插入数据 insert、删除数据 delete、更新数据 update、查询 select
- DCL 语句 数据库控制语言:例如控制用户的访问权限grant、revoke
系统数据库
MySQL 刚创建完成的时候会生成四个系统数据库:information_schema、performance_schema、mysql、test、
- information_schema:虚拟库,不占用磁盘内存,存储的是数据库启动后的参数
- performance_schema:用于收集数据库服务器性能的参数,记录处理查询请求时发生的各种事件、锁等现象
- mysql:授权库,存储系统用户的权限信息
- test:MySQL数据库系统自动创建的测试数据库
创建用户
首先数据库需要有创建用户才可以登陆,这里创建用户共有三种形式:
# 创建新用户
create user 'gggg'@'hostlocal' identified by '';
#在本机上创建一个密码为123的用户,只可在本机进行操作 create user 'alex'@'%' identified by '';
#创建一个密码为123的alex用户,%表示所有人都可在任何机器上登陆 create user 'eva'@'192.168.20.%' identified by '';
#创建一个密码为123的eva用户,只有在该局域网下的机器可登陆
#此时的用户若想登陆,必须输入创建用户的计算机的ip
mysql -h192.168.20.97 -ueva -p123;
为了使新创建的用户有权限对数据库进行操作(增删改查,insert delete alter select),我们需要对该用户进行授权。如一般用户只可查看数据库里的库中的内容或者只让其查看某个表的内容,或者赋予某个用户可以修改数据的权利,就得赋予其一定的权限。注意,权限是你创建时给予的,你可以为了防止数据被篡改或者防止数据泄露只赋予其很少的权限。
这里我们需要了解一个关于数据库内容的知识点。数据库管理系统,即软件(如mysql,oracle等)管理数据库(即文件夹),数据库整理表(即文件夹中有文件),表又是存放记录的(即文件中有文件内容),所以赋予权限时也需要进行分层。
- 级别1:若你赋予其对数据库的某项操作权限,意味着该用户就可以对数据库中所有的库,以及每个库中所有的表,每个表中所有的记录进行该项操作;
- 级别2:若你只赋予其对某个指定的库的某项操作权限,那就意味着该用户只可对该指定的库,以及该库中所有的表,该库中的表中所有的记录进行该项操作;
- 级别3:若你只赋予其对某个指定的库中指定的表进行某项操作权限,那就意味着该用户只可对该指定的库中的指定的表,以及该表中的所有记录进行该项操作;
- 级别4:若你只赋予其对某个指定的库中的指定的表中的指定的某项记录进行某项操作的权限,那就意味着该用户只仅仅可对该记录进行该项操作
#创建对不同级别拥有操作权限的用户,下面用查看操作select举例
#级别1:对所有库拥有权限
grant select on *.* to 'gggg1'@'localhost' identified by ''; #级别2:对指定库db1拥有权限
grant select on db1.* to 'gggg2'@'localhost' identified' by '123'; #级别3:对指定库下的指定表拥有权限db1.t1
grant select on db1.t1 to 'gggg3'@'localhost' identified by ''; #级别4:仅对某字段拥有权限
grant select (id,name) on db1.ti to 'gggg4'@'localhost' identified by '';#赋予查看id和name的权限 grant select (id,name),update (name) on db1.t1 to 'gggg5'@'localhost' identified by '';
#赋予查看id和name的权限,并赋予修改name的权限 #删除权限
revoke select on db1.* to 'gggg5'@'%'; #修改完权限后记得手动刷新
flush privileges;
上述的 select 可根据需要换成以下任何权限:
| alter | 修改表和索引 |
| create | 创建数据库和表 |
| delete | 删除表中已有记录 |
| drop | 删除数据库和表 |
| index | 创建或删除索引 |
| insert | 插入数据 |
| reference | |
| select | 查询表记录 |
| update | 更新表记录 |
| file | 读写服务器上的文件 |
| process | 查看、杀死线程 |
| reload | 重新授权表或清空日志、主机缓存、表缓存 |
| shutdown | 关机 |
| all privileges | 所有权限 |
| usage | 无权限 |
基本增删改查操作
以上是创建拥有相应权限的用户的操作。那么在拥有权限后,登陆该用户就可以对数据库进行操作了,对数据库的操作又分为对库(文件夹)的操作、对表(文件)的操作和对记录(文件内容)的操作。操作即增删改查。
#对库进行操作(文件夹)
#增:
create database db1 charset utf8;#在data目录下新增一个db1库(db1文件夹)
#查:
show databases;#查看data目录下所有的库(所有的文件夹)
show create database db1;#查看新创建的db1库
#改:
alter database db1 charset gbk;#将db1的字符编码改为gbk
#删:
drop database db1;#删除data目录下的db1库 #对表进行操作(文件)
#首先要切换到指定文件夹下:use db1;
#增:
create table t1(id int,name char(10));#新建一个表,表中的字段必须表上数据类型,char表示字符串
create table t1(id int,name char(10))engine=innodb,default charset gbk;
#新建一个表,可以指定引擎,不指定的话默认的引擎就是innodb,default是指定其字符编码,若不指定默认为该库的字符编码
#查:
show tables;#查看所有表
show create table t1;#查看创建的表
desc t1;#查看表结构,比show好用
#改:
alter table t1 add age int;#给t1表加一个字段age,仍需指定数据类型
alter table t1 modify name char(12);#修改name数据类型的字节数
#删:
drop table t1; #对记录进行操作(文件内容)
#增:
insert into db1.t1 values(1,'gggg1'),(2,'gggg2');#按位置传参
insert into db1.t1 (name) values('gggg'),('alex');#指定只传name,id默认为null
#查:
select * from t1;#查看t1中全部记录
select name,id from t1;#查看表中指定字段
#改:
update t1 set name='SB' where id=4;#将id为4的字段的name修改为SB
update t1 set name='SB' where name='alex';#将name为alex的字段的name修改为SB
update t1 set name='';#将name的值都修改为空,即清空所有name的内容
#删:
delete from t1 where id=4;#删除指定字段
#清空:
delete from t1;将记录全部删掉,也可认为是清空
truncate t1;#真正意义上的清空,当数据量较大时,这个的速度比delete快,推荐使用这个清空方式
这里补充一个内容,当我们要向表中新增记录时,每次都要输入id和name,而id是顺序增加的,每次自己手动加入会显得疲劳,这里我们就可以用到自增id的方式
#自增id(就是增加一个约束,该约束可以使系统自己添加id)
create table t1 (id int primary key auto_increment,name char(10));
#primary key的意思为主键,主键不为空且唯一
#在一个字段中只能哟一个主键,通常是id create table t1 (id int not full unique,name char(10));
#not full unique的意思就是不为空且独一无二,所以该命令与上面作用一样,但推荐使用上者 #设定自增id后,增加字段就无需指定id
insert into t1(name) values ('gggg1'),('gggg2');#此时id会自动按序生成
最后说一下拷贝表结构的操作
#拷贝表结构
create table t2 select * from t1 where 1=2;#只拷贝表结构,不拷贝表内容
alter table t2 modify id int primary key auto_increment;#将表修改成自增id
表操作
在MySQL中我们用到最多的是对表的操作,表中数据的查询操作尤其是重中之重。
具体表操作和数据操作地址:http://www.cnblogs.com/zhuminghui/p/8352563.html
MySQL数据库的权限问题操作及基本增删改查操作的更多相关文章
- 第二百七十七节,MySQL数据库-数据表、以及列的增删改查
MySQL数据库-数据表.以及列的增删改查 1.创建一个表 CREATE(创建) TABLE(表) ENGINE(引擎) ENGINE=INNODB(引擎)还有很多类引擎,这里只是简单的提一下INNO ...
- JDBC中 mysql数据库的连接工具类 Java登录 及增删改查 整理 附带:Navicat Premium 11.0.12中文破解版.zip(下载)mysql数据库工具
先写一个工具类,有实现MySQL数据库连接的方法,和关闭数据库连接.关闭ResultSet 结果集.关闭PreparedStatement 的方法.代码如下: package com.swift; ...
- MySQL数据库 、数据表、数据的增删改查简版
数据库操作 # 增 CREATE(DATABASE | SCHEMA)[IF NOT EXISTS] db_name [[DEFAULT] CHARACTER SET[=]charset_name] ...
- Mysql数据库文件、表、记录的增删改查
一.数据库文件夹的的操作 create database db1 charset utf8; 增加db1文件夹 show databases ; 查看所有数据库 show create databas ...
- MySQL数据库-数据表、以及列的增删改查
1.创建一个表 CREATE(创建) TABLE(表) ENGINE(引擎) ENGINE=INNODB(引擎)还有很多类引擎,这里只是简单的提一下INNODB引擎,INNODB引擎支持事务(回滚), ...
- python web.py操作mysql数据库,实现对数据库的增删改查操作
使用web.py框架,实现对mysql数据库的增删改查操作: 该示例代码中连接的是本地数据库testdb,user表,表结构比较简单,只有两个字段:mobile和passwd,类型均为字符型 实际应用 ...
- 【Python + Mysql】之用pymysql库连接Mysql数据库并进行增删改查操作
用pip下载pymysql并引用 具体请参考文章: <Python之MySQL数据库增删改查操作> <python3.6 使用 pymysql 连接 Mysql 数据库及 简单的增删 ...
- 通过jdbc连接MySql数据库的增删改查操作
一.获取数据库连接 要对MySql数据库内的数据进行增删改查等操作,首先要获取数据库连接 JDBC:Java中连接数据库方式 具体操作如下: 获取数据库连接的步骤: 1.先定义好四个参数 String ...
- 48.Python中ORM模型实现mysql数据库基本的增删改查操作
首先需要配置settings.py文件中的DATABASES与数据库的连接信息, DATABASES = { 'default': { 'ENGINE': 'django.db.backends.my ...
随机推荐
- 如何使用ABBYY FineReader 12将JPEG文件转换成可编辑文本
日常工作中,经常会收到一些JPEG格式的图像文件,有时候还需要做一些修改,可是大家都知道JPEG格式的文件是无法修改的,必须转换成可编辑的格式,当然,现在市场上也应用而生了很多转换工具,相信大家都听说 ...
- 设计模式-创建型模式,python享元模式 、python单例模式(7)
享元模式(Flyweight Pattern)主要用于减少创建对象的数量,以减少内存占用和提高性能.这种类型的设计模式属于结构型模式,它提供了减少对象数量从而改善应用所需的对象结构的方式. 享元模式尝 ...
- [Bayes] Understanding Bayes: A Look at the Likelihood
From: https://alexanderetz.com/2015/04/15/understanding-bayes-a-look-at-the-likelihood/ Reading note ...
- android高级---->Handler的原理
andriod提供了Handler来满足线程间的通信,上次在更新UI的时候也提到过Handler的使用,关于Handler的基本使用,参见博客(android基础---->子线程更新UI).今天 ...
- IOS Https适配摸索
转:http://www.jianshu.com/p/f312a84a944c https封面 在WWDC 2016开发者大会上,苹果宣布了一个最后期限:到2017年1月1日 App Store中的所 ...
- 使用原生Java代码生成可执行Jar包
最近想做一个功能,就是把我们编译后的字节码及其资源文件打包成一个可执行的jar包,在装有jre的机器上双击就能运行. 首先是我们需要选择哪些字节码和文件需要打包到文件中,这个我们用JFileChoos ...
- Hadoop工作原理
hadoop的核心思想是MapReduce,其处理数据的基本原理:在执行mapreduce之前,原始数据被分割成若干split,每个split作为一个map任务的输入,在map执行过程中split会被 ...
- 还有看不懂的java语句?
Person stuProxy= (Person) Proxy.newProxyInstance(Person.class.getClassLoader(), new Class<?>[] ...
- 秒杀应用的MySQL数据库优化
关于秒杀 随着双11活动的不断发展,小米饥饿营销模式的兴起,“秒杀”已经成为一个热点词汇.在一些活动中,热销商品会以惊人的速度售罄,比如最近本人在抢购美图M4手机,12点开卖,1分钟之内就被售罄. 秒 ...
- logback logback.xml常用配置详解(一)<configuration> and <logger>
logback logback.xml常用配置详解(一)<configuration> and <logger> 博客分类: Log java loglogback 原创文章 ...