- 1、本文档共83页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第21章 学生信息管理——三层结构数据库编程 ;能力目标:
能使用JDBC建立数据库连接,能编写Java代码连接数据库。
能编写添加、修改、删除数据库记录的程序代码。
理解表示层、业务逻辑层、数据层,理解三层结构的应用程序。
能编写三层结构的学生信息管理应用程序,并能打包发布。;内容介绍;21.1 任务预览 ;21.2 建立数据库 ;21.2.1 在DBMS上建立数据库 ;21.2.2 运行SQL脚本建立数据库 ;USE Studb
CREATE TABLE Stus (
Num char(8) PRIMARY KEY, Name nvarchar(4) NOT NULL,
Sex nchar(1) NOT NULL, Specialty nvarchar(7) NULL,
Year int NULL,
CHECK(Sex=男 or Sex=女 ),
CHECK((Year=2000 and Year=2020) or Year=0),
)
GO
insert into Stus(Num,Name,Sex,Specialty,Year) values 赵益,男,软件技术,2012)
insert into Stus(Num,Name,Sex,Specialty,Year) values 钱珥,女,软件技术,2012)
insert into Stus(Num,Name,Sex,Specialty,Year) values 孙散,男,软件技术,2012)
insert into Stus(Num,Name,Sex) values 李四,男)
GO;用记事本把脚本代码录入电脑,存盘为createstudb.sql。
设计算机已安装速成版SQL Server 2005,打开命令行窗口,进入脚本文件目录。
执行下面命令生成学生数据库Studb.mdf:
sqlcmd -S .\SQLExpress -E -i createstudb.sql; 21.3 连接数据库;JDBC 简介;JDBC简介;使用JDBC/ODBC桥接驱动程序;java.sql包;类或接口名称;使用JDBC API进行数据库操作步骤;5.执行语句:对SELECT语句来说,使用executeQuery方法执行,返回结果是ResultSet类型的结果集:对INSERT、UPDATE、DELETE语句来说,使用executeUpdate方法执行,返回结果是影响的行数。
6.处理结果:对返回的结果集或影响行数进行处理,可以进行显示、判断等操作。
7.关闭资源:与各种对象创建的顺序相反,依次关闭ResultSet、Statement、Connection对象。 ;访问数据库 ;访问数据库;访问数据库;访问数据库;访问数据库;21.3.3 通过数据源建立数据库连接 ;21.3.4 Connection连接 ;(3)PreparedStatement prepareStatement(String sql):创建预编译语句(对象)。
(4)PreparedStatement prepareStatement(String sql, int resultSetType, int resultSetConcurrency)。
(5)void close():关闭连接,释放资源。
(6)void setAutoCommit(boolean autoCommit):设置连接对象是否自动提交。
(6)void commit():提交事务,实现数据更改。
(7)void rollback():回滚事务。
注:默认连接对象自动提交,执行每个语句都会自动提交更改。如果禁用自动提交,那么要提交更改就必须显式调用commit方法。; 21.4 访问数据库;【例21-2】编写读取学生数据库Studb所有记录的Java程序。 ;21.4.2 Statement语句 ;21.4.3 PreparedStatement预编译SQL语句 ;(4)void setString(int parameterIndex, String x):将SQL语句中指定索引处的参数设置为String类型的x值。
SQL语句参数用“?”表示,索引从1开始。如带4个?参数:
sql = update Stus set Name=?,Sex=?,Year=? where Num=?;
prpstmt = conn.prepareStatement(sql); //创建预编译语句
prpstmt.setString(1, 郑丽);
文档评论(0)