结局篇---SQL3.0中的行类型

    技术2022-05-19  20

    SQL3.0中的行类型

    Array,数组Sturct,结构Blob,大的二进制数据文件。Clob,大文本文件对象。在使用上述大对象的时候,在使用JDBC插入记录时要先插入一个空的占位对象,然后使用select blobdata from t_blob where id = " + id + " for update 这样的语法来对获得的大对象,进行实际的写入操作 Blod通过getBinaryOutputStream()方法获取流进行写入。getBinaryStream()方法获得流来获取blob中存储的数据。 clob的操作也和blob相同。getAsciiStream() 方法用于读取存储的文本对象,getAsciiOutputStream()方法之获得流用来向文件对象写入的。第四季一、ID的High/Low算法  高位数字分别与低位数字相匹配,得到的数字是唯一的  减少与数据库的交互

    二、ORM1、类映射成表  类名与表名对应2、属性定义映射成列,类型之间必须是兼容的3、类关系映射成表关系

    一对一双向关系内存中都保存对方的一个引用数据库中,表b的id是主键,也是外键,引用a表的id主键 -- share pk          表b中有一个字段aid是外键,引用a表的主键,并且有唯一约束  -- pk+fk共享主键:create table car_pk (    id number(10,0) not null,    name varchar2(15),    serial varchar2(30),    manufacturer varchar2(50),    producedate date,    primary key (id));

    create table engine_pk (    id number(10,0) not null,    model varchar2(20),    manufacturer varchar2(50),    producedate date,    primary key (id));

    alter table engine_pk     add constraint fk_engine_car_pk     foreign key (id)     references car_pk(id);    外键+唯一约束create table car_fk (    id number(10,0) not null,    name varchar2(15) not null,    serial varchar2(30) not null,    manufacturer varchar2(50) not null,    producedate date,    primary key (id));

    create table engine_fk (    id number(10,0) not null,    model varchar2(20) not null,    manufacturer varchar2(50) not null,    producedate date,    carid number(10,0) unique,    primary key (id));

    alter table engine_fk     add constraint fk_engine_car_fk     foreign key (carid)     references car_fk(id);                        实体对象:在内存中有id属性的值对象:没有id的,依赖其他对象存在

    一对多关系          一的一方保存多一方的一个集合,最好使用set,保证无重复元素多的一方保存一一方的一个对象的引用public class order implements Serializable{    private int id;    private String owner;    private String phone;    private String address;    private Set<Item> items = new HashSet<Item>();}public class Item implements Serializable{    private int id;    private String product;    private int amount;    private order order;    }   

    create table ec_item (    id number(10,0) not null,    product varchar2(15) not null,    amount number(10,0) not null,    orderid number(10,0) not null,    primary key (id));

    create table ec_order (    id number(10,0) not null,    owner varchar2(15) not null,    phone varchar2(15) not null,    address varchar2(50),    primary key (id));

    alter table ec_item     add constraint fk_item_order     foreign key (orderid)     references ec_order(id);        多对多双方都保存对方的多个引用例子:学生选课public class TarenaCourse implements Serializable{    private int id;    private String name;    private int period;    private Set<TarenaStudent> students = new HashSet<TarenaStudent>();    }public class TarenaStudent implements Serializable{    private int id;    private String name;    private Date birthday;    private Set<TarenaCourse> courses = new HashSet<TarenaCourse>();    }

    create table student (    id number(10,0) not null,    name varchar2(15) not null,    birthday date,    primary key (id));

    create table student_course (    sid number(10,0) not null,    cid number(10,0) not null,    primary key (sid, cid));

    create table course (    id number(10,0) not null,    name varchar2(15) not null,    perion number(10,0),    primary key (id));

    alter table student_course     add constraint fk_student    foreign key (sid)     references student(id);

    alter table student_course     add constraint fk_course     foreign key (cid)     references course(id);

    通过学生姓名找课程    select c.name from cource c,student s,student_course scwhere c.id=sc.cid and  s.id=sc.sid and s.name = 's1' 

    三、继承关系     public abstract class Computer implements Serializable{    private int id;    private int price;    private String manufacturer;}

    public class Desktop extends Computer{    private boolean isLCD;    }

    public class Notepad extends Computer{    private float weight;    private float thickness;    } 

    1、建3张表 table per class子类中保存父类的主键作为外键create table computer_tpc (    id number(10,0) not null,    price number(10,0) not null,    manufacturer varchar2(30) not null,    primary key (id));

    create table desktop_tpc (    computerid number(10,0) not null,    islcd char(1),    primary key (computerid));

    create table notepad_tpc (    computerid number(10,0) not null,    weight float,    thickness float,    primary key (computerid));

    alter table desktop_tpc     add constraint fk_desk_computer_tpc     foreign key (computerid)     references computer_tpc(id);

    alter table notepad_tpc     add constraint fk_note_computer_tpc     foreign key (computerid)     references computer_tpc(id);

    查找所有电脑的配制(只要是电脑就能被查出来)    select c.id,c.price,d.islcd,n.weight,n.thicknessfrom computer c, desktop d,notepad nwhere  c.id = d.computerid(+)and  c.id = n.computer(+)     2、建2张表      create table desktop (    id number(10,0) not null,    price number(10,0) not null,    manufacturer varchar2(30) not null,    islcd char(1),    primary key (id));

    create table notepad (    id number(10,0) not null,    price number(10,0) not null,    manufacturer varchar2(30) not null,    weight float,    thickness float,    primary key (id));

    3、建1张表create table computer_tph (    id number(10,0) not null,    category char(1) not null,    price number(10,0) not null,    manufacturer varchar2(30) not null,    islcd char(1),    weight float,    thickness float,    primary key (id));


    最新回复(0)