? QueryRunner(DataSource ds) --不需要控制事务用这组方法
int update(String sql)
Executes the given INSERT, UPDATE, or DELETE SQL statement without any replacement parameters. int update(String sql, Object... params)
Executes the given INSERT, UPDATE, or DELETE SQL statement. int update(String sql, Object param)
Executes the given INSERT, UPDATE, or DELETE SQL statement with a single replacement parameter.
Executes the given SELECT SQL without any replacement parameters.
2.3ResultSetHandler接口
该接口用于处理 java.sql.ResultSet,将数据按要求转换为另一种形式。
ResultSetHandler 接口提供了一个单独的方法:Object handle (java.sql.ResultSet .rs)。 ResultSetHandler 接口的实现类:
ArrayHandler:把结果集中的第一行数据转成对象数组。
ArrayListHandler:把结果集中的每一行数据都转成一个对象数组,再存放到List中。 !!!!BeanHandler:将结果集中的第一行数据封装到一个对应的JavaBean实例中。
!!!!BeanListHandler:将结果集中的每一行数据都封装到一个对应的JavaBean实例中,存放到List里。 MapHandler:将结果集中的第一行数据封装到一个Map里,key是列名,value就是对应的值。 MapListHandler:将结果集中的每一行数据都封装到一个Map里,然后再存放到List ColumnListHandler:将结果集中某一列的数据存放到List中。
KeyedHandler(name):将结果集中的每一行数据都封装到一个Map里(List
!!!!!ScalarHandler:获取结果集中第一行数据指定列的值,常用来进行单值查询 /** * DBUtils方式实现增删改 * @throws SQLException */ @Test public void add2() throws SQLException{ QueryRunner runner = new QueryRunner(new ComboPooledDataSource()); runner.update(\ } /** * 古老方法实现增删改功能 * --在进行增删改操作时,每次都不一样的只有sql语句和sql语句中的参数 */ @Test public void update1(){ Connection conn = null; PreparedStatement ps = null; ResultSet rs = null; ComboPooledDataSource source = new ComboPooledDataSource(); try{ conn = source.getConnection(); ps = conn.prepareStatement(\ ps.setDouble(1, 999); ps.setString(2, \ ps.executeUpdate(); }catch (Exception e) { e.printStackTrace(); }finally{ DbUtils.closeQuietly(conn, ps, rs); } } -------------------------------------------------------------------------------------------------------------------------------------------------------------------- /** * DbUtils方式实现查询 * @throws SQLException */ @Test public void find2() throws SQLException{ QueryRunner runner = new QueryRunner(new ComboPooledDataSource()); Listlist = runner.query(\ , new ResultSetHandler(){ public List handle(ResultSet rs) throws SQLException { List list = new ArrayList(); while(rs.next()){ Account acc = new Account(); acc.setId(rs.getInt(\ acc.setName(rs.getString(\ acc.setMoney(rs.getDouble(\ list.add(acc); } return list; } }, 500); System.out.println(list); } /** * 古老方式实现的查询 * ---sql/sql中的参数/结果集的处理 */ @Test public void find1(){ Connection conn = null; PreparedStatement ps = null; ResultSet rs = null; ComboPooledDataSource source = new ComboPooledDataSource(); List list = new ArrayList(); try{ conn = source.getConnection(); ps = conn.prepareStatement(\ ps.setDouble(1, 500); rs = ps.executeQuery(); while(rs.next()){ } Account acc = new Account(); acc.setId(rs.getInt(\ acc.setName(rs.getString(\ acc.setMoney(rs.getDouble(\ list.add(acc); } System.out.println(list); }catch (Exception e) { e.printStackTrace(); }finally{ DbUtils.closeQuietly(conn, ps, rs); } //ScalarHandler:获取结果集中第一行数据指定列的值,常用来进行单值查询 @Test public void tes9() throws SQLException{ QueryRunner runner = new QueryRunner(new ComboPooledDataSource()); Long count = (Long)runner.query(\ System.out.println(count); } //KeyedHandler(name):将结果集中的每一行数据都封装到一个Map里(List
回调函数:当方法a调用方法b,而方法b在执行的过程中,其中的一些逻辑需要由方法a来告知,此时需要方法a在调用方法b时将逻辑传入,而java中是不允许传递java源代码,此时可以使用回调机制来解决
所谓的回调,就是方法a和方法b约定一个接口,在这个接口中定义一个方法,这个方法的名字通常叫做hander方法,a方法在调用b时,传入此接口的一个实现,其中利用handler方法,将逻辑传入,方法b在执行的过程中需要执行a传入的逻辑时,调用接口实现的handler方法即可,此时a调用b时,b回来调用的a传入的逻辑,所以这个过程叫做回调。
十七、国际化
1.概念
一款软件希望不同的国家和地区的使用者都可以使用,这个时候软件中的一些内容和数据需要根据用户地区信息不同而展示成不同的样子。软件开发时,要使它能同时应对世界不同地区和国家的访问,并针对不同地区和国家的访问,提供相应的、符合来访者阅读习惯的页面或数据。国际化又称为 i18n:internationalization。
软件实现国际化,需具备哪些特征:
? 对于程序(页面)中固定使用的文本元素,例如菜单栏、导航条等中使用的文本元素、或错误提示信息,状态信
?
息等,需要根据来访者的地区和国家,选择不同语言的文本为之服务。
对于程序动态产生的数据,例如(日期,货币等),软件应能根据当前所在的国家或地区的文化习惯进行显示。
2.固定文本元素的国际化
2.1概述
对于软件中的菜单栏、导航条、错误提示信息,状态信息等这些固定不变的文本信息,可以把它们写在一个properties
文件中,并根据不同的国家编写不同的properties文件。这一组properties文件称之为一个资源包。
在JavaAPI中提供了一个ResourceBundle 类用于描述一个资源包,并且 ResourceBundle类提供了相应的方法getBundle,这个方法可以根据来访者的国家地区自动获取与之对应的资源文件予以显示。
2.2创建资源包和资源文件
一个资源包中的每个资源文件都必须拥有共同的basename基名。除了基名,每个资源文件的名称中还必须有标识其本地信息的附加部分。例如:一个资源包的基名是“myproperties”,则与中文、英文环境相对应的资源文件名则为: “myproperites_zh.properties” “myproperites_en.properties”
每个资源包都应有一个默认资源文件,这个文件不带有标识本地信息的附加部分。若ResourceBundle对象在资源包中找不到与用户匹配的资源文件,它将选择该资源包中与用户最相近的资源文件,如果再找不到,则使用默认资源文件。例如:myproperites.properties
2.3资源文件的书写格式
? 资源文件的内容通常采用“关键字=值”的形式,软件根据关键字检索值显示在页面上。一个资源包中的所有资源文件的关键字必须相同,值则为相应国家的文字。
? 并且资源文件中采用的是properties格式文件,所以文件中的所有字符都必须是ASCII字码,对于像中文这样的非ACSII字符,须先进行编码。(java提供了一个native2ascII命令用于编码)。例:属性文件是不能保存中文的。 username=username password=password submit=submit resource_en.properties文件 使用fmt标签库搞定。
java方式实现的页面国际化
<% Locale local = request.getLocale(); ResourceBundle bundle = ResourceBundle.getBundle(\ %>
fmt标签方式实现的页面国际化
DateFormat 类可以将一个日期/时间对象格式化为表示某个国家地区的日期/时间字符串。 DateFormat 类除了可按国家地区格式化输出日期外,它还定义了一些用于描述日期/时间的显示模式的 int 型的常量,包括FULL, LONG, MEDIUM, DEFAULT, SHORT,实例化DateFormat对象时,可以使用这些常量,控制日期/时间的显示长度。 函数: