简单的oracle sql 语句
创建表空间
create tablespace qnhouse
--表空间文件路径
datafile 'E:\qnhost\qnhouse.dbf'
--表空间文件大小
size 100M;
创建用户
create user qnhouse
--登录密码
identified by qnhouse
--默认的表空间
default tablespace qnhouse;
为用户授权
--RESOURCE:拥有Resource权限的用户只可以创建实体,不可以创建数据库结构。
--CONNECT:拥有Connect权限的用户只可以登录Oracle,不可以创建实体,不可以创建数据库结构。
grant connect,resource to qnhouse;
建表与约束
--区域表
create table DISTRICT
(
id NUMBER not null,
name VARCHAR2(50) not null,
--约束
--主键约束
constraint PK_district_id primary key(id)
); --街道表
create table STREET
(
id NUMBER not null,
name VARCHAR2(50),
district_id NUMBER, --区域id
--约束
constraint PK_STREET_id primary key(id),
--外键约束
constraint FK_STREET_district_id foreign key (district_id) references district(id)
); --户型表
create table housetype
(
id NUMBER,
name VARCHAR2(50),
--约束
constraint PK_housetype_id primary key(id)
); --用户表
create table USERS
(
id NUMBER not null,
name VARCHAR2(50),
password VARCHAR2(50),
telephone VARCHAR2(15),
username VARCHAR2(50),
--默认值
isadmin VARCHAR2(5) default 0 not null,
--约束
constraint PK_USERS_id primary key(id),
--唯一约束
constraint UQ_users_name unique(name),
--检查约束,密码不能少于6位
constraint CK_users_password check (length(password)>=6)
); --房屋信息表
create table HOUSE
(
id NUMBER,
user_id NUMBER, --用户ID
type_id NUMBER, --户型ID
title NVARCHAR2(50),
description NVARCHAR2(2000),
price NUMBER,
pubdate DATE,
floorage NUMBER,
contact VARCHAR2(100),
street_id NUMBER, --街道ID
--约束
constraint PK_HOUSE_id primary key(id),
constraint FK_HOUSE_user_id foreign key (user_id) references users(id),
constraint FK_HOUSE_type_id foreign key (type_id) references housetype (id),
constraint FK_HOUSE_street_id foreign key (street_id) references STREET(id)
);
序列
--序列
create sequence seq_qnhouse
--递增值
increment by 1
--开始值
START WITH 1000;
自增触发器
--用户主键自增
create or replace trigger tri_users_id
before insert on users
for each row
begin
--用序列的值填到主键
select seq_qnhost.nextval into :new.id from dual;
end;
/
简单的oracle sql 语句的更多相关文章
- 简单的oracle sql语句练习
简单的oracle sql语句练习 求每个部门的平均薪水 select deptno,avg(sal) from emp group by deptno 每个部门同一个职位的最大工资 select d ...
- Oracle sql语句执行顺序
sql语法的分析是从右到左 一.sql语句的执行步骤: 1)词法分析,词法分析阶段是编译过程的第一个阶段.这个阶段的任务是从左到右一个字符一个字符地读入源程序,即对构成源程序的字符流进行扫描然后根据构 ...
- Oracle SQL语句追踪
Oracle SQL语句追踪 1 SQL语句追踪 追踪SQL语句的执行过程需要在Oracle服务器端进行,Oracle服务器端会检测并记录访问进程所执行的所有SQL语句.下面使用的命令都是在命令行 ...
- Oracle SQL语句执行过程
前言 QQ群讨论的时候有人遇到这样的问题:where子句中无法访问Oracle自定义的字段别名.这篇 博客就是就这一问题做一个探讨,并发散下思维,谈谈SQL语句的执行顺序问题. 问题呈现 直接给出SQ ...
- oracle管理优化必备语句以及oracle SQL语句性能调整
本文转自http://www.dataguru.cn/article-3302-1.html oracle数据库管理优化必备语句: 1. SELECT T.START_TIME,T.USED_UBLK ...
- Oracle SQL语句性能优化方法大全
Oracle SQL语句性能优化方法大全 下面列举一些工作中常常会碰到的Oracle的SQL语句优化方法: 1.SQL语句尽量用大写的: 因为oracle总是先解析SQL语句,把小写的字母转换成大写的 ...
- [转]关于oracle sql语句查询时表名和字段名要加双引号的问题
oracle初学者一般会遇到这个问题. 用navicat可视化创建了表,可是就是不能查到! 后来发现②语句可以查询到 ①select * from user; 但是,我们如果给user加上双引 ...
- Oracle SQL语句执行步骤
转自:http://www.cnblogs.com/quanweiru/archive/2012/11/09/2762345.html Oracle中SQL语句执行过程中,Oracle内部解析原理如下 ...
- oracle: sql语句报ora-01461/ora-00911错误
oracle: sql语句报ora-01461/ora-00911错误 ora-00911:sql语句中可能含有特殊字符,或者sql语句中不能用";"分号结尾. sql语句报ora ...
随机推荐
- CSS网页元素居中
1.水平居中:行内元素解决方案 只需要把行内元素包裹在一个属性display为block的父层元素中,并且把父层元素添加如下属性即可: text-align: center 适用元素:文字,链接,及其 ...
- (转) 学习C++ -> 向量(vector)
vector是向量类型,它是一种对象实体,具有值,所以可以看作是变量. 它可以容纳许多其他类型的相同实体,如若干个整数,所以称其为容器. vector类与一般的Array类的区别在于: 1 ...
- JavaScript开发规范
作为一名开发人员(WEB前端JavaScript开发),不规范的开发不仅使日后代码维护变的困难,同时也不利于团队的合作,通常还会带来代码安全以 及执行效率上的问题.本人在开发工作中就曾与不按规范来开发 ...
- [C++程序设计]用指向数组的指针作函数参数
#include <iostream> using namespace std; int main() { ]); ][]={,,,,,,,,,,,}; output(a); ; } ]) ...
- Anniversary party(POJ 2342 树形DP)
Anniversary party Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 5767 Accepted: 3335 ...
- javascript之Function函数
在javascript里,函数是可以嵌套的. 如: function(){ funcrion square(x){ return x*x; } return square(10); } 在javas ...
- 编译boost python模块遇到的错误:../../libraries/boost_1_44_0/boost/python/detail/wrap_python.hpp:75:24: fatal error: patchlevel.h: No such file or directory
就是遇到类似标题上面的错误. 原因是没有安装对应python的python-dev依赖,不然编译到boost python模块的时候就会出错. 所以解决方案是sudo apt-get install ...
- lambda演算
先了解下相关的知识点(以下都只用先了解简单的概念,建议wiki): BNF范式,上下文无关文法,函数柯里化. lambda读书笔记演算: http://www.blogjava.net/wxb_nud ...
- %{TIMESTAMP_ISO8601} 匹配2016-08-29 17:40:01,191
2016-08-29 17:40:01,191 INFO com.zjzc.common.utils.HttpUtil - 请求接口: https://www.zjcap.cn/pay/interfa ...
- mysql 保留的关键字
mysql> select precision from Product; ERROR 1064 (42000): You have an error in your SQL syntax; c ...