java访问数据库四种方法的对比

java访问数据库四种方法的对比,第1张

1)JDBC-ODBC桥加ODBC驱动程序

JavaSoft桥产品利用ODBC驱动程序提供JDBC访问。注意,必须将ODBC二进制代码(许多情况下还包括数据库客户机代码)加载到使用该驱动程序的每个客户机上。因此,这种类型的驱动程序最适合于企业网(这种网络上客户机的安装不是主要问题),或者是用Java编写的三层结构的应用程序服务器代码。

(2)本地API

这种类型的驱动程序把客户机API上的JDBC调用转换为Oracle、Sybase、Informix、DB2或其它DBMS的调用。注意,象桥驱动程序一样,这种类型的驱动程序要求将某些二进制代码加载到每台客户机上。

(3)JDBC网络纯Java驱动程序

这种驱动程序将JDBC转换为与DBMS无关的网络协议,之后这种协议又被某个服务器转换为一种DBMS协议。这种网络服务器中间件能够将它的纯Java客户机连接到多种不同的数据库上。所用的具体协议取决于提供者。通常,这是最为灵活的JDBC驱动程序。有可能所有这种解决方案的提供者都提供适合于Intranet用的产品。为了使这些产品也支持Internet访问,它们必须处理Web所提出的安全性、通过防火墙的访问等方面的额外要求。几家提供者正将JDBC驱动程序加到他们现有的数据库中间件产品中。

(4)本地协议纯Java驱动程序

这种类型的驱动程序将JDBC调用直接转换为DBMS所使用的网络协议。这将允许从客户机机器上直接调用DBMS服务器,是Intranet访问的一个很实用的解决方法。由于许多这样的协议都是专用的,因此数据库提供者自己将是主要来源,有几家提供者已在着手做这件事了。

据专家预计第(3)、(4)类驱动程序将成为从JDBC访问数据库的首方法。第(1)、(2)类驱动程序在直接的纯Java驱动程序还没有上市前会作为过渡方案来使用。对第(1)、(2)类驱动程序可能会有一些变种,这些变种要求有连接器,但通常这些是更加不可取的解决方案。第(3)、(4)类驱动程序提供了Java的所有优点,包括自动安装(例如,通过使用JDBC驱动程序的appletapplet来下载该驱动程序)。

Android为数据存储提供了多种方式,分别有如下几种:

文件

SharedPreferences

SQLite数据库

内容提供者(Content provider)

网络

使用文件进行数据存储

首先给大家介绍使用文件如何对数据进行存储,Activity提供了openFileOutput()方法可以用于把数据输出到文件中,具体的实现过程与在J2SE环境中保存数据到文件中是一样的。

复制代码 代码如下:

public class FileActivity extends Activity {

@Override public void onCreate(Bundle savedInstanceState) {

FileOutputStream outStream = thisopenFileOutput("csdnttxt", ContextMODE_PRIVATE);

outStreamwrite("CSDN"getBytes());

outStreamclose();

}

}

openFileOutput()方法的第一参数用于指定文件名称,不能包含路径分隔符“/” ,如果文件不存在,Android 会自动创建它。创建的文件保存在/data/data/<package name>/files目录,如: /data/data/cncsdnaction/files/csdntxt ,通过点击Eclipse菜单“Window”-“Show View”-“Other”,在对话窗口中展开android文件夹,选择下面的File Explorer视图,然后在File Explorer视图中展开/data/data/<package name>/files目录就可以看到该文件。

openFileOutput()方法的第二参数用于指定 *** 作模式,有四种模式,分别为: ContextMODE_PRIVATE = 0

ContextMODE_APPEND = 32768

ContextMODE_WORLD_READABLE = 1

ContextMODE_WORLD_WRITEABLE = 2

ContextMODE_PRIVATE:为默认 *** 作模式,代表该文件是私有数据,只能被应用本身访问,在该模式下,写入的内容会覆盖原文件的内容,如果想把新写入的内容追加到原文件中。可以使用ContextMODE_APPEND

ContextMODE_APPEND:模式会检查文件是否存在,存在就往文件追加内容,否则就创建新文件。

ContextMODE_WORLD_READABLE和ContextMODE_WORLD_WRITEABLE用来控制其他应用是否有权限读写该文件。

MODE_WORLD_READABLE:表示当前文件可以被其他应用读取;MODE_WORLD_WRITEABLE:表示当前文件可以被其他应用写入。

如果希望文件被其他应用读和写,可以传入:

openFileOutput("csdntxt", ContextMODE_WORLD_READABLE + ContextMODE_WORLD_WRITEABLE);

android有一套自己的安全模型,当应用程序(apk)在安装时系统就会分配给他一个userid,当该应用要去访问其他资源比如文件的时候,就需要userid匹配。默认情况下,任何应用创建的文件,sharedpreferences,数据库都应该是私有的(位于/data/data/<package name>/files),其他程序无法访问。除非在创建时指定了ContextMODE_WORLD_READABLE或者ContextMODE_WORLD_WRITEABLE ,只有这样其他程序才能正确访问。

读取文件内容

如果要打开存放在/data/data/<package name>/files目录应用私有的文件,可以使用Activity提供openFileInput()方法。

FileInputStream inStream = thisgetContext()openFileInput("csdntxt");

Logi("FileTest", readInStream(inStream));

readInStream()的方法请看本页下面备注。

或者直接使用文件的绝对路径:

File file = new File("/data/data/cncsdnaction/files/csdntxt");

FileInputStream inStream = new FileInputStream(file);

Logi("FileTest", readInStream(inStream));

注意:上面文件路径中的“cncsdnaction”为应用所在包,当你在编写代码时应替换为你自己应用使用的包。

对于私有文件只能被创建该文件的应用访问,如果希望文件能被其他应用读和写,可以在创建文件时,指定ContextMODE_WORLD_READABLE和ContextMODE_WORLD_WRITEABLE权限。

Activity还提供了getCacheDir()和getFilesDir()方法:

getCacheDir()方法用于获取/data/data/<package name>/cache目录

getFilesDir()方法用于获取/data/data/<package name>/files目录

1、grant语句

格式:grant select on 数据库 to 用户名@登录主机 identified by “密码”

说明:

(1)grant all 赋予所有的权限

(2)demo 数据库 demo 中所有的表

(3)newuser 用户名

(4)@localhost 在本地电脑上的 mysql server 服务器

(5)identfified by ‘password’ 设置密码

增加一个用户test1密码为abc,让他可以在任何主机上登录,并对所有数据库有查询、插入、修改、删除的权限。首先用以root用户连入MYSQL,然后键入以下命令:

2、sql语句

代码如下

mysql>INSERT INTO user (host,user,password) VALUES(’192168206%’,'high_vod’,PASSWORD(‘high_vod’));

mysql>INSERT INTO db

VALUES(’192168206%’,'high_vod’,'high_vod’,'Y’,'Y’,'Y’,'Y’,'Y’,'Y’,'N’,'Y’,'Y’,'Y’,'Y’,'Y’,'Y’,'Y’,'Y’,'Y’,'Y’,'Y’,'Y’);

mysql>FLUSH PRIVILEGES;

1、在tomcat6\conf\contextxml文件的Context节点中增加下面节点:

<Resource name="jdbc/eworkflow" auth="Container" type="javaxsqlDataSource" username="sa" password="" driverClassName="netsourceforgejtdsjdbcDriver" url="jdbc:jtds:sqlserver://localhost:1433;databaseName=eworkflow-java;integratedSecurity=true;" maxActive="100" maxIdle="30" maxWait="10000"/>

2、方成软件web-inf\fcconfigxml文件中第一个ds节点配置如下:

<ds name="eworkflow" dbType="sqlserver" type="jndi" jndiName="jdbc/eworkflow" jndiPrefix="java:/comp/env" />

3、web-inf\webxml文件中web-app节点中增加下面节点:

<resource-ref>

<description>DB Connection</description>

<res-ref-name>jdbc/eworkflow</res-ref-name>

<res-type>javaxsqlDataSource</res-type>

<res-auth>Container</res-auth>

</resource-ref>

4、通过数据源访问数据库,由于数据源由tomcat创建并维护,所以必须把数据库连接驱动包复制到tomcat的lib目录下。

这里把jtds-12jar复制到tomcat\lib目录中。

启动 tomcat6,在浏览器中输入:>

我知道两种!

1、Connection的直连

2、采用DataAdapter缓存技术!这是常用的

不知你明白吗?

代码

string str="连接串";

SqlConnection con=new SqlConnection(str);

string sql="select from table1";

SqlCommand cmd=new SqlCommand(sql,con);第一种访问技术

cmdExecudReader();

2、

SqlConnection con=new SqlConnection(str);

string sql="select from table1";

SqlCommand cmd=new SqlCommand(sql,con);第一种访问技术

SqlDataAdapter dataAapter=new SqlDataAdapter(cmd);

DataSet ds=new DataSet();

dataAdapterFills(ds);

dsTables[0];

可以肯定的是:可以用域名方式连接SQL数据库

将SQL服务的1433端口开放(或更改默认端口),通过路由指向外网

域名>花生壳>动态IP>路由(SQL端口指向)>内网IP(服务器)

这两种方法都是对连接的数据库进行数据库的访问的方法。

使用command对象访问数据库,一般和DataReader一起用,这种方式的优点是不占用额外的内存,读取的速度比较快,但是所需编写的程序代码比较长。

使用DataSet访问数据库,这种方式的优点是所需编写的代码程序少,但是需要占用额外的内存,并且读取数据的速度比前一种相对来说慢。

至于需要采用什么样的方式,就要看程序员所要开发系统的特点了

直接客户端访问数据库的方式,称为两层数据库应用,数据处理逻辑、用户交互合二为一,客户端编程既要清楚数据库的数据结构,又要考虑怎么与用户交互,编程复杂,不便于软件的团队开发,同时数据库的结构暴露在客户端,不利于保密。而且当客户需求改变时,数据库结构改变了,客户端程序都得重写,不便于数据库应用功能的扩展。

客户端通过服务端的应用访问数据库的方式,称为多层数据库应用,通常为三层,即所谓的表现层、业务层和数据层。表现层(也就是客户端)用于和用户交互,提供用户界面及 *** 作导航服务;业务层用于业务处理,提供商业逻辑等各种约束;数据层用于数据的集成存储。

有点复杂。简单一点讲,三层数据库应用就象我们用的电脑,应用程序相当于客户端,API相当于业务层, *** 作系统底层的东西相当于数据层。这样,你开发应用程序(客户端)只要知道API怎么用就可以了,不需要知道 *** 作系统底层的东西。 *** 作系统改了(从WIN98、到XP、到WIN7,从32位到64位),只要API接口没变,你的应用程序就还可以运行。你的应用程序要增加功能,API接口不需要改, *** 作系统底层也不需要改。这样,才可能有不同的人开发出各种各样的应用程序。你想想,如果没有API,每个人开发的应用程序都直接与 *** 作系统底层打交道, *** 作系统一变,这些应用程序还能用么?多层数据库应用的道理就是这样。

以上就是关于java访问数据库四种方法的对比全部的内容,包括:java访问数据库四种方法的对比、android有哪几种方式进行数据库访问、试论述MySQL用户获取数据库数据访问权限的三种方法的具体使用等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

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

原文地址: http://outofmemory.cn/sjk/9540989.html

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

发表评论

登录后才能评论

评论列表(0条)

保存