zoukankan      html  css  js  c++  java
  • mysql中的数据类型enum和set

    mysql中的字符串数据类型set,enum

    1、enum

      单选字符串数据类型,适合存储表单界面中的“单选值”。

      设定enum的时候,需要给定“固定的几个选项”;存储的时候就只存储其中的一个值。

      设定enum的格式:

        enum("选项1","选项2","选项3",...);

      实际上,enum的选项都会对应一个数字,依次是1,2,3,4,5...,最多有65535个选项

      使用的时候,可以使用选项的字符串格式,也可以使用对应的数字。

    2、set

      多选字符串数据类型,适合存储表单界面的“多选值”。

      设定set的时候,同样需要给定“固定的几个选项”;存储的时候,可以存储其中的若干个值。

      设定set的格式:

        set("选项1","选项2","选项3",...)

      同样的,set的每个选项值也对应一个数字,依次是1,2,4,8,16...,最多有64个选项

      使用的时候,可以使用set选项的字符串本身(多个选项用逗号分隔),也可以使用多个选项的数字之和(比如:1+2+4=7)

    代码如下:

    /* 创建表格 */
    mysql> create table enum_set_table( -> id int auto_increment primary key, -> gender enum('M','F'), -> hobby set('music','movie','swimming','footbal') -> ); Query OK, 0 rows affected (0.01 sec)
    /* 一个enum值,一个set值,二者均使用选项的字符串格式 */ mysql
    > insert into enum_set_table(id,gender,hobby) values(null,'M','music'); Query OK, 1 row affected (0.01 sec)
    /* 一个enum值,多个set值,二者均使用选项的字符串格式 */ mysql
    > insert into enum_set_table(id,gender,hobby) values(null,'F','music,movie,footbal'); Query OK, 1 row affected (0.00 sec)
    /* 一个enum值,一个set值,二者均使用选项的数字格式 */
    mysql> insert into enum_set_table(id,gender,hobby) values(null,1,1); Query OK, 1 row affected (0.00 sec)
    /* 一个enum值,多个set值,二者均使用选项的数字格式,其中enum的值 2<=>'F',15=1+2+4+8 <=> 'music,movie,swimming,footbal' */ mysql
    > insert into enum_set_table(id,gender,hobby) values(null,2,15); Query OK, 1 row affected (0.00 sec)
    /* 一个enum值,多个set值,enum值使用选项的字符串格式,set值使用选项的数字格式,7=1+2+4 <=> 'music,movie,swimming' */ mysql
    > insert into enum_set_table(id,gender,hobby) values(null,'F',7); Query OK, 1 row affected (0.01 sec)
    /* 查询结果 */ mysql
    > select * from enum_set_table; +----+--------+------------------------------+ | id | gender | hobby | +----+--------+------------------------------+ | 1 | M | music | | 2 | F | music,movie,footbal | | 3 | M | music | | 4 | F | music,movie,swimming,footbal | | 5 | F | music,movie,swimming | +----+--------+------------------------------+ 5 rows in set (0.00 sec)
  • 相关阅读:
    EasyNVR视频平台无法输出RTSP流地址排查步骤
    EasyNVR平台实现播流地址超时无法播放功能过程分享
    EasyNVR视频平台集成出现播放一段时间后自动断开的情况排查及优化
    EasyNVR-ARM版云终端频繁死机重启原因分析
    EasyNVR用户登录修改为IP+用户名限制的修改过程分享
    EasyNVR视频平台设备通道页面显示错误的调整方法
    【解决方案】视频智能监控系统为酒店智能化建设提供一体化融合解决方案
    1051 Pop Sequence (25 分)
    1089 Insert or Merge (25 分)
    1085 Perfect Sequence (25 分)
  • 原文地址:https://www.cnblogs.com/benbenzhu/p/5604598.html
Copyright © 2011-2022 走看看