❶ 在java项目开发中model包里的每个类都要有对应的数据库表吗
这个。。怎么说呢?只是一个模式,不会对程序造成怎样的影响。至于你说的模型层中对应的类,只是你从数据库查出来的结果将它封装成一个类,而结果可能是很多表共同生成的
❷ Java Web中的mapper,service,controller,model究竟分别是什么作用
java web中mapper是对象持久化映射层,一般会继承ibatis或者mybatis servive是一些业务逻辑的处理层,controller是控制层,相当于mvc的c层,model是数据模型层相当于mvc的m层。
❸ java里面,model里面的成员变量类型一定要和数据库的字段类型对应拿
你定义成double也没问题啊,但如果数据库中是double,model里面是float就有问题,不过这倒没什么规定,关键是你要清楚,double变成float是要损失精度的。
原则上保证数据不会有损失就好。
❹ 请问java项目 里的DAO,model,service, IMPL 是什么意思,以及有什么关系
是SSH架构的工程吗?代表了三层吧,model是实例,service提供各种方法,实现各种方法,impl指implement,即实现,service和都需要impl,内部的方法一般是实现与数据库交互的,而model一般就是数据库中表的实例
❺ java开发时为什么要和service都是model层吗
和service不是model层。学习java开发推荐千锋教育。千锋教育培训业务分为大学生技能培训和职后技能培训,为学生的学习保驾护航。
是数据访问层。DAO(Data Access Object) 数据访问对象是第一个面向对象的接口。service是业务层,负责所有的业务逻辑处理。model属于数据实体模型。和数据库的数据字段是基本对应的,model也可以增加一些数据库没有的虚拟字段,帮助处理业务。这样分层的好处是降低程序耦合度。
想要了解更多有关java开发的相关信息,推荐咨询千锋教育。千锋教育成立教研学科中心,推出贴近企业需求的线下技能培训课程。采用全程面授高品质、高体验培养模式,学科大纲紧跟企业需求,拥有国内一体化教学管理及学员服务,在职业教育发展道路上不断探索前行。
❻ java里面,model里面的成员变量类型一定要和数据库的字段类型对应拿
不对应,就不能做映射,取的时候,不能从DB里面取。。。。。。。
❼ java操作数据库
createStatement 这个不是报错,只是这句可能会抛出异常,这种情况在java中是必须使用 try catch 捕捉的。 你只要把代码块用 try catch 包起来就可以了。
❽ Java里用tableModel接收从数据库查询出来的数据该怎么做求详解,最好可以教我一下怎么实现
利用Java开发数据库应用系统时,经常需要在用户界面上显示查询结果。由于SUN公司提供的JDK1.x开发工具包不是可视化的集成开发环境(IDE),不能象Delphi、VB那样方便地把查询结果在DBGrid等表格中显示出来。因此,只能靠自己编写代码来实现。
在实际应用中,我们可以利用Vector、JTable、AbstractTableModel等三个类较好地解决这一问题。以下,详细介绍一下实现方法。
· 一、 类Vector、类JTable及类AbstractTableModel简介:
1、 类Vector:
类Vector是Java的历史集合类,隶属于java.util包。它包装了异构链表和数组杂合体,具有以下两个特点:
* 向量是异构的,不要求每个元素的类型相同,向量中可以混合多种对象类型;
* 向量是数组杂合体,因为它们可以在增加元素时动态增大。
其异构性正好符合数据库记录中属性类型不一的特点,而其动态性也正好符合数据库查询时,结果集记录个数不定的特点。
类Vector定义如下:
public class Vector extends AbstractList
implements List , Cloneable , Serializable{…}
实现了向量成员的查找、新增、删除等方法。如:add(Object obj)可方便地加入一个对象;get(int index)可方便地得到向量中的一个对象;remove(Object obj)。则可方便地删除向量中一个对象。
· 2、 类JTable:
JTable组件是Swing组件中比较复杂的小件,隶属于javax.swing包,它能以二维表的形式显示数据。类JTable定义如下:
public class JTable extends JComponent
implements TableModelListener, Scrollable, TableColumnModelListener,
ListSelectionListener, CellEditorListener, Accessible{…}
类JTable在显示数据时具有以下特点:
* 可定制性:可以定制数据的显示方式和编辑状态;
* 异构性:可以显示不同类型的数据对象,甚至包括颜色、图标等复杂对象;
* 简便性:可以以缺省方式轻松地建立起一个二维表。
其可定制性可满足不同用户和场合的要求,异构性也正好符合数据库访问结果集中属性类型不一的特点。类JTable提供了极为丰富的二维表格操作方法,如设置编
辑状态、显示方式、选择行列等,在此不一一赘述。
使用类JTable显示数据之前,必须根据情况生成定制模型、单元绘制器或单元编辑器。类AbstractListModel用来定制用户自己的数据模型,这个类在后面要介绍。
TableCellRenderer接口用来定制单元绘制器,TableCellEditor接口用来定制单元编辑器,这两个接口主要用于颜色对象的处理上,在示例中没有用到,不做过多说明。
· 3、 类AbstractTableModel:
类AbstractTableModel是一个抽象类,没有完全实现,不能实例化,使用时必须在程序中实现方法。它隶属于javax.swing.table 。类定义如下:
public abstract class AbstractTableModel extends Object
implements TableModel, Serializable{…}
类AbstractTableModel提供了TableModel接口中绝大多数方法的缺省实现。TableModel接口定义了JTable 的基础数据结构。用户要生成自己的数据模型,本来可以
通过实现TableModel接口中所有方法来满足要求,但管理听众表的功能对于所有数据模型是共同的,所以在javax.swing.table中又定义了类AbstractTableModel来
处理这个工作。它既管理听众表,又为生成TableModelEvents事件并委托给听众提供了便利。
要想生成一个具体的TableModel作为AbstractTableMode的子类,至少必须实现下面三个方法:
public int getRowCount();
public int getColumnCount();
public Object getValueAt(int row, int column);
至此,我们可以建立一个简单二维表(5×5),实现方法如下:
TableModel dataModel = new AbstractTableModel() {
public int getColumnCount() { return 5; }
public int getRowCount() { return 5;}
public Object getValueAt(int row, int col) { return new Integer(row*col); }
};
JTable table = new JTable(dataModel);
JScrollPane scrollpane = new JScrollPane(table);
· 二、 数据库及其连接方法简介:
示例采用Sybase数据库系统,数据库存放在数据库服务器中。路径为:D:/WORKER,数据库名为:worker.dbf。具有以下字段:
字段名
类型
Wno(职工号)
VARCHAR
Wname(职工名)
VARCHAR
Sex(性别)
VARCHAR
Birthday(出生日期)
DATE
Wage(工资)
FLOAT
要连接此数据库,需使用java.sql包中的类DriverManager。此类是用于管理JDBC驱动程序的实用程序类。它提供了通过驱动程序取得连接、注册,撤消驱动程序, 设置登记和数据库访问登录超时等方法。具体连接方法如下:
第一步:定位、装入和链接SybDriver类;
driver="com.sybase.jdbc.SybDriver";
SybDriver sybdriver=(SybDriver)Class.forName(driver).newInstance();
第二步:注册SybDriver类;
DriverManager.registerDriver(sybdriver);
第三步:取得连接(SybConnection)对象引用。
user="sa";
password="";
url="jdbc:sybase:Tds:202.117.203.114:5000/WORKER";
SybConnection connection=(SybConnection)DriverManager.getConnection
(url,user,password);
建立完连接后,即可通过Statement接口进行数据库的查询与更改。
· 三、 实现方法:
限于篇幅,在此只给出核心代码,包引入、界面处理、变量定义等部分不再介绍。
第一步:对象声明。
AbstractTableModel tm;//声明一个类AbstractTableModel对象
JTable jg_table;//声明一个类JTable对象
Vector vect;//声明一个向量对象
JScrollPane jsp;//声明一个滚动杠对象
String title[]={"职工号","职工名","性别","出生日期","工资"};
//二维表列名
第二步:定制表格。
1、实现抽象类AbstractTableModel对象tm中的方法:
vect=new Vector();//实例化向量
tm=new AbstractTableModel(){
public int getColumnCount(){
return title.length;}//取得表格列数
public int getRowCount(){
return vect.size();}//取得表格行数
public Object getValueAt(int row,int column){
if(!vect.isEmpty())
return
((Vector)vect.elementAt(row)).elementAt(column);
else
return null;}//取得单元格中的属性值
public String getColumnName(int column){
return title[column];}//设置表格列名
public void setValueAt(Object value,int row,int column){}
//数据模型不可编辑,该方法设置为空
public Class getColumnClass(int c){
return getValueAt(0,c).getClass();
}//取得列所属对象类
public boolean isCellEditable(int row,int column){
return false;}//设置单元格不可编辑,为缺省实现
};
2、定制表格:
jg_table=new JTable(tm);//生成自己的数据模型
jg_table.setToolTipText("显示全部查询结果");//设置帮助提示
jg_table.setAutoResizeMode(JTable.AUTO_RESIZE_OFF);
//设置表格调整尺寸模式
jg_table.setCellSelectionEnabled(false);//设置单元格选择方式
jg_table.setShowVerticalLines(true);//设置是否显示单元格间的分割线
jg_table.setShowHorizontalLines(true);
jsp=new JScrollPane(jg_table);//给表格加上滚动杠
第三步:显示查询结果。
1、 连接数据库:第二部分已给出。
2、 数据库查询:
Statement stmt=connection.createStatement();
ResultSet rs=stmt.executeQuery("select * from worker");
3、 显示查询结果:
vect.removeAllElements();//初始化向量对象
tm.fireTableStructureChanged();//更新表格内容
while(rs.next()){
Vector rec_vector=new Vector();
//从结果集中取数据放入向量rec_vector中
rec_vector.addElement(rs.getString(1));
rec_vector.addElement(rs.getString(2));
rec_vector.addElement(rs.getString(3));
rec_vector.addElement(rs.getDate(4));
rec_vector.addElement(new Float(rs.getFloat(5)));
vect.addElement(rec_vector);//向量rec_vector加入向量vect中
}
tm.fireTableStructureChanged();//更新表格,显示向量vect的内容。
❾ 请问java项目 里的DAO,model,service, IMPL 是什么意思,以及有什么关系
在一般工程中 基本上都会出现上述的字眼
首先 DAO 提供了应用程序与数据库之间的操作规范 和操作 用于通常数据库的增删查改 一般如果使用框架 都是由框架自动生成,提高访问效率和便于快速开发。hibernate的DAO中 提供了关于事物 数据读取 修改 删除 添加 这些逻辑 还依赖于下面提到的Model
Model 为了便于理解业务和代码可读 美观 通常将数据库表 作为对象封装,对象封装中提供属性 一般操作DAO类的时候 传入的是Model 通过 hibernate的映射文件 映射到数据库字段也就是通常说的 通过实体类操作数据库
IMPL 以IMPL 结尾的类 一般是实现了某个或多个接口的类 这些类的接口 是定义了一些规范的类通常是数据访问等等 在service 中 会通过spring的注入 注入这些接口来实现逻辑
service 一般在service的实现类 会出现在action中。这些service 提供了包含逻辑的数据访问
举个例子 在 项目中需要将查询出来的所有数据的某个值加1 那么 在service 中 就会做一次循环 从查询出来的Model 集合中 将值取出来 +1
它们的协作关系如下
web页面--->Action---->service---->interface---->IMPL---->DAO---->DATABASE
❿ 哪位大蛱能给我讲讲java中severlet、modol、server、、数据库处理,这几层之间的联系啊
你好,一般的web应用结构分为三层,采用经典的MVC设计模式,在程序的目录架构上有如下分层:数据库<->model->->service。分析:
1、数据库和model中的实体类是相互对应的,一个实体类,就对应这数据库中的一张表。
2、是一个service和model联系的桥梁,封装了操作数据的具体实现,你可以在中使用jdbc,也可以使用hibernate。但是这些对service层都是透明的。
3、service层通过调用层,直接取得需要的数据或者要执行的操作,并且加入相应的业务逻辑,如检查、判断。
4、当一个应用为web应用时,就可以在servlet中调用service层的方法,来完成不同的功能。常见的增删查改。
5、servlet处理完成后,就结果转发给视图层进行显示。
有上面可以看出:1、2就是M层,3、4就是C层,jsp、html就是V层。
对于你的工厂模式,这个有分好几种,工厂模式作为最简单的一种设计模式,学习起来应该不难,你网络上搜搜,很多介绍了,这里就不献丑了。