数据库基础之一--DDL(数据库定义语言),DCL(数据库控制语言)
Mysql是一个非常典型的C/S结构的应用模型,所以Mysql连接必须依赖于一个客户端或者驱动.
在linux中支持两种连接模式:TCP/IP模式和socket
SQL语句的四部分:
DDL:数据定义语言
DCL:数据控制语言
DML:数据操作语言
DQL:数据查询语言
这篇博客主要对DDL进行介绍
一.首先从数据库方面介绍,对库的增删查改
1.新建数据库
CREATE DATABASE panyang;
CREATE DATABASE panyang2 charset=utf8; 指定字符集
2.查询数据库
SHOW DATABASES; 该命令行在命令行中教常用
如,在mac终端中连接数据库 mysql -u root -p

SHOW CREATE DATABASE panyang; 查看创建数据库的时候得语句

3.修改数据库
ALTER DATABASE panyang charset utf8; 修改数据库编码格式
4.删除数据库
DROP DATABASE panyang2;
二.表操作
在命令行中,使用哪一个数据库命令
USE 你要用的数据库名称 如:use panyang
1.新建
CREATE TABLE student(
id int(10) PRIMARY KEY AUTO_INCREMENT NOT NULL, 自增,主键,不能为空
name VARCHAR(20) NOT NULL UNIQUE, 不能为空,唯一
age INT(10) NOT NULL, 不能为空
address VARCHAR(50) NOT NULL 不能为空
)CHARSET utf8;
2.查询
SHOW TABLES; 查看所有的表;
SHOW CREATE TABLE student;

desc student; 查询表结构

3.修改(alter.注:update面对的是数据,alert是面对的表)
a.在表的最后一列新加一个字段interst
ALTER TABLE student ADD interst VARCHAR(10);
b.在表的第一列增加一个字段
ALTER TABLE student ADD sid int FIRST;
c.在age字段后增加一个字段
ALTER TABLE student ADD sex VARCHAR(10) AFTER age;
d.在age字段后增加一个字段tel并且在最后一列增加email
ALTER TABLE student ADD tel VARCHAR(13) AFTER age,ADD email VARCHAR(20);
e.修改列的名称
ALTER TABLE student CHANGE age age111 int(20);
f.修改列数据类型
ALTER TABLE student MODIFY sex int(4);
g.删除一个列
ALTER TABLE student DROP sid;
4.删除
DROP TABLE student;
补充:
1.创建一个与一个已经存在的表的表结构相同的表的方法.
CREATE TABLE student2 like student; 前面是新的表名,后面是旧表名
2.创建一个与一个已经存在表的备份表(结构相同,数据相同)
CREATE TABLE student22 SELECT * FROM student;
*************DCL***************
数据控制语言,控制用户权限
一个用户可以做什么操作?
1.Mysql用户连接Mysql
2.控制(库,表,数据)权限
主要使用以下命令
GRANT select,update *.* TO 'root'@'localhost' IDENTIFIED BY '123456' WITH GRANT OPTION;
(对ip为localhost的root用户密码为123456,进行查找和增加的权限限制)
GRANT ALL PRIVILEGES ON *.* TO 'test'@'10.0.1.%' IDENTIFIED BY '123456' WITH GRANT OPTION;
(对ip为10.0.1开头的test用户密码为123456,所有权限)
FLUSH PRIVILEGES
这里对个语句进行解释:
1. *.* 库.表
*代表没有显示
*.*代表所有库下面的所有表.如test.student表示test库下的student表
2.'root'@%
%代表没有限制
root代表受限制的用户
'root'@'localhost'表示:ip为localhost的root用户受限制
'root'@'10.0.1.%'表示:ip为10.0.1开头的root用户受限制
权限限制的4个角度:
1、你需要从哪里连接数据库?
2、你需要对谁操作,做什么操作?
3、你要用哪个用户进行操作?
4、密码是什么?
数据库基础之一--DDL(数据库定义语言),DCL(数据库控制语言)的更多相关文章
- MySQL数据库笔记六:数据定义语言及数据库的备份和修复
1. MySQL中的函数 <1>加密函数 password(str) 该函数可以对字符串str进行加密,一般情况下,此函数给用户密码加密. select PASSWORD('tlxy666 ...
- sql 两大类 DDL数据定义语言 和DCL数据控制语言
SQL分为五大类: DDL:数据定义语言 DCL:数据控制语言 DML:数据的操纵语言 DTL:数据事务语言 DQL:数据查询语言. DDL (date definition lang ...
- 数据库中的DDL和DML语言
"D:\mysql-5.6.22-winx64\bin"添加到系统环境变量path中了,然后在任意目录可访问mysql等命令,这样如登录等操作就不需要进入MySQL安装目录才好执行 ...
- oracle学习笔记(三) DCL 数据控制语言与 DDL 数据定义语言
DCL 数据控制语言 Data control language 之前说过的授权和收权利语句 grant, revoke DDL 数据定义语言 Data define language create ...
- Hive 官方手册翻译 -- Hive DDL(数据定义语言)
Hive DDL(数据定义语言) Confluence Administrator创建, Janaki Lahorani修改于 2018年9月19日 原文链接 https://cwiki.apache ...
- mysql DDL数据定义语言
DDL数据定义语言 本节涉及MySQL关键字:create.alter(rename,add,chang,modify,drop).drop.delete.truncate等. -- 创建表:-- 数 ...
- DDL数据定义语言
DDL数据定义语言 (一)概述 DDL(Data Definition Language):数据定义语言,用来定义数据库对象,库.表.列等:创建.删除.修改 库,表结构.主要分为操作数据库的DDL和操 ...
- 【MySQL】DDL数据定义语言的基本用法create、drop和alter(增删改)
DDL 的基础语法 文章目录 DDL 的基础语法 对数据库进行定义 对数据表进行定义 创建表结构(数据表) 设计工具 修改表结构 小结 参考资料 简单复习一波 SQL必知必会 DDL 的英文全称是 D ...
- Oracle language types(语言种类) 表的相关操作 DDL数据定义语言
数据定义语言 Data Definition Language Statements(DDL)数据操纵语言 Data Manipulation Language(DML) Statements事务控制 ...
随机推荐
- OpenCV中CvMat的初始化[转]
一)cvCreateMat创建和分配数据CvCreateMat会创建CvMat,并为CvMat分配数据.cvCreateMat可以配合cvInitMatHeader来初始化CvMat对象.因为CvCr ...
- Android的开机流程及对应源码位置分析
1.系统引导bootloader 1)源码:bootable/bootloader/* 2)说明:加电后,CPU将先执行bootloader程序,此处有三种选择 a)开机按Camera+Power启动 ...
- vue+element ui项目总结点(三)富文本编辑器 vue-wangeditor
1.参考 https://www.npmjs.com/package/vue-wangeditor 使用该富文本编辑器 <template> <div class="egi ...
- js3
举几个小例子: 1. 九九乘法表 var s = "<table>"; for (var i=1;i<=9;i++) { s += "<tr> ...
- scrollviews page分页实现方式
代码 buttonX = 0; buttonW = 50; buttonH = 20; margin = (self.view.width - 5 * buttonW) / 6; CGFloat ym ...
- 二级域名绑定ECS
关于阿里云域名的绑定,下面是个人的理解,如有错误请指出. 首先,任何域名都需要在阿里云备案后才可以使用, 如果是二级域名,不能单独备案,需要其顶级域名在阿里云备案. http://help.aliyu ...
- HTML5微信播放全屏问题的解决方法
在ios和安卓手机里的微信下播放视频时,会遇到不少问题,例如需要手动点击,视频才会播放,并且视频会跳出微信框,出现控制条,如果视频不是腾讯视频,播放完毕会出现腾讯视频的广告推送等问题 解决办法:给vi ...
- SpringBoot入门,新建SpringBoot项目
一.在Spring Initializr中创建初始化项目 https://start.spring.io/ 二.通过maven导入Idea中(解压后的项目) 解压文件 黄色的为项目需要的真正的代码 , ...
- class extension、class category、class-continuation category
class extension Objective-C 2.0增加了class extensions用于解决两个问题: 允许一个对象可以拥有一个私有的interface,且可由编译器验证. 支持一个公 ...
- CS193p Lecture 7 - Views, Gestures
Views 如何绘制自定义图像 Gestures 如何处理用户手势操作 Views 1.它是基本的构造块,代表屏幕上一块矩形区域,定义了一个坐标空间,在此空间中可以绘制,可以添加触控事件: 2.它是分 ...