好的编程习惯,是一个很有必要的过程。好的编程习惯,可以因人而异,但是简单地、基本地代码级别的就那些:写注释、合理的缩进、换行、变量命名等。

  对我们程序员来说,大部分时间都对着电脑,在对着电脑的大部分时间都在对着代码,要么是看别人代码,要么是在写代码。在看别人的代码的过程中,当看到别人 的代码很乱的时候,心里肯定会说,这他妈的谁写的代码,看起来真费劲,要注释没注释,该换行的时候没换行,缩进也没规则。所以,好的编程习惯,一个好处就是,方便自己,也方便别人看自己的代码。编程的时候很多情况是由于一些细节没有注意。在自己代码走读的过程成中会出现对应错误,良好的代码习惯,也有利于问题代码能快速的定位。好的编程习惯,好处就是,可以避免一些问题的发生,从而提高工作效率。

  一般情况下我们的ORACLE 使用关键字上要使用大写的,这样有利于 编程规范,所以这边提供一个小技巧:

  在PL/SQL Tool -> Preferences 中的:

  

Oracle 数据库中,创建一个表的过程,并且其中主键是自动增长的,因为ORACLE 不提供自动增长的自主id,所以,需要我们自己先创建序列然后在调用序列的方法实现自动增长一般过程如下:

-- Create table

CREATE TABLE T_Test(

        test_id INTEGER CONSTRAINT t_test_pk PRIMARY KEY,

        name VARCHAR2(10) NOT NULL

);      

-- Add comments to the table

COMMENT ON TABLE T_Test

  is '测试表';

-- Add comments to the columns

COMMENT ON COLUMN  T_Test.test_id

  is '自增主键';

COMMENT ON COLUMN  T_Test.name

  is '名称';

-- Create/Sequences

CREATE SEQUENCE SEQ_T_Test MINVALUE 1 MAXVALUE 1E27 START WITH 1 INCREMENT BY 1 NOCACHE CYCLE;

--insert

INSERT INTO t_test(test_id,NAME)VALUES(seq_t_test.nextval,'linkepeng');

每次我这样插入数据的时候,如果开始的时候,没有创建对应的序列的化,我们还要先创建,而且,有可能命名冲突,等一些情况,感觉使用起来不方便

这边我写个函数,是为了解决,自动创建的函数这样调用者,不用去关心,序列是否已经创建,而且只要每次调用传入对应的表名字,这样就能获取对应的增长的ID。

第一步:
/*
描述:取字符串左边几个字符
作者:linkepeng
日期:2016-08-07
*/
CREATE OR REPLACE FUNCTION LeftStr
(
M_Text VARCHAR2,
M_Count INTEGER
)
RETURN VARCHAR
AS
L_Result VARCHAR(4000);
BEGIN
L_Result:='';
IF M_Text IS NOT NULL THEN
L_Result:=Substr(M_Text,1,M_Count);
END IF;
RETURN L_Result;
END; /*
描述:创建序列对象
作者:linkepeng
日期:2016-08-07
*/
CREATE OR REPLACE PROCEDURE CreateSequence
(
M_TableName IN VARCHAR2 --表名或序列对象名称
)
--这个在普通用户情况下,需要添加这条语句。
AUTHID CURRENT_USER
AS
L_UserName VARCHAR2(30);
L_SqlString VARCHAR2(1000);
L_SequenceName_C VARCHAR2(500);
L_RowCount INTEGER;
L_MAXID NUMBER;
L_Key_FieldName VARCHAR2(50);
BEGIN
--根据表名得到序列名称
L_SequenceName_C := REPLACE(M_TableName,'-','_');
IF UPPER(LeftStr(L_SequenceName_C,4))<>'SEQ_' THEN
L_SequenceName_C := 'SEQ_' || L_SequenceName_C;
END IF;
L_SequenceName_C := UPPER(LeftStr(L_SequenceName_C,30));
--根据表名取出主键字段
BEGIN
SELECT COLUMN_NAME INTO L_Key_FieldName
FROM User_Cons_Columns
WHERE CONSTRAINT_NAME IN (
SELECT CONSTRAINT_NAME
FROM User_Constraints
WHERE CONSTRAINT_TYPE = 'P' AND UPPER(TABLE_NAME)=UPPER(M_TableName)
) AND ROWNUM=1;
--根据表名、主键字段取出最大值
L_SqlString := 'SELECT MAX(' || L_Key_FieldName || ') FROM ' || M_TableName;
BEGIN
EXECUTE IMMEDIATE L_SqlString INTO L_MAXID;
EXCEPTION
--捕捉错误
WHEN OTHERS THEN
L_MAXID:=0;
END;
EXCEPTION
WHEN OTHERS THEN
L_MAXID:=0;
END;
L_MAXID := NVL(L_MAXID, 0);
--修改下一个值
L_MAXID := L_MAXID + 1;
L_SqlString := 'CREATE SEQUENCE ' || L_SequenceName_C;
L_SqlString:=L_SqlString ||' MINVALUE 1 MAXVALUE 1E27 START WITH '||to_char(L_MAXID) || ' INCREMENT BY 1 NOCACHE CYCLE';
PRAGMA AUTONOMOUS_TRANSACTION;
EXECUTE IMMEDIATE L_SqlString;
END; /*
描述:获取某个表主键新ID
作者:linkepeng
日期:2016-08-07
*/
CREATE OR REPLACE FUNCTION GetNewID
(
M_TableName IN VARCHAR2
)
RETURN INTEGER
AUTHID CURRENT_USER
AS
L_StrSql VARCHAR2(1000);
L_NewID INTEGER;
L_RowCount INTEGER;
L_SequenceName_T VARCHAR2(255);
BEGIN
L_SequenceName_T :=LeftStr('Seq_'||REPLACE(M_TableName,'-','_'),30);
--判断序列是否存在
SELECT COUNT(*) INTO L_RowCount FROM User_Objects
WHERE Object_Type = 'SEQUENCE' AND Upper(OBJECT_NAME) = Upper(L_SequenceName_T);
IF L_RowCount=0 THEN
--通过存储过程创建序列
CreateSequence(M_TableName);
END IF;
L_StrSql:='SELECT '||L_SequenceName_T||'.Nextval FROM dual';
EXECUTE IMMEDIATE L_StrSql INTO L_NewID;
RETURN L_NewID;
END;

其中 AUTHID CURRENT_USER 为的防止用户出现: EXECUTE IMMEDIATE 如果在执行DDL的时候,如果在存储过程没有这个的化,会出现权限不足的问题。

还有一种解决方案是:给用户提高权限:在sysdba权限 用户下,提高权限命令:       GRANT CREATE ANY TABLE TO '用户名';

这样创建以后,我们就可以这样调用我们的插入语句了:

  INSERT INTO t_test(test_id,NAME)VALUES(getnewid('t_test'),'linkepeng');

在写代码的时候,可能出现的序列未创建的异常就可以很好的避免了。

ORACLE 自动增长通过封装函数,方便调用的更多相关文章

  1. oracle 自动增长

    在SQLSERVER和MYSQL里面自动增长字段直接设置就可以.在ORACLE里面就复杂多了.特别是我这样的初学者,不过网络是最好的老师,看了很多相关介绍,本人使用的是使用触发器.具体如下: 首先要创 ...

  2. Oracle自动增长的序列号

    首先建立序列: Create sequence user_id Increment Start Maxvalue .0E28 Minvalue nocycle Cache Noorder; 然后建立触 ...

  3. oracle添加数据时主键自动增长

    CREATE TABLE STUDENT( --创建学生表  ID NUMBER(10) PRIMARY KEY,   --主键ID  SNAME VARCHAR2(20), ); 此时给学生表添加数 ...

  4. Oracle创建自动增长列

    前言: Oracle中不像SQL Server在创建表的时候使用identity(1001,1)来创建自动增长列,而是需要结合序列(Sequences)和触发器(Triggers)来实现 创建测试表 ...

  5. oracle建表并设置ID为自动增长

    CREATE TABLESPACE shopping DATAFILE 'D:\oracle\mypc\oradata\orcl\shopping.dbf' SIZE 20M AUTOEXTEND O ...

  6. Oracle中的自动增长字段

    Oracle中的自动增长字段 Oracle 中不像MYSQL 和MSSQLServer 中那样指定一个列为自动增长列的方式,不过在Oracle中可以通过SEQUENCE序列来实现自动增长字段. 在Or ...

  7. Hibernate注解映射sequence时出现无序增长问题+hibernate 映射 oracle ID自动增长:

    Hibernate注解映射sequence时出现无序增长问题+hibernate 映射 oracle ID自动增长: 通过Hibernate注解的方式映射oracel数据库的sequence主键生成器 ...

  8. PowerDesigner连接Oracle数据库建表序列号实现自动增长

    原文:PowerDesigner连接Oracle数据库建表序列号实现自动增长 创建表就不说了.下面开始介绍设置自动增长列. 1 在表视图的列上创建.双击表视图,打开table properties — ...

  9. Mysql,SqlServer,Oracle主键自动增长的设置

    1.把主键定义为自动增长标识符类型 MySql 在mysql中,如果把表的主键设为auto_increment类型,数据库就会自动为主键赋值.例如: )); insert into customers ...

随机推荐

  1. CSS3常用选择器(三)

    在CSS3的选择器中,除了结构性伪类选择器外,还有一种UI元素状态伪类选择器.这些选择器的共同特征: 指定的样式只有当元素处于某种状态时才起作用,在默认状态下不起作用. 1.hover.focus.a ...

  2. Android开发--仿微信语音对讲录音

    原文地址:http://www.2cto.com/kf/201502/378704.html 自微信出现以来取得了很好的成绩,语音对讲的实现更加方便了人与人之间的交流.今天来实践一下微信的语音对讲的录 ...

  3. easyui combobox点击输入框弹出下拉框

    由于easyui combobox需要点击下拉箭头才能下拉,不能像select标签那样点击输入框就下拉,所以觉得不太方便,查看了一下,combobox弹出框是一个div,原本想在他的输入框的点击事件中 ...

  4. C# 导入EXCEL 报错外部表不是预期的格式错误 .

    错误经过:在读取Excel时,出现外部表不是预期的格式 错误原因1: 由于Excel 97-2003的连接格式与Excel 2010 的 不同造成. 以下是从网上摘抄原文 Excel “Externa ...

  5. 3D旋转相册(适合新手)

    <!DOCTYPE HTML> <html onselectstart="return false"> <head> <meta char ...

  6. 转载:jQuery实现返回顶部功能

    转自:http://blog.csdn.net/itmyhome1990/article/details/25340705 整理两个实现功能,一个是右下角的返回顶部,一个是右侧的返回顶部,分别如图   ...

  7. setValuesForKeysWithDictionary 的用法

    字典的快速赋值 setValuesForKeysWithDictionary 字数918 阅读6604 评论6 喜欢32 前言 在学习解析数据的时候,我们经常是这么写的:PersonModel.h文件 ...

  8. ios 正则表达式之验证手机号、邮箱、身份证、银行卡

    1.手机号 + (BOOL) IsPhoneNumber:(NSString *)number { NSString *phoneRegex1=@"1[34578]([0-9]){9}&qu ...

  9. DFTX 笔试

    char aa[8] = "abcd"; printf("%d",strlen(aa));  4 printf("%d",sizeof(aa ...

  10. SQL Server创建复合索引时,复合索引列顺序对查询的性能影响

    说说复合索引 写索引的博客太多了,一直不想动手写,有一下两个原因:一是觉得有炒剩饭的嫌疑,有兄弟曾说:索引吗,只要在查询条件上建索引就行了,真的可以这么暴力吗?二来觉得,索引是个非常大的话题,很难概括 ...