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(数据库控制语言)的更多相关文章

  1. MySQL数据库笔记六:数据定义语言及数据库的备份和修复

    1. MySQL中的函数 <1>加密函数 password(str) 该函数可以对字符串str进行加密,一般情况下,此函数给用户密码加密. select PASSWORD('tlxy666 ...

  2. sql 两大类 DDL数据定义语言 和DCL数据控制语言

    SQL分为五大类: DDL:数据定义语言   DCL:数据控制语言     DML:数据的操纵语言  DTL:数据事务语言  DQL:数据查询语言. DDL (date definition lang ...

  3. 数据库中的DDL和DML语言

    "D:\mysql-5.6.22-winx64\bin"添加到系统环境变量path中了,然后在任意目录可访问mysql等命令,这样如登录等操作就不需要进入MySQL安装目录才好执行 ...

  4. oracle学习笔记(三) DCL 数据控制语言与 DDL 数据定义语言

    DCL 数据控制语言 Data control language 之前说过的授权和收权利语句 grant, revoke DDL 数据定义语言 Data define language create ...

  5. Hive 官方手册翻译 -- Hive DDL(数据定义语言)

    Hive DDL(数据定义语言) Confluence Administrator创建, Janaki Lahorani修改于 2018年9月19日 原文链接 https://cwiki.apache ...

  6. mysql DDL数据定义语言

    DDL数据定义语言 本节涉及MySQL关键字:create.alter(rename,add,chang,modify,drop).drop.delete.truncate等. -- 创建表:-- 数 ...

  7. DDL数据定义语言

    DDL数据定义语言 (一)概述 DDL(Data Definition Language):数据定义语言,用来定义数据库对象,库.表.列等:创建.删除.修改 库,表结构.主要分为操作数据库的DDL和操 ...

  8. 【MySQL】DDL数据定义语言的基本用法create、drop和alter(增删改)

    DDL 的基础语法 文章目录 DDL 的基础语法 对数据库进行定义 对数据表进行定义 创建表结构(数据表) 设计工具 修改表结构 小结 参考资料 简单复习一波 SQL必知必会 DDL 的英文全称是 D ...

  9. Oracle language types(语言种类) 表的相关操作 DDL数据定义语言

    数据定义语言 Data Definition Language Statements(DDL)数据操纵语言 Data Manipulation Language(DML) Statements事务控制 ...

随机推荐

  1. uvm_subscriber——告诉她我们来过

    Subscribers are basically listeners of an analysis port. They subscribe to a broadcaster and receive ...

  2. IOS命名

    NS开头的名称不要出现. NS系统名称开头. 命名缩写只用于通用专业术语,如URL,不可自创命名缩写,如Ctr.Msg.命名宁可长一些,也不要难于理解. 是否在看别人代码时各种缩写而不知其所以然?简短 ...

  3. Azure 项目构建 – 托管静态网站

    本课程主要介绍了如何在 Azure 平台上快速构建和部署基于 Azure Web 应用的静态托管网站, 实践讲解如何使用 Azure 门户创建 Web 应用, 部署静态网站源代码,设置自定义域名等. ...

  4. MySQL存储过程(批量生成论坛中发帖、回帖、主题等数据)

    USE 数据库名称1;DROP PROCEDURE IF EXISTS 数据库名称1.存储过程名称;delimiter $$CREATE PROCEDURE 数据库名称1.存储过程名称(in v_co ...

  5. POJ 2152 Fire (树形DP,经典)

    题意:给定一棵n个节点的树,要在某些点上建设消防站,使得所有点都能够通过某个消防站解决消防问题,但是每个点的建站费用不同,能够保证该点安全的消防站的距离上限也不同.给定每个点的建站费用以及最远的消防站 ...

  6. codevs 1497 取余运算

    时间限制: 1 s  空间限制: 128000 KB  题目等级 : 钻石 Diamond 题目描述 Description 输入b,p,k的值,编程计算bp mod k的值.其中的b,p,k*k为长 ...

  7. windows/Linux 常用命令

    windows 文件操作命令 cd 切换文件目录 dir 显示文件目录内容 md 创建文件夹 rd 删除文件夹 copy 拷贝文件 move 移动文件 del 删除文件 replace 替换文件 mk ...

  8. Java Web应用中获取用户请求相关信息,如:IP地址、操作系统、浏览器等信息

    引入jar包 <dependency> <groupId>eu.bitwalker</groupId> <artifactId>UserAgentUti ...

  9. 如何用node命令和webpack命令传递参数

    1. 比如在项目中我们的publicPath需要根据服务器环境的变化而变化,这时我们会写一个配置文件,在webpack.config.js中读取,可以 如何才能 取到变量呢? 这里介绍一种方法: 如果 ...

  10. 关于highchts X时间轴比设置时间相差好几个小时的解决

    经过一番查询和研究发现,在曲线图里,x轴的UNIX时间戳是要乘以1000的(通过在线的UNIX转换,结果与原来没有乘以1000的时间戳相差甚远),不然显示的时间会有很大的误差,真是百思不得其解. 另外 ...