枚举类型是Java中常用的一种数据类型,用于定义一些常量值。在实际开发中,我们经常需要将枚举类型的值存储到数据库中,以便进行查询和统计。本文将介绍在JavaWeb中如何将枚举类存储到数据库中。
一、枚举类的定义
在Java中定义枚举类可以采用如下形式:
public enum Season {
SPRING, SUMMER, AUTUMN, WINTER
}
这里定义了一个季节的枚举类Season,其中包含了四个枚举值:SPRING,SUMMER,AUTUMN,WINTER。
二、将枚举类存储到数据库中
在将枚举类存储到数据库中时,需要注意两点:
1、将枚举值存储到数据库中
在将枚举值存储到数据库中时,我们可以将枚举值作为字符串存储,也可以将枚举值作为整数存储。
在将枚举值作为字符串存储时,我们需要在数据库中定义一个CHAR或VARCHAR类型的字段来存储数据。比如:
CREATE TABLE students(
id INT PRIMARY KEY,
name VARCHAR(20),
gender CHAR(6),
grade INT
);
在这个表中,我们定义了一个gender字段,用于存储学生的性别。由于枚举类型的每个值都是一个字符串,所以我们可以在枚举类中定义一个方法,将枚举值转换成字符串。比如:
public enum Gender {
MALE(“男”),
FEMALE(“女”);
private String value;
Gender(String value) {
this.value = value;
}
public String value() {
return value;
}
}
在这个枚举类中,我们定义了两个枚举值:MALE和FEMALE,用于表示男性和女性。同时,我们还定义了一个value属性,用于存储枚举值对应的字符串。在它的构造器中,我们将字符串赋值给value属性。在添加学生信息时,我们可以将枚举值转换成字符串,再存储到数据库中。比如:
String gender = Gender.MALE.value();
在将枚举值作为整数存储时,我们需要在数据库中定义一个INT类型的字段来存储数据。比如:
CREATE TABLE students(
id INT PRIMARY KEY,
name VARCHAR(20),
gender INT,
grade INT
);
在这个表中,我们定义了一个gender字段,用于存储学生的性别。由于枚举类型的每个值都是一个整数,所以我们可以在枚举类中定义一个方法,将枚举值转换成整数。比如:
public enum Gender {
MALE(1),
FEMALE(2);
private int value;
Gender(int value) {
this.value = value;
}
public int value() {
return value;
}
}
在这个枚举类中,我们定义了两个枚举值:MALE和FEMALE,用于表示男性和女性。同时,我们还定义了一个value属性,用于存储枚举值对应的整数。在它的构造器中,我们将整数赋值给value属性。在添加学生信息时,我们可以将枚举值转换成整数,再存储到数据库中。比如:
int gender = Gender.MALE.value();
2、将枚举类型存储到数据库中
在将枚举类型存储到数据库中时,我们需要将枚举类型转换成一个能够存储到数据库中的数据类型。通常情况下,我们可以将枚举类型转换成整数或字符串类型。比如:
public enum Season {
SPRING(1, “春”),
SUMMER(2, “夏”),
AUTUMN(3, “秋”),
WINTER(4, “冬”);
private int value;
private String name;
Season(int value, String name) {
this.value = value;
this.name = name;
}
public int value() {
return value;
}
public String name() {
return name;
}
// 根据value获取枚举值
public static Season valueOf(int value) {
for (Season season : values()) {
if (season.value == value) {
return season;
}
}
return null;
}
// 根据name获取枚举值
public static Season valueOf(String name) {
for (Season season : values()) {
if (season.name.equals(name)) {
return season;
}
}
return null;
}
}
在这个枚举类中,我们定义了四个枚举值:SPRING,SUMMER,AUTUMN,WINTER,用于表示四个季节。同时,我们还定义了一个value属性,用于存储枚举值对应的整数,以及一个name属性,用于存储枚举值名称的字符串。在构造器中,我们将整数和字符串分别赋值给value和name属性。在添加学生信息时,我们可以将枚举类型转换成整数或字符串,再存储到数据库中。比如:
// 将枚举类型转换成整数
int season = Season.SPRING.value();
// 将枚举类型转换成字符串
String season = Season.SPRING.name();
三、
将枚举类型存储到数据库中并不困难,只需要将枚举类型转换成一个能够存储到数据库中的数据类型,并按照相应的格式存储到数据库中即可。在实际开发中,我们需要根据实际情况选择合适的转换方式,以便更好地操作数据库。
成都网站建设公司-创新互联,建站经验丰富以策略为先导10多年以来专注数字化网站建设,提供企业网站建设,高端网站设计,响应式网站制作,设计师量身打造品牌风格,热线:028-86922220一个enum是定义一组值的对象,历粗嫌它可以包括零个或多个值成员。只须定义一个enum型的对象.enum对象的值都会自动获得一个数字值,从0开始,依次递增。如:
EnumDemo.java
package net.javagarage.enums;
public class EnumDemo{
private enum Seasons{
winter,spring,summer,fall
}
public static void main(String[]args){
for(Seasons s:Seasons.values()){
System.out.println(s);
}
}
}
尽管enums有这么多的属性,但并不是用的越多越肢手好,如果那样还不如直接用类来的直接.enums的优势在定义int最终变量仅当这些值有一定特殊含义时.但是如果需要的是一个类,就定义一个类,而不是enum。
扩展资料:
枚举值是常量,不是变量。不能在程序中用赋值语句再对它赋值。枚举元素本身由系统定义了一个表示序号的数值,从0开始顺序定义凳态为0,1,2…。如在weekday中,sun值为0,mon值为1,sat值为6。
只能把枚举值赋予枚举变量,不能把元素的数值直接赋予枚举变量。如一定要把数值赋予枚举变量,则必须用强制类型转换。
11.10 枚举类型
在实际问题中,有些变量的取值被限定在一个有限的范围内。例如,一个星期内只有七天,一年只有十二个月,一个班每周有六门课程等等。如果把这些量说明为整型,字符如局或型或其它类型显然是不妥当的。为此,C语言提供了一种称为“枚举”的类型。在“枚举”类型的定义中列举出所有可能的取值,被说明为该“枚举”类型的变量取值不能超过定义的范围。应该说明的是,枚举类型是一种基本数据类型,而不是一种构造类型,因为它不能再分解为任何基本类型。
11.10.1 枚举类型的定义和枚举变量的说明
1. 枚举的定义枚举类型定义的一般形式为:
enum 枚举名{ 枚举值表 };
在枚举值表中应罗列出所有可用值。这些值也称为枚举元素。
例如:
该枚举名为weekday,枚举值共有7个,即一周中的七天。凡被说明为weekday类型变量的取值只能是七天中的某一天。
2. 枚举变量的说明
如同结构和联合一样,枚举变量也可用不同的方式说明,即先定义后说明,同时定义说明或直接说明。
设有变量a,b,c被说明为上述的weekday,可采用下述任一种方式:
enum weekday{ sun,mou,tue,wed,thu,fri,sat };
enum weekday a,b,c;
或者为:
enum weekday{ sun,mou,tue,wed,thu,fri,sat }a,b,c;
或者为:
enum { sun,mou,tue,wed,thu,fri,sat }a,b,c;
11.10.2 枚举类型变量的赋值和使用
枚举类型在使用中渣伍有以下规定:
1. 枚举值是常量,不是变量。不能在程序中用赋值语句再对它赋值。
例如对枚举weekday的元素再作以下赋值:
sun=5;
mon=2;
sun=mon;
都是错误的。
2. 枚举元素本身由系统定义了一个表示序号的数值,从0开始顺序定义为0,1,2…。如在weekday中,sun值为0,mon值为1,…,sat值为6。
【例11.10】腊歼
main(){
enum weekday
{ sun,mon,tue,wed,thu,fri,sat } a,b,c;
a=sun;
b=mon;
c=tue;
printf(“%d,%d,%d”,a,b,c);
}
说明:
只能把枚举值赋予枚举变量,不能把元素的数值直接赋予枚举变量。如:
a=sum;
b=mon;
是正确的。而:
a=0;
b=1;
是错误的。如一定要把数值赋予枚举变量,则必须用强制类型转换。
如:
a=(enum weekday)2;
其意义是将顺序号为2的枚举元素赋予枚举变量a,相当于:
a=tue;
还应该说明的是枚举元素不是字符常量也不是字符串常量,使用时不要加单、双引号。
【例11.11】
main(){
enum body
{ a,b,c,d } month,j;
int i;
j=a;
for(i=1;id) j=a;
}
for(i=1;i
switch(month)
{
case a:printf(” %2d %c\t”,i,’a’); break;
case b:printf(” %2d %c\t”,i,’b’); break;
case c:printf(” %2d %c\t”,i,’c’); break;
case d:printf(” %2d %c\t”,i,’d’); break;
default:break;
}
}
printf(“\n”);
这个要看你的
枚举
, 是 仅仅一次只能选择一个的? 还是一次可以选择多个的.
例如你的
order_id order_status
SUCS(成功success)
PCES(处理process)
某行拆姿数据, 要么就是 SUCS(成功success) , 要么就是 PCES(处理process)
这种情况下, 用字毕昌符是比较合适的。
但是如果枚举是可以选择多个的, 例如:
id desc
1 无党派
2 知识分子
4 少数民族
8 女性
16 ……
这种情况下, 如果一个人, 多个枚举都满足的情况下, 那么这种情况下, 使用 数字 是比较适合的。
也就是
如果某个人,是 无党派汉族女性研究生, 那么枚旅数绝举值 = 1+2+8
.做个字典表 试试。这样就不怕 忘了。
一般在主表上存储的是枚举值,另建立一个值对应说明表,查询时关联取出说明内容
javaweb enum存数据库的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于javaweb enum存数据库,JavaWeb中如何将枚举类存储到数据库中?,enum怎么用?,在数据库中存枚举值,用数字还是字符好?的信息别忘了在本站进行查找喔。
成都网站建设选创新互联(☎:028-86922220),专业从事成都网站制作设计,高端小程序APP定制开发,成都网络营销推广等一站式服务。
分享题目:JavaWeb中如何将枚举类存储到数据库中?(javawebenum存数据库)
地址分享:http://www.csdahua.cn/qtweb/news21/375171.html
网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网