zoukankan      html  css  js  c++  java
  • TypeScript封装统一操作Mysql Mongodb Mssql的底层类库demo

    /*
    
    功能:定义一个操作数据库的库  支持 Mysql Mssql  MongoDb
    
    要求1:Mysql MsSql  MongoDb功能一样  都有 add  update  delete  get方法    
    
    注意:约束统一的规范、以及代码重用
    
    解决方案:需要约束规范所以要定义接口 ,需要代码重用所以用到泛型
    
        1、接口:在面向对象的编程中,接口是一种规范的定义,它定义了行为和动作的规范
    
        2、泛型 通俗理解:泛型就是解决 类 接口 方法的复用性、
    
    
    */
    
    interface DBI<T>{
        add(info:T):boolean;
        update(info:T,id:number):boolean;
        delete(id:number):boolean;
        get(id:number):any[];
    }
    
    //定义一个操作mysql数据库的类       注意:要实现泛型接口 这个类也应该是一个泛型类
    
    class MysqlDb<T> implements DBI<T>{
    
        constructor(){
    
            console.log('数据库建立连接');
        }
        add(info: T): boolean {
    
            console.log(info);
    
            return true;
           
        }    
        
        update(info: T, id: number): boolean {
            throw new Error("Method not implemented.");
        }
        delete(id: number): boolean {
            throw new Error("Method not implemented.");
        }
        get(id: number): any[] {
            var list=[
    
                {
                    title:'xxxx',
                    desc:'xxxxxxxxxx'
                },
                {
                    title:'xxxx',
                    desc:'xxxxxxxxxx'
                }
            ]
    
            return list;
        }
        
    }
    
    //定义一个操作mssql数据库的类  
    
    
    class MsSqlDb<T> implements DBI<T>{
    
        constructor(){
    
            console.log('数据库建立连接');
        }
        add(info: T): boolean {
            console.log(info);
            return true;
        }    
        update(info: T, id: number): boolean {
            throw new Error("Method not implemented.");
        }
        delete(id: number): boolean {
            throw new Error("Method not implemented.");
        }
        get(id: number): any[] {
           
    
            var list=[
    
                {
                    title:'xxxx',
                    desc:'xxxxxxxxxx'
                },
                {
                    title:'xxxx',
                    desc:'xxxxxxxxxx'
                }
            ]
    
            return list;
        }
    
    }
    
    //操作用户表   定义一个User类和数据表做映射
    
    /*
    
    class User{
        username:string | undefined;
        password:string | undefined;
    }
    
    
    var u=new User();
    u.username='张三111';
    u.password='123456';
    
    
    var oMysql=new MysqlDb<User>(); //类作为参数来约束数据传入的类型 
    oMysql.add(u);
    
    */
    
    
    
    class User{
        username:string | undefined;
        password:string | undefined;
    }
    
    
    var u=new User();
    u.username='张三2222';
    u.password='123456';
    
    var oMssql=new MsSqlDb<User>();
    oMssql.add(u);
    
    
    //获取User表 ID=4的数据
    var data=oMssql.get(4);
    console.log(data);
  • 相关阅读:
    欧拉路问题
    树上依赖背包总结
    树状数组的应用
    KMP
    深探树形dp
    再探树形dp
    日常水题
    深入hash
    同一控制下的企业合并,长期股权投资成本与支付账面之间的差额计入资本公积
    资本公积冲减留存收益
  • 原文地址:https://www.cnblogs.com/loaderman/p/11040594.html
Copyright © 2011-2022 走看看