它们各有自己的优点和缺点,要不就不会存在这两种了。
BMP的创建,重载等 *** 作,是由编写EJB的程序员在写EJB时就设计好的。这部分你好像知道了。
至于CMP呢,则是由一个叫容器的平台了实现的,C就是Container的简写。
容器是一个封装好的一个EJB服务,CMP程序员只要将写好的EJB交给容器就行了。容器会提供管理这些EJB的生命周期。你所说的和数据库连接,它是以容器的一个相当于环境设置变量的接口提供的。EJB只需要去调用该类似于接口的方法就行。
CMP必须符合一定的规范,否则无法运行,由于一些功能是有容器提供,所以它的运行效率和某一些特性将受限,但是,通过部署,它可以很快的在另一个EJB服务器上运行。
BMP在移植性上没有CMP好,但是,它一般是专用专写的程序,它的行为是可控的。
----------------------------------------------------------
BMP是在bean中完成对数据库JDBC的各种调用 也就是说 在实体Bean中明确写入SQL语句,并且使用DataSource获得一个数据库资源以及连接从而对数据库进行增加 删除和修改
CMP 是EJB容器自动完成对数据库的 *** 作,你所做的就是在实体Bean中重写入setXXXX或GETXXXXX方法,然后再ejb-jarxml中定义cmp-field就可以
很明显 编写CMP要简单得多,而且数据库 *** 作有EJB容器完成因该是一种趋势,但CMP不够灵活
>
问题一:数据库怎样可以将放到里面 首先肯定一点,数据库中是可以放数据的!但是这样的话,数据体积会很庞大,当然最好还是把放到文件夹中,数据只用来存放路径,不过最好是存放相对路径,应该以后可能设计到单独放在另一台服务器上,或换了文件夹。
问题二:SQL数据库中能存照片吗? 完全可以存放,但是在数据库中不能以select from a进行查询
但是在相对应得c#、Java中可以查询
是以二进制保存的。
数据库,只要是抽象出来的数据,都可以保存。
而已不能保存的,就是实体,像处啊、鞋子啊、男朋友啊都不姓
问题三:mysql数据库可以存吗? 可以。存的列需要设置成BLOB、MEDIUMBLOB或LONGBLOB等数据类型。
但是以前基本上不会把直接存在数据库里,因为数据库里的数据是为了用来快速分析、快速存取的,数据在mysql里既不能建立索引也不能和其他数据一起分析,存取速度和读写磁盘也没什么区别,每次备份、导入导出数据库时还增加了数据量,降低了效率。所以一般都是把存在系统里,然后把的存放路径放在数据库里。
问题四:如何存入数据库 第一种方式:保存路径至数据库中
第二种方式:数据插入相应表中,参数类型为byte[]
例如:
sql:insert into table(imageColumn) values (@image);
其中@image参数值为byte[]类型的变量
问题五:如何存放在oracle数据库 测试可行。这只是核心Class文件代码,你要是弄不出来,就再联系我,我再把整个项目给你。这是把真个放到数据库
package dao;
import javaioFileInputStream;
import javaioOutputStream;
import javasqlBlob;
import javasqlConnection;
import javasqlPreparedStatement;
import javasqlResultSet;
import javautilScanner;
import oraclesqlBLOB;
public class Insert {
Scanner sc =new Scanner(Systemin);
@SuppressWarnings(deprecation)
public int insertbinary(String pname,String src1){
Connection con = null;
String sql = insert into test values(,);
String sql1 =update test set image= where pname=;
int res = 0;
try {
con=BaseDAOgetConnection();
consetAutomit(false);
PreparedStatement pstm = conprepareStatement(sql);
pstmsetString(1, pname);
EMPTY_BLOB和EMPTY_CLOB返回一个空的LOB定位器,
可以用来初始化一个LOB变量,或在INSERT或UPDATE语句,
初始化LOB列或属性为空。 EMPTY表示LOB初始化,但不填充数据。
pstmsetBlob(2, oraclesqlBLOBempty_lob());
pstmexecuteUpdate();
pstmclose();
pstm = conprepareStatement(select from test where pname=);
pstmsetString(1, pname);
ResultSet rs = pstmexecuteQuery();
rsnext();
BLOB blob = (BLOB) rsgetBlob(2);
OutputStream os = blobgetBinaryOutputStream();
FileInputStream fi = new FileInputStream(src1);
byte[] buff = new byte[1024];
int len = firead(buff);
while (len != -1) {
oswrite(buff);
len = firead(buff);
}
pstm = conprepareStatement(sql1);
pstmsetBlob(1,>>
问题六:如何将储存在MySQL数据库里 通常对用户上传的需要保存到数据库中。解决方法一般有两种:一种是将保存的路径存储到数据库;另一种是将以二进制数据流的形式直接写入数据库字段中。以下为具体方法:
一、保存的上传路径到数据库:
string uppath=;用于保存上传路径
获取上传的文件名
string fileFullname = thisFileUpload1FileName;
获取上传的时间,以时间作为的名字可以防止重名
string dataName = DateTimeNowToString(yyyyMMddhhmmss);
获取的文件名(不含扩展名)
string fileName = fileFullnameSubstring(fileFullnameLastIndexOf(\\) + 1);
获取扩展名
string type = fileFullnameSubstring(fileFullnameLastIndexOf() + 1);
判断是否为要求的格式
if (type == bmp || type == jpg || type == jpeg || type == gif || type == JPG || type == JPEG || type == BMP || type == GIF)
{
将上传到指定路径的文件夹
thisFileUpload1SaveAs(ServerMapPath(~/upload) + \\ + dataName + + type);
将路径保存到变量,将该变量的值保存到数据库相应字段即可
uppath = ~/upload/ + dataName + + type;
}
二、将以二进制数据流直接保存到数据库:
引用如下命名空间:
using SystemDrawing;
using SystemIO;
using SystemDataSqlClient;
设计数据库时,表中相应的字段类型为iamge
保存:
路径
string strPath = thisFileUpload1PostedFileFileNameToString ();
读取
FileStream fs = new SystemIOFileStream(strPath, FileModeOpen, FileAccessRead);
BinaryReader br = new BinaryReader(fs);
byte[] photo = brReadBytes((int>>
问题七:如何在数据库中存储文件 解决方法一般有两种:
一种是将保存的路径存储到数据库;
另一种是将以二进制数据流的形式直接写入数据库字段中。
问题八:如何将存到数据库 通常对用户上传的需要保存到数据库中。解决方法一般有两种:一种是将保存的路径存储到数据库;另一种是将以二进制数据流的形式直接写入数据库字段中。以下为具体方法:
一、保存的上传路径到数据库:
string uppath=;用于保存上传路径
获取上传的文件名
string fileFullname = thisFileUpload1FileName;
获取上传的时间,以时间作为的名字可以防止重名
string dataName = DateTimeNowToString(yyyyMMddhhmmss);
获取的文件名(不含扩展名)
string fileName = fileFullnameSubstring(fileFullnameLastIndexOf(\\) + 1);
获取扩展名
string type = fileFullnameSubstring(fileFullnameLastIndexOf() + 1);
判断是否为要求的格式
if (type == bmp || type == jpg || type == jpeg || type == gif || type == JPG || type == JPEG || type == BMP || type == GIF)
{
将上传到指定路径的文件夹
thisFileUpload1SaveAs(ServerMapPath(~/upload) + \\ + dataName + + type);
将路径保存到变量,将该变量的值保存到数据库相应字段即可
uppath = ~/upload/ + dataName + + type;
}
二、将以二进制数据流直接保存到数据库:
引用如下命名空间:
using SystemDrawing;
using SystemIO;
using SystemDataSqlClient;
设计数据库时,表中相应的字段类型为iamge
保存:
路径
string strPath = thisFileUpload1PostedFileFileNameToString ();
读取
FileStream fs = new SystemIOFileStream(strPath, FileModeOpen, FileAccessRead);
BinaryReader br = new BinaryReader(fs);
byte[] photo = br>>
问题九:怎样数据库access保存jpg 只有两种方法
1存地址,放服务器的一个文件夹里
2存的数据,也就是二进制流
既然第一种你说不行 那只能第二种了。
我只说一下思路,代码网上找一下,多的很,也不麻烦1数据库字段类型为image(sqlserver的是image,不知道access的是不是)
2把文件序列化 放到一个byte[]数组里,然后存到数据库
显示的时候:
1单独在一个页面读出的内容到一个byte[]数组
2用response把这段二进制输出
3在要引用的地方,比如你的image控件,把引用的地址指向这个页面就行了
问题十:如何像数据库中保存? 一般图像是不保存在数据库的而是先将放在工程下的某个文件夹中,将所在的工程文件路径存在数据库中,当程序加载的时候,从数据库中读取的路径,然后根据路径在工程的文件夹中读取文件
意味着该字段的内容是一张名为photobmp的。这种设置常见于数据库中的记录,用于记录与该记录相关的信息。比如,一个商品的记录包含商品的名称、价格、描述等信息,同时也会包含该商品的信息,以便在网站上展示商品。
以上就是关于BMP和CMP的差异全部的内容,包括:BMP和CMP的差异、如何在数据库中添加图片、数据库能存图片吗等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)