목차
Oracle 데이터베이스에서 필드를 수정하는 방법
Oracle ALTER TABLE MODIFY列示例
데이터 베이스 Oracle Oracle 데이터베이스의 필드를 수정하는 방법

Oracle 데이터베이스의 필드를 수정하는 방법

Mar 02, 2022 pm 06:13 PM
oracle 데이터 베이스

Oracle에서는 "ALTER TABLE MODIFY" 문을 사용하여 필드를 수정할 수 있습니다. 구문은 "수행할 ALTER TABLE 테이블 이름 MODIFY 필드 이름 작업"입니다. 열의 기본값, 가상 열의 표현 수정 등

Oracle 데이터베이스의 필드를 수정하는 방법

이 튜토리얼의 운영 환경: Windows 7 시스템, Oracle 11g 버전, Dell G3 컴퓨터.

Oracle 데이터베이스에서 필드를 수정하는 방법

Oracle에서는 "ALTER TABLE MODIFY" 문을 사용하여 필드를 수정하고 기존 필드의 정의를 변경할 수 있습니다. ALTER TABLE MODIFY”语句来修改字段,更改现有字段的定义。

要更改表中列的定义,请按如下所示使用ALTER TABLE MODIFY列语法:

ALTER TABLE 表名 
MODIFY 字段名 需要执行的操作;
로그인 후 복사

语句很直接。要修改表的列,需要指定要执行的列名,表名和操作。

Oracle允许执行多种操作,但以下是主要常用的操作:

  • 修改列的可见性

  • 允许或不允许NULL值

  • 缩短或扩大列的大小

  • 更改列的默认值

  • 修改虚拟列的表达式

要修改多个列,请使用以下语法:

ALTER TABLE 表名
MODIFY (
    字段名1 action,
    字段名2 action,
    ...
);
로그인 후 복사

Oracle ALTER TABLE MODIFY列示例

首先,为演示创建一个名为accounts的新表:

-- 12c语法
CREATE TABLE accounts (
    account_id NUMBER GENERATED BY DEFAULT AS IDENTITY,
    first_name VARCHAR2(25) NOT NULL,
    last_name VARCHAR2(25) NOT NULL,
    email VARCHAR2(100),
    phone VARCHAR2(12) ,
    full_name VARCHAR2(51) GENERATED ALWAYS AS( 
            first_name || ' ' || last_name
    ),
    PRIMARY KEY(account_id)
);
로그인 후 복사

其次,向accounts表中插入一些行:

INSERT INTO accounts(first_name,last_name,phone)
VALUES('Trinity',
       'Knox',
       '410-555-0197');


INSERT INTO accounts(first_name,last_name,phone)
VALUES('Mellissa',
       'Porter',
       '410-555-0198');


INSERT INTO accounts(first_name,last_name,phone)
VALUES('Leeanna',
       'Bowman',
       '410-555-0199');
로그인 후 복사

第三,通过使用下面的SELECT语句验证插入操作:

SELECT
    *
FROM
    accounts;
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사

执行上面查询语句,得到以下结果 -

Oracle 데이터베이스의 필드를 수정하는 방법

1. 修改列的可见性

在Oracle 12c中,可以将表列定义为不可见或可见。不可见列不可用于查询,如:

SELECT
    *
FROM
    table_name;
로그인 후 복사

或者,

DESCRIBE table_name;
로그인 후 복사

都是查到不到不可见列的。

但是,可以通过在查询中显式指定不可见列来查询:

SELECT
    invisible_column_1,
    invisible_column_2
FROM
    table_name;
로그인 후 복사

默认情况下,表列是可见的。可以在创建表或使用ALTER TABLE MODIFY列语句时定义不可见列。

例如,以下语句使full_name列不可见:

ALTER TABLE accounts 
MODIFY full_name INVISIBLE;
로그인 후 복사

执行再次查询表中数据,得到以下结果 -

Oracle 데이터베이스의 필드를 수정하는 방법

以下语句返回accounts表除了full_name列以外的所有列中返回数据:

SELECT
    *
FROM
    accounts;
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사

这是因为full_name列是不可见的。要将列从不可见变为可见,请使用以下语句:

ALTER TABLE accounts 
MODIFY full_name VISIBLE;
로그인 후 복사

2. 允许或不允许null示例

以下语句将email列更改为接受非空(not null)值:

ALTER TABLE accounts 
MODIFY email VARCHAR2( 100 ) NOT NULL;
로그인 후 복사
로그인 후 복사

但是,Oracle发出以下错误:

SQL Error: ORA-02296: cannot enable (OT.) - null values found
로그인 후 복사

因为当将列从可为null改为not null时,必须确保现有数据符合新约束(也就是说,如果原来数据中NULL是不行的)。

为了解决这个问题,首先更新email列的值:

UPDATE 
    accounts
SET 
    email = LOWER(first_name || '.' || last_name || '@oraok.com') ;
로그인 후 복사

请注意,LOWER()函数将字符串转换为小写字母。

然后改变email列的约束:

ALTER TABLE accounts 
MODIFY email VARCHAR2( 100 ) NOT NULL;
로그인 후 복사
로그인 후 복사

现在,它应该就会按预期那样工作了。

3. 扩大或缩短列示例的大小

假设要添加国际代码到phone列上,比如:前缀加上+86。 在修改列的值之前,必须使用以下语句扩大phone列的大小:

ALTER TABLE accounts 
MODIFY phone VARCHAR2( 24 );
로그인 후 복사

现在,我们可以更新电话号码的数据了:

UPDATE
    accounts
SET
    phone = '+86 ' || phone;
로그인 후 복사

以下语句验证更新:

SELECT
    *
FROM
    accounts;
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사

执行上面查询语句结果中,应该可以看到原电话号码前缀有加上+86的国际区号了。

Oracle 데이터베이스의 필드를 수정하는 방법

要缩短列的大小,请确保列中的所有数据都符合新的大小。

例如,尝试将phone列的大小缩减到12个字符:

ALTER TABLE accounts 
MODIFY phone VARCHAR2( 12 );
로그인 후 복사
로그인 후 복사

Oracle数据库发出以下错误:

SQL Error: ORA-01441: cannot decrease column length because some  value is too big
로그인 후 복사

要解决这个问题,首先,应该从电话号码中删除国际代码(即:+86):

UPDATE
    accounts
SET
    phone = REPLACE(
        phone,
        '+86 ',
        ''
    );
로그인 후 복사

REPLACE()函数用一个新的子字符串替换一个子字符串。在这种情况下,它将用空字符串替换+86

然后缩短phone列的大小:

ALTER TABLE accounts 
MODIFY phone VARCHAR2( 12 );
로그인 후 복사
로그인 후 복사

4. 修改虚拟列

假设按以下两列的格式填写全名:

last_name, first_name
로그인 후 복사

为此,可以更改虚拟列full_name

테이블의 열 정의를 변경하려면 다음과 같이 ALTER TABLE MODIFY 열 구문을 사용하세요. 🎜
ALTER TABLE accounts 
MODIFY full_name VARCHAR2(52) 
GENERATED ALWAYS AS (last_name || ', ' || first_name);
로그인 후 복사
로그인 후 복사
🎜문은 간단합니다. 테이블의 컬럼을 수정하려면 컬럼 이름, 테이블 이름, 수행할 작업을 지정해야 합니다. 🎜🎜Oracle을 사용하면 다양한 작업을 수행할 수 있지만 일반적으로 사용되는 주요 작업은 다음과 같습니다. 🎜
  • 🎜열 표시 여부 수정🎜< /li>
  • 🎜NULL 값을 허용하거나 허용하지 않습니다🎜
  • 🎜열 크기를 줄이거나 확장합니다🎜
  • 🎜열의 기본값 변경🎜
  • 🎜가상 열 수식의 표현식 수정 🎜
🎜여러 열을 수정하려면 다음 구문을 사용하세요: 🎜
SELECT
    *
FROM
    accounts;
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사

Oracle ALTER TABLE MODIFY 열 예 🎜🎜🎜 먼저 🎜 데모용 accounts라는 새 테이블을 만듭니다. 🎜
ALTER TABLE accounts
ADD status NUMBER( 1, 0 ) DEFAULT 1 NOT NULL ;
로그인 후 복사
로그인 후 복사
🎜🎜두 번째 🎜, accounts에 일부 행을 삽입합니다. 테이블: 🎜
ALTER TABLE accounts 
MODIFY status DEFAULT 0;
로그인 후 복사
로그인 후 복사
🎜🎜Third 🎜 , 다음 SELECT 문을 사용하여 삽입 작업을 확인합니다. 🎜
INSERT INTO accounts ( first_name, last_name, email, phone )
VALUES ( &#39;Julia&#39;,
         &#39;Madden&#39;,
         &#39;julia.madden@oraok.com&#39;,
         &#39;410-555-0200&#39; );
로그인 후 복사
로그인 후 복사
🎜위 쿼리 문을 실행하고 다음 결과를 얻습니다.🎜🎜Oracle 데이터베이스의 필드를 수정하는 방법🎜🎜🎜1. 열 가시성 수정 🎜🎜🎜Oracle 12c에서는 테이블 열을 표시 또는 표시로 정의할 수 있습니다. 🎜
SELECT
  *
FROM
  accounts;
로그인 후 복사
로그인 후 복사
🎜 또는 🎜rrreee🎜와 같은 쿼리에는 보이지 않는 열을 사용할 수 없습니다. 🎜🎜그러나 쿼리에 명시적으로 지정하여 보이지 않는 열을 쿼리할 수 있습니다. 🎜rrreee🎜테이블 열은 기본적으로 표시됩니다. 보이지 않는 열은 테이블을 생성하거나 ALTER TABLE MODIFY 열 문을 사용할 때 정의할 수 있습니다. 🎜🎜예를 들어 다음 문은 full_name 열을 보이지 않게 만듭니다. 🎜rrreee🎜테이블의 데이터 쿼리를 다시 실행하고 다음 결과를 얻습니다.🎜🎜Oracle 데이터베이스의 필드를 수정하는 방법🎜🎜다음 문은 계정을 반환합니다. full_name<을 제외한 테이블 /code> 열을 제외한 모든 열의 데이터를 반환합니다. 🎜rrreee🎜 이는 <code>full_name 열이 표시되지 않기 때문입니다. 열을 표시할 수 있는 상태로 변경하려면 다음 문을 사용하세요: 🎜rrreee🎜🎜2. null 예를 허용하거나 허용하지 않음🎜🎜🎜다음 문은 email 열이 null이 아닌(null이 아님) 값을 허용하도록 변경되었습니다: 🎜rrreee🎜 그러나 Oracle은 다음 오류를 발생시킵니다: 🎜rrreee🎜 열을 사용 가능에서 변경할 때 to nullnot null로 변경할 때 기존 데이터가 새 제약 조건을 준수하는지 확인해야 합니다(즉, NULL이 허용되지 않는 경우). 원본 데이터에서). 🎜🎜이 문제를 해결하려면 먼저 email 열의 값을 업데이트하세요. 🎜rrreee🎜LOWER() 함수는 문자열을 소문자로 변환합니다. 🎜🎜그런 다음 email 열의 제약 조건을 변경합니다. 🎜rrreee🎜이제 예상대로 작동합니다. 🎜🎜🎜3. 열의 크기를 늘리거나 줄이세요🎜🎜🎜휴대폰</code에 국제 코드를 추가하고 싶다고 가정해 보세요. > 열(예: <code>+86 접두사) 열 값을 수정하기 전에 다음 문을 사용하여 phone 열의 크기를 확장해야 합니다. 🎜rrreee🎜이제 전화번호 데이터를 업데이트할 수 있습니다. 🎜rrreee🎜다음 문은 업데이트: 🎜rrreee🎜Execute 위 쿼리문의 결과에서 원래 전화번호에는 +86 접두사가 붙은 국제 지역 코드가 있음을 확인할 수 있습니다. 🎜🎜Oracle 데이터베이스의 필드를 수정하는 방법🎜🎜To 열의 크기를 줄여 열의 모든 데이터가 새 크기에 맞는지 확인합니다. 🎜🎜예를 들어 phone 열의 크기를 12자로 줄여보세요. 🎜rrreee🎜Oracle 데이터베이스에서 다음 오류가 발생합니다. 🎜rrreee🎜이 문제를 해결하려면 먼저 , 전화번호에서 국제 코드를 제거해야 합니다(예: +86). 🎜rrreee🎜REPLACE() 함수는 하위 문자열을 새 하위 문자열로 바꿉니다. 이 경우 +86는 빈 문자열로 대체됩니다. 🎜🎜그런 다음 phone 열의 크기를 줄이세요: 🎜rrreee🎜🎜4. 가상 열을 수정하세요🎜🎜🎜 다음 두 열을 누르세요. 전체 이름을 🎜rrreee🎜 형식으로 입력하세요. 이렇게 하려면 가상 열 full_name의 표현을 다음과 같이 변경할 수 있습니다. 🎜
ALTER TABLE accounts 
MODIFY full_name VARCHAR2(52) 
GENERATED ALWAYS AS (last_name || &#39;, &#39; || first_name);
로그인 후 복사
로그인 후 복사

以下语句验证修改:

SELECT
    *
FROM
    accounts;
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사

执行上面查询语句,可以看到以下结果

Oracle 데이터베이스의 필드를 수정하는 방법

5. 修改列的默认值

添加一个名为status的新列,默认值为1accounts表中。参考以下语句 -

ALTER TABLE accounts
ADD status NUMBER( 1, 0 ) DEFAULT 1 NOT NULL ;
로그인 후 복사
로그인 후 복사

当执行了该语句,就会将accounts表中的所有现有行的status列中的值设置为1

要将status列的默认值更改为0,请使用以下语句:

ALTER TABLE accounts 
MODIFY status DEFAULT 0;
로그인 후 복사
로그인 후 복사

可以在accounts表中添加一个新行来检查status列的默认值是0还是1

INSERT INTO accounts ( first_name, last_name, email, phone )
VALUES ( &#39;Julia&#39;,
         &#39;Madden&#39;,
         &#39;julia.madden@oraok.com&#39;,
         &#39;410-555-0200&#39; );
로그인 후 복사
로그인 후 복사

现在,查询accounts表中的数据:

SELECT
  *
FROM
  accounts;
로그인 후 복사
로그인 후 복사

执行上面查询语句,应该看类似下面的结果 

Oracle 데이터베이스의 필드를 수정하는 방법

正如所看到的那样,ID4的账户的status列的值是0

推荐教程:《Oracle教程

위 내용은 Oracle 데이터베이스의 필드를 수정하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

MySQL : 세계에서 가장 인기있는 데이터베이스 소개 MySQL : 세계에서 가장 인기있는 데이터베이스 소개 Apr 12, 2025 am 12:18 AM

MySQL은 오픈 소스 관계형 데이터베이스 관리 시스템으로, 주로 데이터를 신속하고 안정적으로 저장하고 검색하는 데 사용됩니다. 작업 원칙에는 클라이언트 요청, 쿼리 해상도, 쿼리 실행 및 반환 결과가 포함됩니다. 사용의 예로는 테이블 작성, 데이터 삽입 및 쿼리 및 조인 작업과 같은 고급 기능이 포함됩니다. 일반적인 오류에는 SQL 구문, 데이터 유형 및 권한이 포함되며 최적화 제안에는 인덱스 사용, 최적화 된 쿼리 및 테이블 분할이 포함됩니다.

MySQL을 사용하는 이유는 무엇입니까? 혜택과 장점 MySQL을 사용하는 이유는 무엇입니까? 혜택과 장점 Apr 12, 2025 am 12:17 AM

MySQL은 성능, 신뢰성, 사용 편의성 및 커뮤니티 지원을 위해 선택됩니다. 1.MYSQL은 효율적인 데이터 저장 및 검색 기능을 제공하여 여러 데이터 유형 및 고급 쿼리 작업을 지원합니다. 2. 고객-서버 아키텍처 및 다중 스토리지 엔진을 채택하여 트랜잭션 및 쿼리 최적화를 지원합니다. 3. 사용하기 쉽고 다양한 운영 체제 및 프로그래밍 언어를 지원합니다. 4. 강력한 지역 사회 지원을 받고 풍부한 자원과 솔루션을 제공합니다.

오라클을 열 수 없다면해야 할 일 오라클을 열 수 없다면해야 할 일 Apr 11, 2025 pm 10:06 PM

Oracle에 대한 솔루션은 개설 할 수 없습니다. 1. 데이터베이스 서비스 시작; 2. 청취자를 시작하십시오. 3. 포트 충돌을 확인하십시오. 4. 환경 변수를 올바르게 설정하십시오. 5. 방화벽이나 바이러스 백신 소프트웨어가 연결을 차단하지 않도록하십시오. 6. 서버가 닫혀 있는지 확인하십시오. 7. RMAN을 사용하여 손상된 파일을 복구하십시오. 8. TNS 서비스 이름이 올바른지 확인하십시오. 9. 네트워크 연결 확인; 10. Oracle 소프트웨어를 다시 설치하십시오.

Oracle Cursor를 닫는 문제를 해결하는 방법 Oracle Cursor를 닫는 문제를 해결하는 방법 Apr 11, 2025 pm 10:18 PM

Oracle Cursor Closure 문제를 해결하는 방법에는 다음이 포함됩니다. Close 문을 사용하여 커서를 명시 적으로 닫습니다. For Update 절에서 커서를 선언하여 범위가 종료 된 후 자동으로 닫히십시오. 연관된 PL/SQL 변수가 닫히면 자동으로 닫히도록 사용 절에서 커서를 선언하십시오. 예외 처리를 사용하여 예외 상황에서 커서가 닫혀 있는지 확인하십시오. 연결 풀을 사용하여 커서를 자동으로 닫습니다. 자동 제출을 비활성화하고 커서 닫기를 지연시킵니다.

Oracle Loop에서 커서를 만드는 방법 Oracle Loop에서 커서를 만드는 방법 Apr 12, 2025 am 06:18 AM

Oracle에서 FOR 루프 루프는 커서를 동적으로 생성 할 수 있습니다. 단계는 다음과 같습니다. 1. 커서 유형을 정의합니다. 2. 루프를 만듭니다. 3. 커서를 동적으로 만듭니다. 4. 커서를 실행하십시오. 5. 커서를 닫습니다. 예 : 커서는 상위 10 명의 직원의 이름과 급여를 표시하기 위해주기별로 만들 수 있습니다.

Oracle 데이터베이스를 중지하는 방법 Oracle 데이터베이스를 중지하는 방법 Apr 12, 2025 am 06:12 AM

Oracle 데이터베이스를 중지하려면 다음 단계를 수행하십시오. 1. 데이터베이스에 연결하십시오. 2. 즉시 종료; 3. 셧다운은 완전히 중단됩니다.

Oracle Dynamic SQL을 만드는 방법 Oracle Dynamic SQL을 만드는 방법 Apr 12, 2025 am 06:06 AM

SQL 문은 Oracle의 동적 SQL을 사용하여 런타임 입력을 기반으로 작성 및 실행할 수 있습니다. 단계에는 다음이 포함됩니다 : 동적으로 생성 된 SQL 문을 저장할 빈 문자열 변수 준비. 즉시 실행 또는 준비 명령문을 사용하여 동적 SQL 문을 컴파일하고 실행하십시오. 바인드 변수를 사용하여 사용자 입력 또는 기타 동적 값을 동적 SQL로 전달하십시오. 동적 SQL 문을 실행하려면 즉시 실행 또는 실행을 사용하십시오.

HDFS에서 CentOS를 구성하는 데 어떤 단계가 필요합니까? HDFS에서 CentOS를 구성하는 데 어떤 단계가 필요합니까? Apr 14, 2025 pm 06:42 PM

Centos 시스템에서 Hadoop 분산 파일 시스템 (HDF)을 구축하려면 여러 단계가 필요합니다. 이 기사는 간단한 구성 안내서를 제공합니다. 1. 초기 단계에서 JDK를 설치할 준비 : 모든 노드에 JavadevelopmentKit (JDK)을 설치하면 버전이 Hadoop과 호환되어야합니다. 설치 패키지는 Oracle 공식 웹 사이트에서 다운로드 할 수 있습니다. 환경 변수 구성 : /etc /프로파일 파일 편집, Java 및 Hadoop 설정 설정 시스템에서 JDK 및 Hadoop의 설치 경로를 찾을 수 있습니다. 2. 보안 구성 : SSH 비밀번호가없는 로그인 SSH 키 : 각 노드에서 ssh-keygen 명령을 사용하십시오.

See all articles