金色的骷髅 发表于 2015-2-4 00:13:50

PHP教程之J2EE中几种面向对象的数据库映照会见策...

学会了PHP,那么学其他的语言,肯定速成,反过来也一样,如果你之前学过其他的语言,那么学PHP肯定快。j2ee|战略|对象|会见|数据|数据库   几种面向对象的数据库会见战略:
1 JDBC
是最原始的办法,写sql语句,保护性差

上面面向对象的办法:
例如update: 要先掏出对象,更新对象,然后再保留
OrderInfo order = orderService.getOrder(orderId);
order.setStatus(new Integer(2));
orderService.updateOrder(order);
2 Hibernate
利用Hql
3 iBatis
将查询和更新放在maps文件中
<dynamic-mapped-statement name="searchProductList" result-map="result">
    select productid, name, descn, category from product
    <dynamic prepend="where">
      <iterate property="keywordList" open="(" close=")" conjunction="OR">
      lower(name) like #keywordList[]# OR lower(category) like #keywordList[]# OR lower(descn) like #keywordList[]#
      </iterate>
    </dynamic>
4 EasyDBO:
有三种完成办法,咱们只看个中采取annotation的
@Table(tableName="Customer")
public class Customer implements Serializable {
来肯定表名
采取反射的办法,不需求设置装备摆设文件:
public List getRootCustomers() {
return this.dao.query(Customer.class,"(parent_id is null or parent_id='')");
}
List list=dao.query(CustomerPrice.class, "customer_id="+cu.getId()+" and product_id="+p.getId()+" order by vdate desc");
该办法已和ADODB很像了,但和adodb分歧的是,依然没有完成完整主动的Plain SQL转换到PO.
5 PHP's ADODB的j2ee移植
以jdbc查询sql为基本,经由过程反射,范型等办法主动装载。
adodb的办法和下面的easydbo很像,不外在obj到sql的生成上加倍成熟一些,驱动也加倍多
关于查询
    /////////////////////////////////////////////////////////////////////////////
    //Function: 完成ResultSet对象向ArrayList对象为纠合的对象的转化
    //Para:sql,指定的查询Sql
   //Para:className,Sql绝对应得JavaBean/FormBean类的名字
   //Return:以类className为一笔记录的了局集,完成ResultSet对象向ArrayList对象为集//合的className对象的转化
//////////////////////////////////////////////////////////////////////////////
public ArrayList Select(String sql,String className){
    ArrayList paraList=new ArrayList();
    try{
      if (conn == null){
      Connection();
      }
      PreparedStatement stmt = conn.prepareStatement(sql);
      ResultSet rs = stmt.executeQuery();
      String recordValue="";
      Object c1=null;
      paraList=new ArrayList();
      ResultSetMetaData rsmd = rs.getMetaData();
      int columnCount = rsmd.getColumnCount();
      while (rs.next()){
          c1=Class.forName(className).newInstance();
          for (int i=1; i<=columnCount; i++) {
            if(rs.getString(rsmd.getColumnName(i))!=null){
            recordValue=rs.getString(rsmd.getColumnName(i));
            }else{
            recordValue="";
            }
            Method m=c1.getClass().getMethod(getSetMethodName(rsmd.getColumnName(i)),new Class[]{recordValue.getClass()});
            m.invoke (c1, new Object[]{recordValue});
          }
          paraList.add(c1);
      }
    }catch(SQLException ex){
      
    }catch(ClassNotFoundException e){
    }catch(NoSuchMethodException e) {
    }catch(InvocationTargetException e){
    }catch (IllegalAccessException e){
    }catch(InstantiationException e){
    } finaly{
      closeConnection();
    return paraList;
    }
      }

   //Function:获得用户列表
//Para:
//Return:前往用户列表
/////////////////////////////////////////////////////////////////////////////
public ArrayList getUsers(){
      ArrayList ret=null;
      DatabaseManage db=new DatabaseManage();
      String sql=" select usr_id,usr_name "
          +" from users " ;//该办法的优点是SQL可以随意写,需求的字段也能够随意写,乃至免除了耐久层的LazyLoad
      ret=db.Select(sql,"com.domain.User");
      return ret;
}
关于单张表,用PO/Formbean来寄存
假如有联系关系多张表,需求一个VO/Map来寄存
关于保留和更新
    反省对象外面的每个属性,假如不是null,就构成SQL语句,
    更新的时分,先查出这个对象,假如属性不是null,而且属性值变了,才将该属性构成SQL语句
   
这类办法和Hibernate/Ibatis比拟能够就义一些功能,然而免除了大批的设置装备摆设文件,假如对字段有特别的请求,可以
经由过程annotation来界说。
Annotation可是个好器材,依据jdk手册:Annotations can be read from source files, class files, or reflectively at run time.
所以可以充实使用反射读取annotation来削减代码。
上面是一些例子
@com.acme.util.Name(first=Alfred, middle=E., last=Neuman)
@Table(tableName="Customer")
@ManyToOne(column = "parent_id", fieldType=java.util.HashSet.class,type = Customer.class,lazy=false)
读取的办法是在反射外面利用上面的办法
<T extends Annotation> T xxx = getAnnotation(Class<T> annotationClass)
固然,完成必需声明annotationClass,上面是手册的一个复杂例子
/**
* Describes the Request-For-Enhancement(RFE) that led
* to the presence of the annotated API element.
   界说一个标签记号
*/
public @interface RequestForEnhancement {
    int    id();
    String synopsis();
    String engineer() default "";
    String date();    default "";
}
这个标签,和它的属性都在下面声了然,上面是某个函数中需求用到这个标签的示例
@RequestForEnhancement(
    id       = 2868724,
    synopsis = "Enable time-travel",
    engineer = "Mr. Peabody",
    date   = "4/1/3007"
)
public static void travelThroughTime(Date destination) { ... }
因而咱们假如想要挪用这个标签
for (Method m : Class.forName('假定是travelThroughTime地点的类名').getMethods()) {
         if (m.isAnnotationPresent(RequestForEnhancement.class)) {
             RequestForEnhancement rfe = m.getAnnotation(RequestForEnhancement.class);
             上面就能够获得rfe的属性了
         }
      }
Commons Attributes也是一个替换jdk尺度annotation的计划

PHP中的ADODB之所以壮大,高效是在于PHP数组的壮大和弱变量界说的便利。
固然这里的每个对象就相当于对应数据库的一张表,如许也很好。
由于在营业相当庞杂的时分,联系关系要尽可能罕用,把营业精心设计在数据库表下面而非java对象的纠合的联系关系上。
在大型使用中,普通1:1的联系关系都多利用View来处置联系关系,1:n和n:n的联系关系,建议仍是在DAO外面手动保留,装载和更新

===================
另外还有一些办法,可以便利咱们疾速的将RS酿成可操作的对象,复杂举几个例子以下
1 commons dbutils
Custom RowProcessor
java.lang.Object[] toArray(java.sql.ResultSet rs)
          Convert a ResultSet row into an Object[].
java.lang.Object toBean(java.sql.ResultSet rs, java.lang.Class type)
          Convert a ResultSet row into a JavaBean.
java.util.List toBeanList(java.sql.ResultSet rs, java.lang.Class type)
          Convert a ResultSet into a List of JavaBeans.
java.util.Map toMap(java.sql.ResultSet rs)
          Convert a ResultSet row into a Map.

Custom BeanProcessor

java.lang.Object toBean(java.sql.ResultSet rs, java.lang.Class type)
          Convert a ResultSet row into a JavaBean.
java.util.List toBeanList(java.sql.ResultSet rs, java.lang.Class type)
          Convert a ResultSet into a List of JavaBeans.

2 commons beanutils
ResultSetDynaClass (Wraps ResultSet in DynaBeans)
Connection conn = ...;
Statement stmt = conn.createStatement();
ResultSet rs = stmt.executeQuery
    ("select account_id, name from customers");
Iterator rows = (new ResultSetDynaClass(rs)).iterator();
while (rows.hasNext()) {
    DynaBean row = (DynaBean) rows.next();
    System.out.println("Account number is " +
                     row.get("account_id") +
                     " and name is " + row.get("name"));
}
rs.close();
stmt.close();
============
总得来讲,利用反射机制可以极大得便利对数据的各类操作,使操作变得加倍通明,无需设置装备摆设文件


通过这段时间的学习实践,对软件开发有了更多新的认识,不在局限于之前的片面性。当然,现在所学到的东西其实并不多,离当一个真正的程序员,还有很大的差距。

柔情似水 发表于 2015-2-4 10:03:28

写的比较杂,因为我也是个新手,不当至于大家多多指正。

愤怒的大鸟 发表于 2015-2-9 22:03:39

其实也不算什么什么心得,在各位大侠算是小巫见大巫了吧,望大家不要见笑,若其中有错误的地方请各位大虾斧正。

活着的死人 发表于 2015-2-10 06:52:31

因为blog这样的可以让你接触更多要学的知识,可以接触用到类,模板,js ,ajax

简单生活 发表于 2015-2-28 23:54:22

,熟悉html,能用div+css,还有javascript,优先考虑linux。我在开始学习的时候,就想把这些知识一起学习,我天真的认为同时学习能够互相呼应,因为知识是相通的。

飘飘悠悠 发表于 2015-3-9 23:53:57

不禁又想起那些说php是草根语言的人,为什么认得差距这么大呢。

再见西城 发表于 2015-3-13 07:09:42

遇到出错的时候,我经常把错误信息直接复制到 google的搜索栏,一般情况都是能搜到结果的,不过有时候会搜出来一大片英文的出来,这时候就得过滤一下,吧中文的弄出来,挨着式方法。

海妖 发表于 2015-3-20 16:25:33

本人接触php时间不长,算是phper中的小菜鸟一只吧。由于刚开始学的时候没有名师指,碰过不少疙瘩,呗很多小问题卡过很久,白白浪费不少宝贵的时间,在次分享一些子的学习的心得。

分手快乐 发表于 2015-3-22 19:16:06

多看优秀程序员编写的代码,仔细理解他们解决问题的方法,对自身有很大的帮助。

谁可相欹 发表于 2015-3-26 19:23:14

作为一个合格的coder 编码的规范是必须,命名方面我推崇“驼峰法”,另外就是自己写的代码最好要带注释,不然时间长了,就算是自己的代码估计看起来都费事,更不用说别人拉。

老尸 发表于 2015-3-31 02:36:08

装在C盘下面可以利用windows的ghost功能可以还原回来(顺便当做是重转啦),当然啦我的编译目录要放在别的盘下,不然自己的劳动成果就悲剧啦。

兰色精灵 发表于 2015-4-1 20:10:07

使用zendstdio 写代码的的时候,把tab 的缩进设置成4个空格是很有必要的

山那边是海 发表于 2015-4-6 20:27:01

没接触过框架的人,也不用害怕,其实框架就是一种命名规范及插件,学会一个框架其余的框架都很好上手的。

莫相离 发表于 2015-4-7 15:44:23

建数据库表的时候,int型要输入长度的,其实是个摆设的输入几位都没影响的,只要大于4就行,囧。

若天明 发表于 2015-4-9 15:18:56

首推的搜索引擎当然是Google大神,其次我比较喜欢 百度知道。不过搜出来的结果往往都是 大家copy来copy去的,运气的的概率很大。

admin 发表于 2015-4-11 07:08:49

本人接触php时间不长,算是phper中的小菜鸟一只吧。由于刚开始学的时候没有名师指,碰过不少疙瘩,呗很多小问题卡过很久,白白浪费不少宝贵的时间,在次分享一些子的学习的心得。

冷月葬花魂 发表于 2015-4-15 03:07:57

先学习php和mysql,还有css(html语言很简单)我认为现在的效果比以前的方法好。

第二个灵魂 发表于 2015-4-15 21:20:53

要进行开发,搭建环境是首先需要做的事,windows下面我习惯把环境那个安装在C盘下面,因为我配的环境经常出现诡异事件,什么事都没做环境有的时候就不能用啦。

精灵巫婆 发表于 2015-4-23 18:38:39

实践是检验自己会不会的真理。

只想知道 发表于 2015-4-29 17:32:26

基础有没有对学习php没有太大区别,关键是兴趣。
页: [1] 2
查看完整版本: PHP教程之J2EE中几种面向对象的数据库映照会见策...