文本文件名为 count.txt,里面随便写入一个数字。
静态页面名为Cnt.htm。
2.以上3个文件都放在同一目录下。
由于采用Access数据库,而它采用非标准SQL语法,所以要注意在表名和字段名上需要加方括号: []
3.下面是页面里的代码:其中getCountFromDB方法是对Access数据库进行 *** 作,getCountFromTxt方法是对txt纯文本进行 *** 作,这两个方法都在本地执行通过。
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML>
<HEAD>
<TITLE>New Document </TITLE>
<META NAME="Generator" CONTENT="EditPlus">
<META NAME="Author" CONTENT="">
<META NAME="Keywords" CONTENT="">
<META NAME="Description" CONTENT="">
<SCRIPT LANGUAGE="JavaScript">
<!--
function getCountFromDB() {
//以当前页面文件为基础,找到文件所在的绝对路径。
var filePath = location.href.substring(0, location.href.indexOf("Cnt.htm"))
var path = filePath + "MyData.mdb"
//去掉字符串中最前面的"files://"这8个字符。
pathpath = path.substring(8)
var updateCnt = 0
//生成查询和更新用的sql语句。
var sqlSelCnt = "SELECT COUNT FROM [COUNT] WHERE ID = 'count'"
var sqlUpdCnt = "UPDATE [COUNT] SET [COUNT] = '"
//建立连接,并生成相关字符串 www.knowsky.com。
var con = new ActiveXObject("ADODB.Connection")
con.Provider = "Microsoft.Jet.OLEDB.4.0"
con.ConnectionString = "Data Source=" + path
con.open
var rs = new ActiveXObject("ADODB.Recordset")
rs.open(sqlSelCnt, con)
while (!rs.eof) {
var cnt = rs.Fields("COUNT")
document.write(cnt)
//将取得结果加1后更新数据库。
updateCnt = cnt * 1 + 1
rs.moveNext
}
rs.close()
rs = null
sqlUpdCntsqlUpdCnt = sqlUpdCnt + updateCnt + "'"
con.execute(sqlUpdCnt)
con.close()
con = null
}
function getCountFromTxt() {
var filePath = location.href.substring(0, location.href.indexOf("Cnt.htm"))
var path = filePath + "count.txt"
pathpath = path.substring(8)
var nextCnt = 0
var fso, f1, ts, s
//以只读方式打开文本文件。
var ForReading = 1
//以读写方式打开文本文件。
var ForWriting = 2
fso = new ActiveXObject("Scripting.FileSystemObject")
f1 = fso.GetFile(path)
ts = f1.OpenAsTextStream(ForReading, true)
s = ts.ReadLine()
nextCnt = eval(s) + 1
document.write("now count is :" + s)
ts.Close()
ts = f1.OpenAsTextStream(ForWriting, true)
ts.WriteLine(nextCnt)
ts.close()
}
//-->
</SCRIPT>
</HEAD>
<BODY>
<SCRIPT LANGUAGE="JavaScript">
<!--
getCountFromTxt()
//-->
</SCRIPT>
</BODY>
</HTML>
4.用这种方法来读写数据库,只适合做计数器和留言版这样的不需要保密性的工作,毕竟代码全是用javascript写成的,谁都可以看到,然后就可以得到路径把db文件下载下来进行分析,所以没办法用它来保存一些不想让别人知道的东西。
按如下方法添加值列表,以access2013为例:
1、打开access数据库文件。
2、选择“创建”——“表设计”。
3、按照如图创建一个表格。
4、这里的省份需要设置成列表,然后,点击下方的“查阅”。
5、在行来源类型选择“值列表”,行来源中输入要添加的列表值,并以英文输入法的分号分隔,如图:
6、然后保存表。
7、然后添加数据时,可见之前设置的值达到了值列表的状态,如图:
//先连接好数据源,假设连接成功并取名为users,无密码和用户名//下简单的对数据库中users表进行了添加和修改,编译执行无误
import java.sql.*
public class operateDateBase {
public static void main(String[] args) {
Connection ct=null
PreparedStatement ps=null
int a=0,b=0
try {
Class.forName("sun.jdbc.odbc.JdbcOdbcDriver")
ct=DriverManager.getConnection("jdbc:odbc:users")
//下为插入语句,values()中各值为users表中各字段的值
ps=ct.prepareStatement("insert into users values('27','jj','kk','kk','2')")
a=ps.executeUpdate()
//下为修改 *** 作,将users表中id号为26的passwd改成mm
ps=ct.prepareStatement("update users set passwd='mm' where userId=26")
b=ps.executeUpdate()
//如果 *** 作成功,a和b的值都应为1
System.out.println("a="+a+" b="+b)
} catch (Exception e) {
e.printStackTrace()
}finally{
try {
if(ps!=null)
{
ps.close()
ps=null
}
if(ct!=null)
{
ct.close()
ct=null
}
} catch (Exception e2) {
e2.printStackTrace()
}
}
}
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)