关于数据库保存流java流对象

关于数据库保存流java流对象,第1张

什么》? 哎呀没必要。。

不过可实现的:如下为一个通用的例子:

假设有这么个对象

import javaioSerializable;

public class MyObject implements Serializable {

private static final long serialVersionUID = 1L;

private int i;

public int getI() {

return i;

}

public void setI(int i) {

thisi = i;

}

}

//测试 的方法如下

import javaioByteArrayInputStream;

import javaioByteArrayOutputStream;

import javaioIOException;

import javaioObjectInputStream;

import javaioObjectOutputStream;

import javasqlConnection;

import javasqlDriverManager;

import javasqlPreparedStatement;

import javasqlResultSet;

public class test {

public static void main(String[] args) throws IOException,

ClassNotFoundException {

MyObject obj = new MyObject();

objsetI(4567);

write(Object2Bytes(obj));

// read();

}

public static void write(byte[] b) throws ClassNotFoundException {

Systemoutprintln(blength);

ClassforName("sunjdbcodbcJdbcOdbcDriver");

try {

Connection con = DriverManagergetConnection("jdbc:odbc:temp");

String sql = "insert into tab values()";

PreparedStatement pstmt = conprepareStatement(sql);

pstmtsetBytes(1, b);

pstmtexecute();

pstmtclose();

conclose();

} catch (Exception e) {

eprintStackTrace();

}

}

public static void read() throws ClassNotFoundException {

ClassforName("sunjdbcodbcJdbcOdbcDriver");

try {

Connection con = DriverManagergetConnection("jdbc:odbc:temp");

String sql = "select from tab";

PreparedStatement pstmt = conprepareStatement(sql);

ResultSet res = pstmtexecuteQuery();

while (res != null && resnext()) {

byte[] b = resgetBytes("key");

Systemoutprintln(blength);

MyObject obj = (MyObject) Bytes2Object(b);

Systemoutprintln(objgetI());

}

pstmtclose();

conclose();

} catch (Exception e) {

eprintStackTrace();

}

}

// 将对象转换成字节数组

public static byte[] Object2Bytes(Object obj) throws IOException {

ByteArrayOutputStream baos = new ByteArrayOutputStream();

ObjectOutputStream oos = new ObjectOutputStream(baos);

ooswriteObject(obj);

return baostoByteArray();

}

// 将字节数组转换成为对象

public static Object Bytes2Object(byte[] b) throws IOException,

ClassNotFoundException {

ByteArrayInputStream bais = new ByteArrayInputStream(b);

ObjectInputStream ois = new ObjectInputStream(bais);

Object obj = oisreadObject();

return obj;

}

}

你把byte[]类型转成String就可以了吧,一种是String s=new String(byte[]);一种是写个循环,把byte[]里面的内容拼成String,比如0x01,0x02再存进去,区别就是你从数据库取得时候不一样,需要做转换

import javasql;

public final class DBUtils

{

//1数据库在哪里,叫什么名字(连接串)

private static final String url="数据库连接串/数据库名";

//2用哪个驱动连接数据库(驱动串)

private static final String driver="数据库驱动串";

//通过静态块加载驱动

static

{

try

{

//1加载驱动串

ClassforName(driver); //反射加载,new Driver();

}

catch (ClassNotFoundException e)

{

eprintStackTrace();

}

}

public static Connection getConnection()throws Exception

{

return DriverManagergetConnection(url, "实例名", "密码");

}

public static void close(ResultSet rs)

{

try

{

//语句对象销毁

rsclose();

}

catch(Exception ex)

{

exprintStackTrace();

}

}

public static void close(PreparedStatement pstm)

{

try

{

//语句对象销毁

pstmclose();

}

catch(Exception ex)

{

exprintStackTrace();

}

}

public static void close(Connection conn)

{

try

{

//连接对象销毁

connclose();

}

catch(Exception ex)

{

exprintStackTrace();

}

}

POJO是一种概念或者接口,身份及作用随环境变化而变化,DTO是经过处理后的PO,可能增加或者减少PO的属性,一个POJO持久化以后就是PO。

一、具体含义:

POJO(plainordinaryjavaobject):简单无规则java对象

传统意义的java对象。就是说在一些Object/RelationMapping工具中,能够做到维护数据库表记录的persisentobject完全是一个符合JavaBean规范的纯Java对象,没有增加别的属性和方法,是最基本的JavaBean,只有属性字段及setter和getter方法。

DAO(dataaccessobject):数据访问对象

是一个sun的一个标准j2ee设计模式,这个模式中有个接口就是DAO,它负持久层的 *** 作。为业务层提供接口。此对象用于访问数据库。通常和PO结合使用,DAO中包含了各种数据库的 *** 作方法。通过它的方法,结合PO对数据库进行相关的 *** 作。夹在业务逻辑与数据库资源中间。配合VO,提供数据库的CRUD *** 作。

二、相关概念:

PO(persistantobject):持久对象

在o/r映射的时候出现的概念,如果没有o/r映射,没有这个概念存在了。通常对应数据模型(数据库),本身还有部分业务逻辑的处理。可以看成是与数据库中的表相映射的java对象。最简单的PO就是对应数据库中某个表中的一条记录,多个记录可以用PO的集合。PO中应该不包含任何对数据库的 *** 作。

VO(valueobject):值对象

通常用于业务层之间的数据传递,和PO一样也是仅仅包含数据而已。但应是抽象出的业务对象,可以和表对应,也可以不,这根据业务的需要个人觉得同DTO(数据传输对象),在web上传递。

TO(TransferObject):数据传输对象

在应用程序不同tie(关系)之间传输的对象

BO(businessobject):业务对象

从业务模型的角度看,见UML元件领域模型中的领域对象。封装业务逻辑的java对象,通过调用DAO方法,结合PO,VO进行业务 *** 作。

以上就是关于关于数据库保存流java流对象全部的内容,包括:关于数据库保存流java流对象、java byte[]类型数据要存储到sql server 2005中,请问hibernet如何映射,数据库应该是什么类型、7、 Java数据库编程包含哪些类Java数据库编程的基本过程是什么等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/10126705.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-05
下一篇2023-05-05

发表评论

登录后才能评论

评论列表(0条)

    保存