自己对数据库的整理,也是对自己知识的梳理

SQL ( Structure query language ) 结构化查询语言

SQL语言分为4个部分

  • 1、DDL(Data Definition Languages)语句:数据定义语言,主要负责定义字段,数据库,表,列,索引等。常用的语句主要包括,create、drop、alter等。
  • 2、DML(Data Manipulation Languages)语句:数据操作语言,主要负责添加、删除、更新和查询数据库记录,并检查数据的完整性。常用的语句包括,insert,delete,update,select等
  • 3 、DQL(data question language) 查询
  • 4、 DCL(Data control Languages)语句:数据控制语句,主要负责控制不同数据段直接的许可和访问,定义数据库,表,字段,用户的访问权限和安全级别,常用的语句包括,grant revoke等。

DDL语句

DDL 主要是对数据库内部对象进行创建,删除,修改等的
操作语句。(对库和表结构的操作) 和DML的区别:DML时针对表内部数据操作,而不涉及表的定义结构修改。(对数据的操作) DCL:主要是权限管理,一般由管理员使用,开发人员很少使用

1. 库的操作

  • 命令行输入mysql -u root -p 输入密码进入

每条SQL语句结束,用‘;’,或者‘\g’ 表示结束

创建数据库 test1

CREATE DATABASE test1;
结果:Query ok,1 row affected (0.00 sec) 表示创建成功 如果test1库已经存在会返回一下结果
ERROR 1007 (HY000): Can't create database 'test1'; database exists

想查看系统中有哪些库:

show database;
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| mysql |
| performance_schema |
| sakila |
| sys |
| test1 |
| world |
+--------------------+
7 rows in set (0.00 sec)
从上面结果可以看到有很多库,其他库都是系统内置,我们暂时可以不去理会

进入到指定的数据库中:USE test1

切换数据库 USE 库名

mysql> USE test1;
Database changed

查看当前库中的所有的表

要查看指定库中的表  必须使用USE切换到指定的库里然后执行
show tables; mysql> show tables;
Empty set (0.00 sec) test1库是刚创建的库,里面什么都没有 提示Empty

删除库

drop database 库名

mysql> drop database test1;
Query OK, 0 rows affected (0.23 sec) mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| mysql |
| performance_schema |
| sakila |
| sys |
| world |
+--------------------+
6 rows in set (0.00 sec) 执行完命令我们在通过 show databases; 查看系统中所有的库发现test1没有了
注意:数据库删除后,下面所有的表数据都会全部删除,所以删除前一定要慎重并做好数据备份

库操作总结:

  • 查看所有库: show databases;
  • 创建库: CREATE DATABASE 库名
  • 切换库: USE 库名
  • 查看当前库中所有的表: show tables;

2.表操作

查看当前表结构: desc 表名;

查看建表语句: show create table 表名;

创建表:

cerate table class(
id int(10) unsigned not null auto_increment primary key,
cname varchar(50)
)default charset=utf8 class 为表名
id 和 cname 是字段名,列名
int(10) varchar(50) 字段类型
unsigned not null ... 是字段约束

查看表结构:

desc 表名

mysql> desc class;
+-------+------------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+-------+------------------+------+-----+---------+----------------+
| id | int(10) unsigned | NO | PRI | NULL | auto_increment |
| cname | varchar(30) | YES | | NULL | |
+-------+------------------+------+-----+---------+----------------+
2 rows in set (0.00 sec)

查看建表语句:

mysql> show create table class\G;
*************************** 1. row ***************************
Table: class
Create Table: CREATE TABLE `class` (
`id` int(10) unsigned NOT NULL AUTO_INCREMENT,
`cname` varchar(30) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8
1 row in set (0.00 sec) ERROR:
No query specified

删除表:

mysql> drop table class;
Query OK, 0 rows affected (0.00 sec)

修改表结构:

对于已经建立好的表,尤其是有大量数据的表,如果需要做一些结构上的修改,可以先将表删除,然后重新建表,但是这样做需要做一些而外的工作,如果有服务正在访问,对服务也会产生影响

所以大多数情况下使用下面的命令修改

alter table 表名 modeify 字段名 字段类型和约束

添加字段:

alter table 表名 add 新字段名 字段类型和约束

删除字段;

alter table 表名 drop 字段名

修改字段名:

alter table 表名 change 旧字段名 新字段名  字段类型和约束

注意:modify 和 change 都可以修改字段 不同的是 change 后面必须写两次字段名

指定字段添加的位置:

前面添加字段都是将字段默认添加到最后

如果我向将字段添加到最前面
alter table class add 字段名 字段类型和约束 first 如果我想将字段放到指定字段的后面
alter table class add 字段名和字段约束 after 指定的字段名

修改表名

alter table class rename 新表名

表操作总结:

创建表
查看表结构
删除表
修改表结构
修改表名

DDL语句 库和表的操作

数据库DDL的更多相关文章

  1. 数据库DDL审计

    一.为什么需要数据库DDL审计? DDL在生产系统中扮演非常重要的作用. 1)首先从业务角度来说,DDL可能意味着表结构变更,意味着新的版本即将发布,是个重要的时刻. 2)其次从运维角度来说,DDL尤 ...

  2. 数据库DDL语句书写规范

    数据库DDL语句书写规范 1.SQL语句编写说明编写SQL语句应遵循统一的规范,包括大小写.空格.换行.缩进等等,只有完全一样的SQL才能在数据库中共享,从而减少硬解析. 字段类型.长度:根据数据情况 ...

  3. 数据库DDL、DML、DCL、DQL、DPL、CCL的全称和使用

    数据库DDL.DML.DCL.DQL.DPL.CCL的全称和使用 简介: SQL (Structure Query Language):结构化查询语言,一种特殊目的的编程语言,一种数据库查询和程序设计 ...

  4. 数据库DDL操作

    DDL1. 数据库* 查看所有数据库:SHOW DATABASES* 切换(选择要操作的)数据库:USE 数据库名* 创建数据库:CREATE DATABASE [IF NOT EXISTS] myd ...

  5. 监控数据库DDL操作日志

    背景 为了监控好生产环境下各个数据库服务器上DDL操作日志,便于运维工程师管控好风险,我们有必要关注当前实例下的所有的DDL操作以及对应的IP和hostname. 测试环境 Microsoft SQL ...

  6. Oracle数据库 —— DDL

    时间:2016-10-5 14:55 逆风的方向更适合飞翔我不怕千万人阻挡只怕自己投降 --------------------------------------- 一.表的创建与管理1.表的基本操 ...

  7. 数据库DDL与DML对应含义

    DDL:指的是操作数据库.表.字段的相关语句,例如:create.alter.drop DML:指的是对表中的数据进行增删改的操作,例如:insert.update.delete 查询语句书写顺序:s ...

  8. Oracle数据库DDL,DML,视图,PLSQL编程

    动手敲~~~ --创建一个表空间--beijing create tablespace beijing datafile 'c:\beijing.dbf' size 100m autoextend o ...

  9. Oracle数据库 — DDL:数据定义语言

    1.数据定义语言:用于定义数据库的结构,比如创建.修改或删除数据库对象: 包括: CREATE TABLE:创建数据库表:创建表的命名规则: 2.以字母开头:在 1–30 个字符之间:只能包含 A–Z ...

随机推荐

  1. 部署Cube报错,用户登录失败;280000

    在创建SSAS项目过程中,创建数据源.数据源视图.多维数据集.纬度等一切都没有问题.但是在“进程”这一步的时候,发现总是报错,提示如下. OLE DB 错误: OLE DB 或 ODBC 错误 : 用 ...

  2. OC与JS交互之UIWebView

    随着H5的强大,hybrid app已经成为当前互联网的大方向,单纯的native app和web app在某些方面显得就很劣势.关于H5的发展史,这里有一篇文章推荐给大家,今天我们来学习最基础的基于 ...

  3. poj 3107 树重心

    http://acm.hust.edu.cn/vjudge/problem/18069 和poj 1655差不多:http://www.cnblogs.com/qlky/p/5780933.html ...

  4. Sharepoint 2013企业内容管理学习笔记终章

    说完了半自动化内容管理&全自动化内容管理,下面我们来说另外一个企业内容管理的东东吧 企业内容记录化 这个企业内容记录化,其实是我起的名字了,在sharepoint里面它叫做声明记录 这个声明记 ...

  5. 关于在Share point 2010 中保存SPFieldLookupValue类型到一个List中的问题

    在share point 中,有时字段的类型是lookup的,那么将会从另外的一个list中进行相应的连接,这是如果保存string等类型,将会报一个错, Invalid data has been ...

  6. JavaScript(一) 对象基础

    1.定义类或对象 1.1 混合的构造函数/原型方法 用构造函数定义对象的所有非函数属性,类似于Java的构造方法.用原型方法定义对象的函数属性(方法).这种方法是使用比较广泛的定义类或对象的方法. / ...

  7. mongoDB基础知识(一)

    mongoDB是一个基于分布式文件存储的数据库,介于关系型数据库和非关系型数据库之间,在非关系型数据库中功能最丰富, 最像关系型数据库.数据结构松散,类似于json的bson格式,可以存储比较复杂的数 ...

  8. TP5.1:模板赋值与变量输出

    模板赋值:assign() 模板渲染:fetch() 前提准备: 1.在app/index/controller下建立一个控制器,名为Templates.php,里面有test1和test2方法,并且 ...

  9. April 10 2017 Week 15 Monday

    He alone is poor who does not possess knowledge. 没有知识,才是贫穷. Knowledge, as a important part of wisdom ...

  10. 微信的 rpx

    微信小程序新单位rpx与自适应布局   rpx是微信小程序新推出的一个单位,按官方的定义,rpx可以根据屏幕宽度进行自适应,在rpx出现之前,web页面的自适应布局已经有了多种解决方案,为什么微信还捣 ...