如何创建一个创建MySQL数据库中的datetime类型


Posted in MySQL onMarch 21, 2022

环境系统平台:Microsoft Windows (64-bit) 10版本:4.5

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

  • ​CREATE DOMAIN​:它创建了一个用户定义的数据类型,可以有可选的约束,基于其他基本类型,实质是定义一个域。
  • ​CREATE TYPE​:它通常用于使用存储过程创建复合类型(两种或多种数据类型混合的数据类型)。

一、domain用法及示例

假如有以下表结构:

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

其中md5列的类型及约束,可以定义一个domain来抽象,如下:

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

二、创建MySQL中datetime类型

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)

三、create type用法及示例

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数据库中的datetime类型的文章就介绍到这了,更多相关创建datetime类型内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

MySQL 相关文章推荐
MySQL入门命令之函数-单行函数-流程控制函数
Apr 05 MySQL
多表查询、事务、DCL
Apr 05 MySQL
解决MySQL存储时间出现不一致的问题
Apr 28 MySQL
mysql数据库入门第一步之创建表
May 14 MySQL
MySQL query_cache_type 参数与使用详解
Jul 01 MySQL
分享mysql的current_timestamp小坑及解决
Nov 27 MySQL
Mysql Innodb存储引擎之索引与算法
Feb 15 MySQL
面试提问mysql一张表到底能存多少数据
Mar 13 MySQL
MySQL分区以及建索引的方法总结
Apr 13 MySQL
mysql中如何用命令创建联合唯一索引
Apr 20 MySQL
Mysql中常用的join连接方式
May 11 MySQL
MySQL count(*)统计总数问题汇总
Sep 23 MySQL
mysql 获取时间方式
Mar 20 #MySQL
mysql 生成连续日期及变量赋值
Mar 20 #MySQL
MySQL派生表联表查询实战过程
MySQL学习之基础命令实操总结
Mar 19 #MySQL
MySQL学习之基础操作总结
Mar 19 #MySQL
Pycharm远程调试和MySQL数据库授权问题
Mar 18 #MySQL
MySQL 主从复制数据不一致的解决方法
You might like
用PHP和ACCESS写聊天室(三)
2006/10/09 PHP
使用PHP 5.0创建图形的巧妙方法
2010/10/12 PHP
php设计模式 Visitor 访问者模式
2011/06/28 PHP
php中将html中的br换行符转换为文本输入中的换行符
2013/03/26 PHP
PHP字符串的递增和递减示例介绍
2014/02/11 PHP
一些相见恨晚的 JavaScript 技巧
2010/04/25 Javascript
js判断两个日期是否相等的方法
2013/09/10 Javascript
JavaScript代码复用模式详解
2014/11/07 Javascript
JavaScript实现图片轮播的方法
2015/07/31 Javascript
理解Javascript文件动态加载
2016/01/29 Javascript
jQuery+HTML5+CSS3制作支持响应式布局时间轴插件
2016/08/10 Javascript
微信小程序技巧之show内容展示,上传文件编码问题
2017/01/23 Javascript
js实现截图保存图片功能的代码示例
2017/02/16 Javascript
Vue2.0父子组件传递函数的教程详解
2017/10/16 Javascript
Angular整合zTree的示例代码
2018/01/24 Javascript
vue + vuex todolist的实现示例代码
2018/03/09 Javascript
Angular value与ngValue区别详解
2019/11/27 Javascript
Python编写检测数据库SA用户的方法
2014/07/11 Python
python中map()函数的使用方法示例
2017/09/29 Python
python中如何使用正则表达式的非贪婪模式示例
2017/10/09 Python
Python实现的朴素贝叶斯算法经典示例【测试可用】
2018/06/13 Python
python使用Plotly绘图工具绘制水平条形图
2020/03/25 Python
Django 实现admin后台显示图片缩略图的例子
2019/07/28 Python
python正则-re的用法详解
2019/07/28 Python
Python 操作mysql数据库查询之fetchone(), fetchmany(), fetchall()用法示例
2019/10/17 Python
一款纯css3实现的颜色渐变按钮的代码教程
2014/11/12 HTML / CSS
HTML5 自动聚焦(autofocus)属性使用介绍
2013/08/07 HTML / CSS
腾讯公司的一个sql题
2013/01/22 面试题
公共事业管理本科生求职信
2013/10/07 职场文书
函授本科毕业生自我鉴定
2013/10/16 职场文书
关于赌博的检讨书
2014/01/08 职场文书
安全生产月演讲稿
2014/05/09 职场文书
2015年学校图书室工作总结
2015/05/19 职场文书
女儿满月酒致辞
2015/07/29 职场文书
MySQL非空约束(not null)案例讲解
2021/08/23 MySQL
Python采集壁纸并实现炫轮播
2022/04/30 Python