>  기사  >  데이터 베이스  >  MySQL 데이터베이스에서 날짜/시간 유형을 생성하는 방법

MySQL 데이터베이스에서 날짜/시간 유형을 생성하는 방법

WBOY
WBOY앞으로
2023-06-02 16:55:041811검색

환경 시스템 플랫폼: Microsoft Windows(64비트) 10 버전: 4.5Microsoft Windows (64-bit) 10版本:4.5

瀚高数据库中支持使用以下语句创建用户定义的数据类型:

  • CREATE DOMAIN:它创建了一个用户定义的数据类型,可以有可选的约束,基于其他基本类型,实质是定义一个域。

  • CREATE TYPE

  • Hangao 데이터베이스는 다음 명령문을 사용하여 사용자 정의 데이터 유형 생성을 지원합니다.

CREATE DOMAIN: 기본적으로 도메인을 정의하는 다른 기본 유형을 기반으로 선택적 제약 조건을 가질 수 있는 사용자 정의 데이터 유형을 생성합니다.

  • CREATE TYPE: 일반적으로 저장 프로시저를 사용하여 복합 유형(둘 이상의 데이터 유형이 혼합된 데이터 유형)을 생성하는 데 사용됩니다.

    1. 도메인 사용법 및 예시

    다음과 같은 테이블 구조가 있는 경우:

    create table test_domain (id varchar,md5 text not null check(length(md5)=32));

    그 중 md5 컬럼의 유형과 제약 조건은 다음과 같이 도메인을 정의하여 추상화할 수 있습니다.

    highgo=# create domain md5 as
    
    highgo-# text not null
    
    highgo-# check (
    
    highgo(#     length(value) = 32
    
    highgo(# );
    
    CREATE DOMAIN
    
    highgo=# 
    
    highgo=# \dD md5
    
                                      List of domains
    
     Schema | Name | Type | Collation | Nullable | Default |           Check            
    
    --------+------+------+-----------+----------+---------+----------------------------
    
     public | md5  | text |           | not null |         | CHECK (length(VALUE) = 32)
    
    (1 row)
    
    highgo=# create table test_domain (id varchar,md5 md5);
    
    CREATE TABLE
    
    highgo=# insert into test_domain values('1','2');
    
    ERROR:  value for domain md5 violates check constraint "md5_check"
    
    highgo=# insert into test_domain values('2','76a2173be6393254e72ffa4d6df1030a');
    
    INSERT 0 1
    🎜 2. MySQL 날짜/시간 유형을 생성합니다🎜
    highgo=# create domain datetime as timestamp without time zone;
    
    highgo=# create table t_time (id int,create_time datetime);
    
    CREATE TABLE
    
    highgo=# \d+ t_time
    
                                         Table "public.t_time"
    
       Column    |   Type   | Collation | Nullable | Default | Storage | Stats target | Description 
    
    -------------+----------+-----------+----------+---------+---------+--------------+-------------
    
     id          | integer  |           |          |         | plain   |              | 
    
     create_time | datetime |           |          |         | plain   |              | 
    
    Access method: heap
    
    highgo=# insert into t_time values (1,now()),(2,now());
    
    INSERT 0 2
    
    highgo=# 
    
    highgo=# select * from t_time;
    
     id |        create_time         
    
    ----+----------------------------
    
      1 | 2021-08-03 19:28:11.207324
    
      2 | 2021-08-03 19:28:11.207324
    
    (2 rows)
    🎜3. 유형 사용 및 예시 생성🎜
    CREATE TYPE name AS
    
        ( [ attribute_name data_type [ COLLATE collation ] [, ... ] ] )
    
    CREATE TYPE name AS ENUM
    
        ( [ 'label' [, ... ] ] )
    
    CREATE TYPE name AS RANGE (
    
        SUBTYPE = subtype
    
        [ , SUBTYPE_OPCLASS = subtype_operator_class ]
    
        [ , COLLATION = collation ]
    
        [ , CANONICAL = canonical_function ]
    
        [ , SUBTYPE_DIFF = subtype_diff_function ]
    
    )
    
    CREATE TYPE name (
    
        INPUT = input_function,
    
        OUTPUT = output_function
    
        [ , RECEIVE = receive_function ]
    
        [ , SEND = send_function ]
    
        [ , TYPMOD_IN = type_modifier_input_function ]
    
        [ , TYPMOD_OUT = type_modifier_output_function ]
    
        [ , ANALYZE = analyze_function ]
    
        [ , INTERNALLENGTH = { internallength | VARIABLE } ]
    
        [ , PASSEDBYVALUE ]
    
        [ , ALIGNMENT = alignment ]
    
        [ , STORAGE = storage ]
    
        [ , LIKE = like_type ]
    
        [ , CATEGORY = category ]
    
        [ , PREFERRED = preferred ]
    
        [ , DEFAULT = default ]
    
        [ , ELEMENT = element ]
    
        [ , DELIMITER = delimiter ]
    
        [ , COLLATABLE = collatable ]
    
    )
    
    CREATE TYPE name
    🎜🎜생성 예시:🎜🎜
    CREATE TYPE compfoo AS (f1 int, f2 text);
    
    CREATE FUNCTION getfoo() RETURNS SETOF compfoo AS $$
    
        SELECT fooid, fooname FROM foo
    
    $$ LANGUAGE SQL;
    
    CREATE TYPE bug_status AS ENUM ('new', 'open', 'closed');
    
    CREATE TABLE bug (
    
        id serial,
    
        description text,
    
        status bug_status
    
    );
    
    CREATE TYPE float8_range AS RANGE (subtype = float8, subtype_diff = float8mi);

    위 내용은 MySQL 데이터베이스에서 날짜/시간 유형을 생성하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

  • 성명:
    이 기사는 yisu.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제