SQL概念及DDL语句
SQL概念
SQL全称(Structured Query Language):结构化查询语句,是一种特殊目的的编程语言,是一种数据库查询和程序设计语言,用于存取数据以及查询和管理关系型数据库。
其实就是定义了所有关系型数据库的规则。但是每一种数据库的sql语句操作方式存在不一样的地方,也把这种不一样的地方称为该数据库的'方言'
SQL通用语句
- SQL语句可以单行或多行书写,以分号结尾
- 可以使用空格和缩进来增强语句的可读性
- MySQL数据库的SQL 语句不区分大小写, 关键字建议大写
- 注释
- 单行注释: -- 注释内容 (--后要加空格) 或 # 注释内容(mysql特有)
- 多行注释: /* 注释内容 */
SQL语句分类
- DDL(Data Definition Language): 数据定义语言
- 用来定义数据库对象:数据库,表,列等。 关键字:create,drop, alter等。
- DML(Data Manipulation Language): 数据操作语言
- 用来对数据库中的表进行增删改操作。 关键字:insert,delete,update等。
- DQL(Data Query Language): 数据查询语言
- 用来查询数据库中表的记录(数据)。 关键字:select, where等
- DCL(Data Control Language): 数据控制语言
- 用来定义数据库的访问控制权限和安全级别,及创建用户。关键字: grant, revoke等
DDL: 操作数据库、表
操作数据库:CRUD(增删改查)
C(Create): 创建
- 创建数据库: CREATE DATABASE 数据库名称;
- 创建数据库,判断是否存在,不存在则创建:CREATE DATABASE IF NOT EXISTS 数据库名称;
- 创建数据库并指定其字符集: CREATE DATABASE 数据库名称 CHARACTER SET 字符集;
示例:
CREATE DATABASE IF NOT EXISTS dbName CHARACTER SET gbk;
R(Retrieve): 查询
- 查询所有数据库的名称:
SHOW DATABASES;
示例:

- 查询某个数据库的创建语句:
SHOW CREATE DATABASE 数据库名称;
示例:

从上图可以看出,在查询数据库创建语句时,也可以看到数据库的字符集,所以通过该语句也可以看出数据库的字符集
- 查询所有数据库的名称:
U(Update): 修改
- 修改数据库的字符集:
ALTER DATABASE dbName CHARACTER SET 字符集名称;
示例:

- 修改数据库的字符集:
D(Delete): 删除
- 删除数据库:
DROP DATABASE 数据库名称; - 判断数据库存在,存在则删除:
DROP DATABASE IF EXISTS 数据库名称;
- 删除数据库:
使用数据库
只有使用了数据库,才能对数据库里面的表等进行操作。若没有使用某一个数据库,而直接对其表进行操作,这样会发生错误,SQL语句并不会执行。
- 查询当前正在使用的数据库名称: select database();
示例:

NULL代表了当前没有使用任何数据库,
- 使用数据库: USE 数据库名称;
- 查询当前正在使用的数据库名称: select database();
操作表
- C(Create): 创建
- 语法:
CREATE TABLE tableName(
列名1 数据类型1,
列名2 数据类型2,
....
列名n 数据类型n,
[添加约束...]
);
- 注意:最后一行不用加逗号(,);加了就会报错
- 数据库中常用的数据类型:
- 整数类型: int, bigint 等
- 浮点数: float,double,decimal 浮点数可以指定精度 如decimal(11,2) 代表了该浮点数的长度为11位,小数位只保留2位
- 日期类型:
- date: 只包含年月日 yyyy-MM-dd;
- datetime: 包含年月日时分秒 yyyy-MM-dd HH:mm:ss;
- timestamp: 时间戳类型 包含年月日时分秒 yyyy-MM-dd HH:mm:ss; 如果在插入数据时,不给时间戳类型赋值,或赋值为null,则默认使用当前的系统时间,来自动赋值。并且只要对该类型所在的行进行CUD(增删改)操作,这个类型的字段会自动更新成当前系统时间
- 字符串类型: varchar 如: password varchar(16) 指定该字段的最大字符
- 创建表示例:
CREATE TABLE student(
stu_id INT(32),
stu_name VARCHAR(20),
stu_age INT,
stu_score DECIMAL(4,1),
stu_birthday DATE,
insert_time TIMESTAMP
); - 复制表: CREATE TABLE 表名 like 被复制的表名;
- R(Retrieve): 查询
- 查询某个数据库中所有表名称:
SHOW TABLES; - 查询表的结构:
DESC 表名;
- 查询某个数据库中所有表名称:
- U(Update): 修改
- 修改表名:
ALTER TABLE 表名 RENAME TO 新表名; - 修改表的字符集:
ALTER TABLE 表名 CHARACTER SET 字符集名称; - 添加一列:
ALTER TABLE 表名 ADD 列名 数据类型 - 修改列名 类型:
ALTER TABLE 表名 CHANGE 列名 新列名 新数据类型;
只修改数据类型
ALTER TALBE 表名 MODIFY 列名 新数据类型; - 删除列:
ALTER TABLE 表名 DROP 列名;
- 修改表名:
- D(Delete):删除
DROP TABLE 表名;或者DROP TABLE IF EXISTS 表名;
- C(Create): 创建
SQL概念及DDL语句的更多相关文章
- 常用SQL DDL语句
常用SQL DDL语句 DDL-数据库定义语言:直接提交的.CREATE:用于创建数据库对象.DECLARE:除了是创建只在过程中使用的临时表外,DECLARE语句和CREATE语句非常相似.唯一可以 ...
- 九、dbms_ddl(提供了在PL/SQL块中执行DDL语句的方法)
1.概述 作用:提供了在PL/SQL块中执行DDL语句的方法,并且也提供了一些DDL的特殊管理方法. 2.包的组成 1).alter_compile说明:用于重新编译过程.函数和包语法:dbms_dd ...
- MySQL-第二篇SQL语句基础(1)语句分类及DDL语句
1.什么是SQL语句 SQL是Structed Query Language的缩写,即结构化查询语言.SQL是操作和检索数据库的标准语言,标准的SQL语句可以操作任何关系数据库. 2.标准的SQL语句 ...
- Oracle获取干净的建表DDL语句,不含其它存储、表空间、段属性
早上一个同事资讯怎么获取到建表语句而且是不带存储那种SQL.Oracle自己提供了一个函数DBMS_METADATA.GET_DDL,但是获取到的建表语句含有存储.表空间.以及一些其他段的属性.如图: ...
- 数据库DDL语句书写规范
数据库DDL语句书写规范 1.SQL语句编写说明编写SQL语句应遵循统一的规范,包括大小写.空格.换行.缩进等等,只有完全一样的SQL才能在数据库中共享,从而减少硬解析. 字段类型.长度:根据数据情况 ...
- Hibernate hbm2ddl.auto DDL语句 控制台输出的配置
在开发中我们需要知道hbm2ddl.auto生成的SQL语句,来判断代码的正确性,现在记录配置的过程. Hibernate的DDL语句在控制台的输出配置: 一.在lib中确保只有下面的三个相关包:1) ...
- oracle使用dbms_metadata包取得所有对象DDL语句
当我们想要查看某个表或者是表空间的DDL的时候,可以利用dbms_metadata.get_ddl这个包来查看. dbms_metadata包中的get_ddl函数详细参数 GET_DDL函数返回创建 ...
- 利用dbms_metadata.get_ddl查看DDL语句
http://www.cnblogs.com/aocle/archive/2011/10/13/2209790.html 当我们想要查看某个表或者是表空间的DDL的时候,可以利用dbms_metada ...
- mysql DDL语句
sql语言分为三个级别. 1.ddl 语句 ,数据定义语句,定义了数据库.表.索引等对象的定义.常用语句包含:create.drop.alter. 2.dml 语句 ,数据操纵语句,用于添加.删除.更 ...
随机推荐
- setsockopt函数功能及参数详解
Socket描述符选项[SOL_SOCKET] #include <sys/socket.h> int setsockopt( int socket, int level, int opt ...
- dubbo的扩展点重构
可扩展设计是框架要重点考虑的设计,因为它直接影响到框架的稳定性和功能的扩展,Dubbo扩展点重构.它在扩展性设计上踩过的坑,值得框架设计者借鉴学习. 第一步,微核心,插件式,平等对待第三方 即然要扩展 ...
- WPF 后台触发 Validate UI‘s Element
wpf中有validateRule类, 用于界面元素的验证, 如何后台去控制validateRule呢? 1. UI层要binding写好的ValidateRule,分为Binding和MultiBi ...
- UDK游戏打包详解
转自:http://blog.sina.com.cn/s/blog_944177030100ycki.html 安装完的udk目录下有4个主要的文件夹 Binaries -这个文件夹包含游戏的exe程 ...
- CSharp读取配置文件的类(简单实现)
Reinventing the wheel 系列 CSharp 读取配置文件的类 简单实现(注意没有写) 本人对CS 不是很熟,库也不熟,所以到网上找个实现,并自己添加了点异常.如果只是读取信息,足够 ...
- 【转】python的复制,深拷贝和浅拷贝的区别
在python中,对象赋值实际上是对象的引用.当创建一个对象,然后把它赋给另一个变量的时候,python并没有拷贝这个对象,而只是拷贝了这个对象的引用 一般有三种方法, alist=[1,2,3,[& ...
- 【240】◀▶IEW-Unit05
Unit 5 Education: Study Abroad 表格技巧讲解 1. Model1对应表格分析 This table shows the numbers of international ...
- 03_通过OpenHelper获取SqliteDatabase对象
MyOpenHelper openHelper = new MyOpenHelper(this); 类似于java的File file = new File();只是声明这个东西,但是文件还并没有真正 ...
- [poj1986]Distance Queries(LCA)
解题关键:LCA模板题 复杂度:$O(n\log n)$ #pragma comment(linker, "/STACK:1024000000,1024000000") #incl ...
- Unable to start services for VMware Tools
vmware安装扩展工具报错的问题 vmware安装扩展工具报错Creating a new initrd boot image for the kernel.update-initramfs: Ge ...