前面我们讲了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 ...
随机推荐
-
实际项目中的一个angularjs 应用
实际需求:通过下拉框,选择自己需要的类型,创建元素(要求必须是输入点击保存了才能出现对应的类型块) html代码: <div class="list-panel-data"& ...
-
Sublime文本排序&;查找重复行&;删除重复行
排序 按F9或者选择菜单:Edit > Sort Lines,对每行文本进行排序 查找重复行 排序好后,按Ctrl+F,调出查找面板 查找字符串: ^(.+)$[\r\n](^\1$[\r\n] ...
-
[开发笔记]-Visual Studio 2012中为创建的类添加注释的模板
为类文件添加注释,可以让我们在写代码时能够方便的查看这个类文件是为了实现哪些功能而写的. 一:修改类文件模板 找到类模版的位置:C:\Program Files (x86)\Microsoft Vis ...
-
【锋利的jQuery】中全局事件ajaxStart、ajaxStop不执行
最近一直都在研究[锋利的jQuery],确实是一本好书,受益匪浅.但由于技术发展及版本更新等原因,里面还是有些坑需要踩的. 比如:第六章七节中提到的全局事件ajaxStart.ajaxStop照着案例 ...
-
javascript方法的方法名慎用close
通常我们在定义了与window同名的方法时,会自动覆盖掉window同名的方法.close()方法也不例外.示例: <!DOCTYPE html PUBLIC "-//W3C//DTD ...
-
BZOJ 3329: Xorequ [数位DP 矩阵乘法]
3329: Xorequ 题意:\(\le n \le 10^18\)和\(\le 2^n\)中满足\(x\oplus 3x = 2x\)的解的个数,第二问模1e9+7 \(x\oplus 2x = ...
-
javascript语言之 this概念
转载 猫猫小屋 http://www.maomao365.com/?p=837 由于javascript是一种解释性语言,运行时才会解释所有的变量值,所以对于javascript中this所指的对象是 ...
-
什么是分表和分区 MySql数据库分区和分表方法
1.为什么要分表和分区 日常开发中我们经常会遇到大表的情况,所谓的大表是指存储了百万级乃至千万级条记录的表.这样的表过于庞大,导致数据库在查询和插入的时候耗时太长,性能低下,如果涉及联合查询的情况,性 ...
-
理解单链表的反转(java实现)
要求很简单,输入一个链表,反转链表后,输出新链表的表头. 反转链表是有2种方法(递归法,遍历法)实现的,面试官最爱考察的算法无非是斐波那契数列和单链表反转,递归方法实现链表反转比较优雅,但是对于不 ...
-
vue - webpack.base.conf.js
描述:webapck基本配置文件. 为了给开发文件和打包文件(webpack.dev.conf.js|| webpack.prod.conf.js) 提供方便. 'use strict' // 路径 ...