1. oracle怎么实现id自增和设置主键啊
可以使用序列实现id自增,主键的语法为primary key。
当一个序列第一次被查询调用时,它将返回一个预定值。在随后的每次查询中,序列将产生一个按指定的增量增长的值。序列可以循环,或者是连续增加的,直到指定的最大值为止。
创建序列语法如下:create sequence [模式]序颂慧列名称[start with 起始数字] [increment by 增量][maxvalue 最大值|nomaxvalue][minvalue 最小值|nominva lue][cycle|nocuyle][cache 数目|nocache][order|noorder]。
具体代码示例如下:
创野耐答建表
create table book(
bookId varchar2(4) primary key,
name varchar2(20)
);
创建序列
create sequence book_seq start with 1 increment by 1;
创建触发器
create or replace trigger book_trigger
before insert on book
for each row
begin
select book_seq.nextval into :new.bookId from al;
end ;
添加数据
insert into book(name) values ('cc');
insert into book(name) values ('dd');
commit;
(1)可以使用访问序列扩展阅读:
在数据表中,有时候需要主键值自动增加,但在Oracle数据库中,没有象Mysql的Autoincrement一样自动增长的数据类型。在实现Oracle数据库字段自增功能时,利用DML触发器来完成。
触发器(trigger)是一些过程,当发生亩前一个特定的数据库事件时就执行这些过程,可以使用触发器扩充引用的完整性。DML即数据操纵语言,用于让用户或程序员使用,实现对数据库中数据的操作。基本的数据操作分成两类四种:检索(查询)和更新(插入、删除、修改)。
触发器类似于函数和过程,其在数据库中以独立身分存在。触发事件可以是对数据库表的DML(insert、update或delete)操作等。
2. Oracle同一表空间可以建立两个同名的索引名
1) Oracle 数据库对象又称模式对象;数据库对象是逻辑结构的集合,最基本的数据库对象是表。
其他数据库对象包括:同义词,索巧租判引,序列,视图。
1.1 同义词是现有对象的一个别名。
简化SQL语句;隐藏对象的名称和所有者;提供对对象的公共访问。
同义词共有两种类型:私有同义词和公有同义词。
私有同义词只能在其模式内访问,且不能与当前模式的对象同名。
私有同义词语法:
CREATE SYNONYM emp FOR SCOTT.emp;--其中emp是SCOTT.emp 的别名,SCOTT 是模式名,emp是表明
公有同义词语法:
CREATE PUBLIC SYNONYM emp_syn FOR SCOTT.emp;--其中emp_syn 是 同义词名称
创建或替换现有的同义词:
CREATE OR REPLACE SYNONYM emp_syn FOR SCOTT.emp;-- OR REPLACE 是替换现有的同义词
删除同义词:
SQL DROP SYNONYM emp;
SQL DROP PUBLIC SYNONYM emp_syn;
1.2 序列
1.2.1序列是用于生成唯一、连续序号的对象;序列可以是升序的,也可以是降序的。
使用CREATE SEQUENCE语句创建序列:
SQL CREATE SEQUENCE toys_seq
START WITH 10
INCREMENT BY 10
MAXVALUE 2000
MINVALUE 10
NOCYCLE
CACHE 10;
注意:指定内存中预先分配的序号数 。
1.2.2访问序列:
通过序列的伪列来访问序列的值
NEXTVAL 返回序列的下一个值
CURRVAL 返回序列的当前值
SQL INSERT INTO toys (toyid, toyname, toyprice)
VALUES ( toys_seq.NEXTVAL, ‘TWENTY’, 25);
SQL INSERT INTO toys (toyid, toyname, toyprice)
VALUES ( toys_seq.NEXTVAL, ’MAGIC PENCIL’, 75);
--其中toys_seq.NEXTVAL指定序列的下一个值
SQL SELECT toys_seq.CURRVAL FROM al;-- 检索序列的当前值
1.2.3更改和删除序列
使用ALTER SEQUENCE语句型盯修改序列,不能更改序列的START WITH参数
SQL ALTER SEQUENCE toys_seq MAXVALUE 5000 CYCLE;
使用DROP SEQUENCE语句删除序列
SQL DROP SEQUENCE toys_seq;
1.3视图
1.3.1视图以经过定制的方式孝改显示来自一个或多个表的数据;
视图可以视为“虚拟表”或“存储的查询”;
创建视图所依据的表称为“基表。”
视图的优点有:
提供了另外一种级别的表安全性;
隐藏的数据的复杂性;
简化的用户的SQL命令;
隔离基表结构的改变;
通过重命名列,从另一个角度提供数据。
1.3.2创建视图的语法:
CREATE [OR REPLACE] [FORCE] VIEW
view_name [(alias[, alias]...)]
AS select_statement
[WITH CHECK OPTION]
[WITH READ ONLY];
CREATE VIEW stud_view(是图表)
AS SELECT studno, studname, subno(字段)
FROM Stud_details(原始表);
使用 WITH CHECK OPTION 选项创建视图
CREATE OR REPLACE VIEW pause_view AS
SELECT * FROM order_master WHERE ostatus = 'p'
WITH CHECK OPTION CONSTRAINT chk_pv;
使用 ORDER BY 子句创建视图
CREATE OR REPLACE VIEW ord_ven AS
SELECT * FROM vendor_master ORDER BY venname;
创建带有错误的视图
CREATE FORCE VIEW ven AS
SELECT * FROM venmaster;
创建外联接视图
CREATE VIEW ven_ord_outj_view AS
SELECT vm.vencode, venname, orderno, odate, ostatus
FROM vendor_master vm, order_master om
WHERE vm.vencode = om.vencode(+);
或者
SELECT vm.vencode, venname, orderno, odate, ostatus
FROM vendor_master vm LEFT OUTER JOIN order_master om
ON vm.vencode = om.vencode;
1.3.3视图上的DML语句
在视图上也可以使用修改数据的DML语句,如INSERT、UPDATE和DELETE
视图上的DML语句有如下限制:
只能修改一个底层的基表;
来源:( - 数据库对象_一土林夕_新浪博客如果修改违反了基表的约束条件,则无法更新视图;
如果视图包含连接操作符、DISTINCT 关键字、集合操作符、聚合函数或 GROUP BY 子句,则将无法更新视图;
如果视图包含伪列或表达式,则将无法更新视图。
视图中可以使用单行函数、分组函数和表达式:
CREATE VIEW item_view AS
SELECT itemcode, LOWER(itemdesc) item_desc
FROM itemfile;
使用DROP VIEW语句删除视图
SQL DROP VIEW toys_view;
1.4索引
索引有各种类型,除了标准索引外,还有一些特殊类型的索引:
索引的类型:唯一索引、位图索引、组合索引、基于函数的索引、反向键索引。
创建标准索引:
SQL CREATE INDEX item_index ON itemfile (itemcode)
TABLESPACE index_tbs;
重建索引:
SQL ALTER INDEX item_index REBUILD;
删除索引:
SQL DROP INDEX item_index;
1.4.1唯一索引
唯一索引确保在定义索引的列中没有重复值
Oracle 自动在表的主键列上创建唯一索引
使用CREATE UNIQUE INDEX语句创建唯一索引:
SQL CREATE UNIQUE INDEX item_index
ON itemfile (itemcode);
1.4.2组合索引
组合索引是在表的多个列上创建的索引;
索引中列的顺序是任意的;
如果 SQL 语句的 WHERE 子句中引用了组合索引的所有列或大多数列,则可以提高检索速度。
SQL CREATE INDEX comp_index
1.4.3反向键索引
反向键索引反转索引列键值的每个字节;
通常建立在值是连续增长的列上,使数据均匀地分布在整个索引上;
创建索引时使用REVERSE关键字:
SQL CREATE INDEX rev_index
ON itemfile (itemcode) REVERSE;
SQL ALTER INDEX rev_index REBUID NOREVERSE;
1.4.4位图索引
位图索引适合创建在低基数列上;
位图索引不直接存储ROWID,而是存储字节位到ROWID的映射;
减少响应时间;
节省空间占用。
语法:
SQL CREATE BITMAP INDEX bit_index
ON order_master (orderno);
1.4.5索引组织表
索引组织表的数据存储在与其关联的索引中;
索引中存储的是行的实际数据,而不是ROWID;
基于主键访问数据;
CREATE TABLE 命令与 ORGANIZATION INDEX 子句一起用于创建索引组织表:
SQL CREATE TABLE ind_org_tab (
vencode NUMBER(4) PRIMARY KEY,
venname VARCHAR2(20)
)
ORGANIZATION INDEX;
普通表与索引组织表的比较:
普通表索引组织表
ROWID 唯一地标识行 主键唯一地标识行
隐式的 ROWID 列 没有隐式的 ROWID 列
基于 ROWID 的访问 基于主键的访问
顺序扫描返回所有行 完全索引扫描返回所有行,并按主键顺序排列
支持分区 不支持分区
1.4.6基于函数的索引
基于一个或多个列上的函数或表达式创建的索引
表达式中不能出现聚合函数
不能在LOB类型的列上创建
创建时必须具有 QUERY REWRITE 权限
SQL CREATE INDEX lowercase_idx
ON toys (LOWER(toyname));
SQL SELECT toyid FROM toys
WHERE LOWER(toyname)='doll';
1.4.7索引中的分区
可以将索引存储在不同的分区中
与分区有关的索引有三种类型:
局部分区索引 - 在分区表上创建的索引,在每个表分区上创建独立的索引,索引的分区范围与表一致;
全局分区索引 - 在分区表或非分区表上创建的索引,索引单独指定分区的范围,与表的分区范围或是否分区无关;
全局非分区索引 - 在分区表上创建的全局普通索引,索引没有被分。
1.4.8获取索引的信息
与索引有关的数据字典视图有:
USER_INDEXES - 用户创建的索引的信息;
USER_IND_PARTITIONS - 用户创建的分区索引的信息;
USER_IND_COLUMNS - 与索引相关的表列的信息。
SQL SELECT INDEX_NAME, TABLE_NAME, COLUMN_NAME
FROM USER_IND_COLUMNS
ORDER BY INDEX_NAME, COLUMN_POSITION;
来源:( - 数据库对象_一土林夕_新浪博客
3. Python+语言可以通过索引来访问序列中的元素是正确的嘛
是的,Python语言可以通过索引来访问序列中的元素。序列是一种基本的数据类型,包括列表、元组和字符带悔灶串等。
通过索引可以访问序列中的单个元蠢扮素,索引从0开始递增。例如,访前尺问列表中第一个元素可以使用索引0,访问第二个元素可以使用索引1,以此类推。例如:
Copy code
my_list = ['apple', 'banana', 'orange']
print(my_list[0]) # 输出 'apple'
print(my_list[1]) # 输出 'banana'
print(my_list[2]) # 输出 'orange'
此外,还可以使用负数索引访问序列中的元素,-1 表示最后一个元素,-2 表示倒数第二个元素,以此类推。例如:
Copy code
my_tuple = (1, 2, 3, 4, 5)
print(my_tuple[-1]) # 输出 5
print(my_tuple[-2]) # 输出 4
4. 页面访问序列怎么求
一般采用以下几种算法
1、最佳置换算法
2、先进先出迟败毕置换算法
3、最近最久未使用置换算法
4、改进型Clock置换算法
5、页面缓冲置换算法
例如
已知页面大小为100,则可分成第1页:0-100,第2页:100-200.。。。第5页:400-500
根据已知进程访问序列,可知10在第1页内,11在第1页内,以此类推得出枯兄页面访问序列:
1,1,2,2,1,4,2,3,3,5,5,4
页面访问的序列串是一个整数序列,需要我们编写函数生成,要求整数的取值范围为0-N-1。页面访问序列串中的每个元素p表示对页面p的一次访问。1.确定虚拟内存的尺寸N,工作集的起始位置p,工作集中包含的页数e,工作集移动率m(每处理m个页面访问则将起始位置p +1),以及一个范围在0和1之间的值t;2.生成m个取值范围在p和p + e间的码芹随机数,并记录到页面访问序列串中; 3.生成一个随机数r,0 ≤ r ≤ 1;4.如果r < t,则为p生成一个新值,否则p = (p + 1) mod N; 5.如果想继续加大页面访问序列串的长度,请返回第2步,否则结束。
5. Oracle数据库中nextval和values代表什么意思
可以通过在 SQL 语句中使用 NEXTVAL 或 CURRVAL 运算符来访问序列的值。必须用以 sequence.NEXTVAL 或 sequence.CURRVAL 格式驻留在同一个数据库中的序列名称(或同义词)来限定 NEXTVAL 或 CURRVAL。表达式也可以用所有者名来限定序列,如 zelaine.myseq.CURRVAL。可以指定 sequence 的 SQL 标识或有效同义词(如果存在的话)。
在符合 ANSI 的数据库中,如果您不是所有者,必须用所有者名(owner.sequence)限定序列名。
要对序列使用 NEXTVAL 或 CURRVAL,必须对序列具有选择特权或对数据库具有 DBA 特权。关于序列级特权的信息,请参阅 GRANT 语句。
使用 NEXTVAL
第一次访问一个序列,在引用 sequence.CURRVAL 之前必须先引用 sequence.NEXTVAL。第一次引用 NEXTVAL,返回序列的初始值。后面每次引用 NEXTVAL,用已定义的 step 增加序列值并返回序列新的增加以后的值。
在一个 SQL 语句中只能对给定的序列增加一次。即使在一个语句中多次指定 sequence.NEXTVAL,序列也只增加一次,所以每次 sequence.NEXTVAL 出现在同一 SQL 语句中返回相同的值。
除了在同一语句中多次出现这种情况以外,每个 sequence.NEXTVAL 表达式都会增加序列,无论后来是否提交或回滚当前事务。
如果在最终回滚的事务中指定 sequence.NEXTVAL,某些序列数可能被跳过。
使用 CURRVAL
任何对 CURRVAL 的引用返回指定序列的当前值,该值是最后一次对 NEXTVAL 的引用所返回的值。用 NEXTVAL 生成一个新值以后,可以继续使用 CURRVAL 访问这个值,不管另一个用户是否增加这个序列。
如果 sequence.CURRVAL 和 sequence.NEXTVAL 都出现在一个 SQL 语句中,则序列只增加一次。在这种情况下,每个 sequence.CURRVAL 和 sequence.NEXTVAL 表达式都返回相同的值,不管在语句中 sequence.CURRVAL 和 sequence.NEXTVAL 的顺序。
序列的并发访问
序列总是在数据库中生成唯一值,即使当多个用户并发地引用同一序列时也没有可察觉的等待或锁定。当多个用户使用 NEXTVAL 来增长序列时,每个用户生成一个其他用户不可见的唯一值。
当多个用户并发地增加同一序列时,每个用户看到的值是有差异的。例如,一个用户可能从一个序列生成一组值,如 1、4、6 和 8,而另一个用户并发地从同一序列生成值 2、3、5 和 7。
限制
NEXTVAL 和 CURRVAL 只在 SQL 语句中有效,并不在 SPL 语句中直接有效。(但是使用 NEXTVAL 和 CURRVAL 的 SQL 语句可用于 SPL 例程。)以下限制应用于 SQL 语句中的这些运算符:
必须对序列有选择特权。
在 CREATE TABLE 或 ALTER TABLE 语句中,在下列上下文中不能指定 NEXTVAL 或 CURRVAL:
在 DEFAULT 子句中
在检查约束中。
在 SELECT 语句中,下列上下文中不能指定 NEXTVAL 或 CURRVAL:
使用 DISTINCT 关键字时在投影列表中。
在 WHERE、GROUP BY 或 ORDER BY 子句中
在子查询中
在 UNION 运算符结合 SELECT 语句时。
在下列这些上下文中也不能指定 NEXTVAL 或 CURRVAL:
在分段存储表达式中
在对另一个数据库中的远程序列对象的引用中。
示例
在下面的例子中,假设没有其它用户并发地访问序列并且用户连续执行语句。
6. Python 通用的序列操作
序列 (sequence)是Python最基本的一种数据结构。
序列中的每个元素都有编号,即其位置或索引,其中第一个元素的索引为0,第二个元素的索引为1,依此类推。Python的序列索引支持负数,-1表示序列的最后一个元素,这是Python不同其他很多种语言不同的地方。
Python内置了多种序列,列表、元组、字符串是其中最常用的三种,本文为你描述各种序列的通用操作。
索引从0开始,索引号为0的元素为1,greeting的索引号为0的元素为'H'。
你可能注意到'Hello'和'H'都用单引号包围,这是Python不同于其他语言的另一个地方。Python并没有专门用于表示字符的数据类型,因此一个字符就是一个只包含一个元素的字符串。
Python的序列索引支持负数,-1表示倒数第一个元素。
切片 (slicing)操作用于访问序列特定 范围 内的元素。在一对方括号内使用两个索引,并用冒号隔开:
注意到,返回的序列并未包含愿序列的第6个元素7,就相当于数学集合中的 左闭右开区间 操作。
换言之,你提供两个索引来指定切片的边界,其中第一个索引指定的元素包含在切片内,但第二个索引指定的元素不包含在切片内。
保留冒号,省略羡运备第一个索引,表示从序列起始位置开始切片;省略第二个索引,表示切片到序列末尾,包含最后一个元素:
这个操作的效果是:在指定的区间内间隔取元素,语法格式为:
例如:
步长为正数时,它从起点移到终点,而步长为负数时,它从终点移到起点。
可以使用加法运算(+运算符)拼接两个序列:
从错误消息兄毁可知,不能拼接列表和字符串,虽然它们都是序列。一般而言,不悄配能拼接不同类型的序列。
将序列与数x 相乘时,将重复这个序列x 次来创建一个新序列:
初始化一个长度为10的空列表:
成员资格检查判定一个元素是否存在于集合中,如存在返回True,否则返回False,实际上是一个布尔表达式。
语法:
例如:
内置函数 len 返回序列包含的元素个数,而 min 和 max 分别返回序列中最小和最大的元素。
Python通用的序列操作有:索引、切片、乘法、成员资格检查、长度、最小值和最大值。
7. oracle使用什么可以访问序列当前的值和下一个值
这个需要分两步来斗迅完胡销卜成1 drop sequence 序列名;2 create sequence 序列名minvalue 最小值maxvalue 最裤穗大值start with 开始值increment by 递增cache 20order;