面向对象chapter12

使用jdbc步骤
  a.导入数据库厂商提供的驱动程序(导入jar包)
  b.加载驱动程序
  Class.forName("驱动程序类");
  c.获得连接
  Connection conn =DriverManager.getConnection(url,username,password);
  url = "jdbc:数据库://ip地址:端口;数据库";
  username="用户名";
  password="密码";
  d.获得执行sql对象,执行sql返回结果
  Statement stat = conn.createStatement();
  ResultSet rs = stat.executeQuery("sql语句");
  e.处理结果集
  while(rs.next()){
  Xxxx s = rs.getXxxx("字段名|数字");
  }
  注意数据下标从1开始
  f.释放资源
  rs.close();
  stat.close();
  conn.close();

public class Test1 {
    private static Logger logger = Logger.getLogger(Test1.class.getName());
    public static void main(String[] args) {
        Connection conn = null;
        //1.加载驱动
        try {
            Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");
        } catch (ClassNotFoundException e) {
            logger.error(e);
        }
        //2.建立连接
        try{
        conn = DriverManager.getConnection("jdbc:sqlserver://localhost:1433;DatabaseName=epet","sa","sa");
        System.out.println("建立连接成功");
        }catch(SQLException e){
            logger.error(e);
        }finally{
            //3.关闭连接
            try{
                if(null!= conn){
                    conn.close();
                    System.out.println("关闭连接成功");
                }
            }catch(SQLException e){
                    logger.error(e);
        }

    }

    }
}
public class Test2 {

    public static void main(String[] args) {
        try {
            Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");
            String url = "jdbc:sqlserver://localhost:1433;databaseName = schoolDB";
            String username = "sa";
            String password = "sa";
            int deptno = 200;
            String dname = "ww";
            String loc = "dd";
            Connection conn =DriverManager.getConnection(url,username,password);
            Statement stat = conn.createStatement();
//增加        String sql = "insert into DEPT(DEPTNO,dname,LOC)values(800,‘szb‘,‘yiyang‘)";
//修改        String sql1 = "update DEPT set dname =‘szb7‘ where DEPTNO = 800";
//删除        String sql2="delete from dept where deptno=800";
            String sql3= "insert into DEPT(DEPTNO,dname,LOC)values(?,?,?)";
            PreparedStatement pst = conn.prepareStatement(sql3);
            pst.setInt(1, deptno);
            pst.setString(2, dname);
            pst.setString(3, loc);
            pst.executeUpdate();
//            stat.executeUpdate(sql3);
            stat.close();
            conn.close();
        } catch (ClassNotFoundException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }catch(SQLException e){
            e.printStackTrace();
        }

    }

}

Dao层步骤
        第一步:建表
        第二步:实体类
        第三步:写接口(需求)
        第四步:帮助类(BaseDao)(只需写一次)
        第五步:实现类

表--->实体类--->dao--->biz--->controller

serializable 序列化接口
              序列化         接口+实现
                   接口+实现

2.MVC思想
        1.model:模型层
        2.view:视图层
        3.controller:控制层
        4.业务层:biz,server
          dao层
       
        分包:
            Dao
            Biz
            Controller
            view  (Test)
            entity
            utils

时间: 2024-10-17 23:06:15

面向对象chapter12的相关文章

python学习 面向对象封装

from collectoins import namedtuplePoint=namedtuple('point',['x','y'])t1=Point(1,2)print(t1.x)print(t1.y)没有方法的类属性不会发生变化    定义简单 不能改变面向对象封装私有属性!!!私有方法!!!用装饰器描述的几个方法@property !!!@classmethod!!@staticmethod! 封装:class Teacher:     def __init__(self,name,p

python—面向对象的封装

封装 私有属性 class Teacher: __identifier = 'Teacher' #私有静态属性 def __init__(self,name,pwd) self.name = name self.__pwd = pwd #私有属性 内部使用,外部不能使用 def pwd(self): print(self.__pwd) alex = Teacher('alex','3714') alex.pwd() class Teacher: __identifier = 'Teacher'

python学习_day26_面向对象之封装

1.私有属性 (1)动态属性 在python中用双下划线开头的方式将属性隐藏起来.类中所有双下划线开头的名称,如__x都会自动变形成:_类名__x的形式.这种自动变形的特点是: a.类中定义的__x只能在内部使用,如self.__x,引用的就是变形的结果.b.这种变形其实正是针对外部的变形,在外部是无法通过__x这个名字访问到的.c.在子类定义的__x不会覆盖在父类定义的__x,因为子类中变形成了:_子类名__x,而父类中变形成了:_父类名__x,即双下滑线开头的属性在继承给子类时,子类是无法覆

python面向对象知识点疏理

面向对象技术简介 类: 用来描述具有相同的属性和方法的对象的集合.它定义了该集合中每个对象所共有的属性和方法.对象是类的实例.class 类变量:类变量在整个实例化的对象中是公用的.类变量定义在类中且在函数体之外.类变量通常不作为实例变量使用. 数据成员:类变量或者实例变量用于处理类及其实例对象的相关的数据. 方法重写:如果从父类继承的方法不能满足子类的需求,可以对其进行改写,这个过程叫方法的覆盖,也称为方法的重写. 实例变量:定义在方法中的变量,只作用于当前实例的类. 继承:即一个派生类(de

php学习笔记 面向对象中[接口]与[多态性]的应用

代码如下: <?php /* 接口技术 * * 接口是一种特殊的抽象类,抽象类又是一种特殊的类 * * 接口和抽象类是一样的作用 * * 因为在PHP是单继承的,如果使用抽象类,子类实现抽象类就不能再去继承其他的类了 * * 如果既想实现一些规范,又想继承其他类.就要使用接口. * * 接口和抽象类的对比 * * 1.作用相同,都不能创建对象,都需要子类去实现 * * 2.接口的声明和抽象类不一样 * * 3.接口被实现方式不一样 * * 4.接口中的所有方法必须是抽象方法,只能声明抽象方法(不

php面向对象

面向对象 什么是面向对象? 面向对象编程(Object Oriented Programming, OOP, 面向对象程序设计)是一种计算机编程架构,OOP的一条基本原则是计算机程 序是由单个能够起到子程序作用的单元或对象组合而成,OOP达到了软件工程的三个目标:重用性.灵活性和扩展性.为了实现整体 运算,每个对象都能够接收信息.处理数据和向其它对象发送信息. 什么是面向对象编程呢? 把每个独立的功能模块抽象成类形成 对象,由多个对象组成这个系统,这些对象之间都能够接收信息.处理数据和向其它对象

面向对象注意事项

在面向对象中,有实例变量和类变量,实例变量为类对象的实例成员,而类变量不仅类可以直接调用,而且类的对象也可以调用.类对象可以对实例变量进行添加.修改.删除操作等... 下面就用个示例来做参考: #!/usr/bin/env python # -*- coding:utf-8 -*- class PersonInfo(object): commity_data = 123 def __init__(self,name,age): self.name = name self.age = age de

java面向对象:面向对象的思想和概述

1:面向对象思想 面向对象是基于面向过程的编程思想. 面向过程:强调的是每一个功能的步骤 面向对象:强调的是对象,然后由对象去调用功能 2:面向对象的思想特点 A:是一种更符合我们思想习惯的思想 B:可以将复杂的事情简单化 C:将我们从执行者变成了指挥者 开发,设计,特征 面向对象开发 就是不断的创建对象,使用对象,指挥对象做事情. 面向对象设计 其实就是在管理和维护对象之间的关系. 面向对象特征 封装(encapsulation) 继承(inheritance) 多态(polymorphism

6 面向对象之类和对象

1 面向对象和面向过程的区别 两者都是软件开发思想,先有面向过程,后有面向对象.在大型项目中,针对面向过程的不足推出了面向对象开发思想. 区别: 1)编程思路不同: 面向过程以实现功能的函数开发为主,而面向对象要首先抽象出类.属性及其方法,然后通过实例化类.执行方法来完成功能. 2)封装性:都具有封装性,但是面向过程是封装的是功能,而面向对象封装的是数据和功能. 3)面向对象具有继承性和多态性,而面向过程没有继承性和多态性,所以面向对象优势是明显. 2 类和对象 对象:客观存在的实体(一个具体的