11. sql DDL

SQL分为5大类:
DDL:数据定义语言
DCL:数据控制语言
DML:数据操纵语言
DTL:数据事务语言
DQL:数据查询语言

 

1、DDL(data definition language):create,drop,alter,rename to

数据类型

①、数字类型,可以数学运算

  number(4)代表整数,最大4位数,也就是9999

  number(7,2)代表小数,总长度7位,小数2位,整数5位

②、字符型,可以拼接

  char(20), 固定长度,不管里面多少内容,只要小于20,输出结果就是20个字符

  varchar2(20),不固定长度,最长20个字符

  在数据库中要用 ' ' 标注字符串

③、日期类型,可以加减运算

  date  年月日时分秒

  time  时分秒

  timestamp  年月日时分秒,还有小时位,如1.2秒

④、大数据类型
  clob character large object 大字符型对象,最大可存4G
  blob binary large object 大二进制对象,最大可存4G
  注意:大数据类型不支持查看结果

 

约束(constraint)
作用:约束表格中是数据,相对于数据类型而言,用来进一步限定表中的数据,使得添加到表中的数据都是合法有效的,符合业务需求的数据,不会出现无效数据

2、oracle中的5种约束

  primary key    PK  含义:主键

  not null      NN  含义:非空

  unique       UK  含义:唯一

  check         CK  含义:自定义约束,相当于添加条件

  foreign key     FK   含义:外键

 

3、创建表格

create table abc(
  id number(4),
  name varchar2(10),
  title varchar2(10),

  constraint abc_id_pk primary key(id),
  constraint abc_name_nn check(name is not null),
  constraint abc_title_nn check(title is not null)
);


create table bcd(
  id number(4),
  name varchar2(10),
  manager_id number(4),

  constraint bcd_id_pk primary key(id),
  constraint bcd_name_nn check(name is not null),
  constraint bcd_manager_id_fk foreign key(manager_id) references abc(id)

                       ↑           ↑    ↑

                      外键的列     主键表   主键id
);

 

创建表格的另一种方法,就是把已有的表复制过来

--复制某张表中的指定列,构建一张新的表格(拷贝了数据)
create table 新表格名 as select 列,列,列from原表格;
例:创建一张表格,表格中只有s_emp表中的id,first_name,salary三列数据
create table new_emp as select id,first_name,salary from s_emp;

--复制了某张表格的指定列,构建一张新表格(不拷贝数据,取表结构)
create table 新表格名 as select 列,列,列from原表格 where 恒假条件;
例:创建一张表格,表格中只有s_emp表中的id,first_name,salary三列数据
create table new_emp as select id,first_name,salary from s_emp where 1=2;
注意:此处1=2表示恒false,则数据库不会被拷贝,只能得到一张空表

 

4、删除表格

drop table 表名

注意约束,外键

 

5、修改表格

--列相关
  1.添加列
  alter table 表名 add 列名 数据类型 [default默认值] 约束;
  例:--给tbl_user表添加一列年龄
  alter table tbl_user add age number(3) default 18 not null;

  2.删除列
  alter table 表名 drop column 列名;【注意关键字column】
  例:删除tbl_user表中age列
  alter table tbl_user drop column age;

  3.修改列(修改列数据类型和约束)
  alter table 表名 modify 原列名 新数据类型 新约束;
  例:修改tbl_user表中password列为char(6)默认值‘000000’非空
  alter table tbl_user modify password default'000000' not null;

  4.修改列名
  alter table 表名 rename column 原列名 to 新列名;
  --修改tbl_user表中password列名为pwd
  alter table tbl_user rename column password to pwd;





--约束相关
  1.添加约束
  alter table 表名 add constraint 约束名 约束类型(列名)
  注意:如果是添加非空约束,则:
  alter table 表名 add constraint 表名_列名_nn check (is not null)

  注意:所有的DDL语句都是自动提交事务的,所以语句是不能回滚的
  2.删除约束
  alter table 表名 drop constraint 约束名;

  3.使约束生效
  alter table 表名 enable constraint 约束名

  4.使约束失效
  alter table 表名 disable constraint 约束名

转载于:https://www.cnblogs.com/wang95529/p/7823270.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/252923.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

[bzoj2243][SDOI2011]染色

来自FallDream 的博客,未经允许,请勿转载,谢谢qaq 给定一棵有n个节点的无根树和m个操作,操作有2类: 1、将节点a到节点b路径上所有点都染成颜色c; 2、询问节点a到节点b路径上的颜色段数量(连续相…

Linux学习笔记——例说makefile 增加宏定义

从学习C语言开始就慢慢开始接触makefile,查阅了很多的makefile的资料但总感觉没有真正掌握makefile,如果自己动手写一个makefile总觉得非常吃力。所以特意借助博客总结makefile的相关知识,通过例子说明makefile的具体用法。 例说makefile…

Android基本组件是什么?

1、ImageView继承View组件,不单单用于显示图片,用 XML代码 编写的Drawable也可以显示出来。其中的XML属性 android:scaleType(设置图片如何缩放或移动以适应ImageView的大小) 有很多的属性值,如:matrix(使用矩形方式进行缩放)fitXY(对图片横向纵向缩放)center(图片放在ImageVie…

Java 运算符及优先级

运算符 分割符&#xff1a;  ,  ;  []  ()算数运算符&#xff1a;    -  *  /  %    --关系运算符&#xff1a;  >  <  >  <    !逻辑运算符&#xff1a;  !  &  |  ^  &&  ||赋值运算符&#xff1a; …

array sort - 2 : quick sort

递归实现&#xff1a; #include <stdio.h>int arr[10] {3, 2, 4, 1, 9, 7, 5, 6, 0, 8};void print_array(){ int i 0; for (i 0; i < 10; i) printf("arr[%d]:%d ", i, arr[i]); printf("\n");}void swap(int *i, int *j){ …

Linux C 读取文件夹下所有文件(包括子文件夹)的文件名

本文&#xff1a;http://www.cnblogs.com/xudong-bupt/p/3504442.html Linux C 下面读取文件夹要用到结构体struct dirent&#xff0c;在头#include <dirent.h>中&#xff0c;如下&#xff1a; #include <dirent.h> struct dirent {long d_ino; /* inode number 索…

报表工具实现单据套打

【摘要】 单据套打再也不用手动测量&#xff0c;反复调试了&#xff0c;报表工具实现单据套打&#xff0c;去乾学院看个究竟&#xff1a;报表工具实现单据套打!实际项目开发中&#xff0c;很多情况会涉及到单据的打印。即在一张印刷好的空白单据上&#xff0c;准确无误地打印上…

每隔10秒钟打印一个“Helloworld”

/*** 每隔10秒钟打印一个“Helloworld”*/ public class Test03 {public static void main(String[] args) throws InterruptedException {ThreadImp threadImp new ThreadImp();Thread thread1 new Thread(threadImp);thread1.start();} }class ThreadImp extends Thread {p…

C++ STL 优先队列

//优先队列//Priority_queue //STL#include<iostream>#include<cstdio>#include<cstdlib>#include<queue>using namespace std;struct cmp{ bool operator() (const int a,const int b) const{//用const定义的a,b是包裹着变量外衣的常数&#xff0c;不…

GDB调试core文件样例(如何定位Segment fault)

core dump又叫核心转储, 当程序运行过程中发生异常, 程序异常退出时, 由操作系统把程序当前的内存状况存储在一个core文件中, 叫core dump. (Linux中如果内存越界会收到SIGSEGV信号&#xff0c;然后就会core dump) 在程序运行的过程中&#xff0c;有的时候我们会遇到Segment fa…

管理信息系统的开发与管理

{% extendsmuban.html %} {% block head %}输入{% endblock %} {% block main %} <div><div class"form-group"><label for"question">标题</label><textarea class"form-control" cols"50" rows"2&q…

python11-28笔记(1.6-1.7)

1.6 多类型传值和冗余参数多类型传值&#xff1a;比如def fun(x,y)&#xff0c;定义2个形参定义一个元组t(1,2),如果把元组当做实参传入到函数中&#xff0c;会报错 如何将元组当做不同类型的参数传入到函数中fun(t) 代表传入的是元组或者这样调用fun((1,2))注意实参的个数要和…

session机制详解以及session的相关应用

session是web开发里一个重要的概念&#xff0c;在大多数web应用里session都是被当做现成的东西&#xff0c;拿来就直接用&#xff0c;但是一些复杂的web应用里能拿来用的session已经满足不了实际的需求&#xff0c;当碰到这样的情况时候我们需要更加深入的理解session的机制&am…

(转)Shell中获取字符串长度的七种方法

Shell中获取字符串长度的七种方法 原文&#xff1a;http://blog.csdn.net/jerry_1126/article/details/51835119 求字符串操作在shell脚本中很常用&#xff0c;下面归纳、汇总了求字符串的几种可能方法: 【方法一】:利用${#str}来获取字符串的长度 【方法二】:利用awk的length方…

linux下用core和gdb查询出现段错误的地方

有些时候我们在一段C代码的时候&#xff0c;由于对一个非法内存进行了操作&#xff0c;在程序运行的过程中&#xff0c;出现了"段错误"。呵呵&#xff0c;这种问题我想很多人会经常遇到。遇到这种问题是非常无语的&#xff0c;只是提示了"段错误"&#xff…

第一篇-Html标签中head标签,body标签中input系列,textarea和select标签

第十四周课程&#xff08;1-12章节&#xff09; HTML 裸体 CSS 穿华丽衣服 Javascript 动起来 一 HTML &#xff08;20个标签&#xff09; 1.我们的浏览器是socket客户端 2.一套规则&#xff0c;浏览器认识的规则 3.开发者&#xff1a; 学习html规则 开发后台程序&#xff1a…

opencv3.2.0 Cmake 3.8.0 + tdm-gcc-5.1.0-3

实测 tdm-gcc-5.1.0-3 tdm32-1 32位版本无法正确编译Opencv 3.2.0 会遇到诸多编译问题 解决办法 使用tdm-gcc-5.1.0-2 tdm64-1 64位版本转载于:https://www.cnblogs.com/fundou/p/6710209.html

什么是商品属性

一、什么是商品属性&#xff1a; Definition of Product Attributes A product attribute is a characteristic that defines a particular product and will affect a consumers purchase decision. Product attributes can be tangible (or physical in nature) or intangibl…

linux用户管理(1)----创建用户(adduser和useradd)和删除用户(userdel)

arm linux的系统用户管理&#xff1a; 1、删除root用户&#xff1a;deluser root2、删除tt用户:deluser tt3、建立root用户&#xff1a;adduser root4、修改用户密码&#xff1a;登录相应的用户后&#xff0c;用passwd来修改密码4、linux用户和密码的管理&#xff08;ftp&#…

前端性能优化之图像优化原理

前端性能优化中&#xff0c;图像的优化是非常重要的一环&#xff0c;为什么要说图像的优化呢&#xff0c;而不是我们常见的图片优化&#xff1f;因为这里的图像包括矢量图和位图&#xff0c;我们常说的图片优化是指位图的优化。这篇文章转载至奇舞周刊&#xff0c;大佬总结的非…