graphql 数据增删改查分页及关联操作(三)
说明:
- 接第二篇文章,代码也是在第二篇文章之上
- 本文只是针对mondodb来操作
一、添加相关的包
- yarn add Mongoose
二、初始化Mongodb
- 修改server.ts
- 导入 import * as Mongoose from 'mongoose';
- 添加了方法 mongodbInit()
- 全部代码如下 :
- import * as express from 'express';
- const { graphqlExpress, graphiqlExpress } = require('apollo-server-express')
- const expressPlayground = require('graphql-playground-middleware-express').default;
- import * as Mongoose from 'mongoose';
- var bodyParser = require('body-parser');
- import schema from './schema';
- class Server {
- public app: express.Application;
- constructor() {
- this.app = express();
- this.routes();
- this.mongodbInit();
- }
- private routes(): void {
- this.app.use('/graphql',bodyParser.json(), graphqlExpress({ schema }));
- this.app.get('/playground', expressPlayground({ endpoint: '/graphql' }));
- }
- private mongodbInit() {
- const MONGO_URI = "mongodb://localhost/gqlServer";
- Mongoose.connect(MONGO_URI || process.env.MONGO_URI);
- this.app.use(bodyParser.urlencoded({ extended: false }));
- this.app.use(bodyParser.json());
- }
- }
- export default new Server().app;
- import * as express from 'express';
三、修改user文件
- 添加user.ts代码如下:
- import { model, Schema, Document } from 'mongoose';
- export interface IUserModel extends Document {
- id:string,
- name: String,
- password: String,
- }
- let UserSchema: Schema = new Schema({
- name: String,
- password: String,
- createAt: {
- type: Date,
- default: new Date(),
- required: true
- },
- updateAt: {
- type: Date,
- default: new Date(),
- required: true
- },
- })
- export default model<IUserModel>('User', UserSchema);
- 修改resolver.ts代码如下:
- import UserSchema, { IUserModel } from './user';
- export class User {
- constructor() {
- }
- static Query: any = {
- getUsers(parent, { }, context) {
- return UserSchema.find();
- }
- }
- static Mutation: any = {
- saveUser(parent, { user }, context) {
- return UserSchema.create(user)
- }
- }
- }
四、运行项目 yarn start 打开地址http://localhost:8080/playground应该可以添加用户和查找用户了效果如下:
五、增删改查相关的方法可以自己去扩展
六、关联
- 添加角色文件夹role/role.gql,role/resolve,role/resolver.ts
- 代码基本可以复制user里面的代码改相关的名字
- 项目结构
- role.gql代码
- type Role{
- id:String
- roleName:String
- }
- extend type Query {
- # 查找所有角色
- getRoles: [Role]
- }
- extend type Mutation {
- # 创建角色| 修改角色
- saveRole(role:inputRole):Role
- }
- input inputRole{
- id:String
- roleName:String
- }
- type Role{
- role.ts代码
- import { model, Schema, Document } from 'mongoose';
- export interface IRoleModel extends Document {
- id:string,
- roleMame: String,
- }
- let RoleSchema: Schema = new Schema({
- roleMame: String,
- createAt: {
- type: Date,
- default: new Date(),
- required: true
- },
- updateAt: {
- type: Date,
- default: new Date(),
- required: true
- },
- })
- export default model<IRoleModel>('Role', RoleSchema);
- resolver.ts 代码
- import RoleSchema, { IRoleModel } from './role';
- export class Role {
- constructor() {
- }
- static Query: any = {
- getRoles(parent, { }, context) {
- return RoleSchema.find();
- }
- }
- static Mutation: any = {
- saveRole(parent, { role }, context) {
- return RoleSchema.create(role)
- }
- }
- }
- 导入resolver到resolvers.ts代码如下:
- import { User } from "./user/resolver";
- import { Role } from "./role/resolver";
- export default {
- Query: {
- ...User.Query,
- ...Role.Query
- },
- Mutation: {
- ...User.Mutation,
- ...Role.Mutation
- },
- };
- import { User } from "./user/resolver";
- 导入role.gql 到src/schema.ts 代码如下:
- import { makeExecutableSchema } from 'graphql-tools';
- import resolver from "./resolvers";
- var requireText = require('require-text');
- var Base = requireText('./base.gql', require);
- var User = requireText('./user/user.gql', require);
- var Role = requireText('./role/role.gql', require); //添加了角色
- //基础信息
- var typeDefs = [Base];
- typeDefs = typeDefs.concat(User);
- typeDefs = typeDefs.concat(Role);
- const schema = makeExecutableSchema({
- typeDefs: typeDefs,
- resolvers: resolver
- })
- export default schema;
- import { makeExecutableSchema } from 'graphql-tools';
- 运行可以看到相关表,尝试添加一个角色,和查找一下
七、关联用户与角色,基本关系,每一个用户有一个角色1对1
- 修改文件user.gql代码如下:
- type User{
- id:String
- name:String
- passwrod:String
- # 添加了role字段
- Role:Role
- }
- extend type Query {
- # 查找所有用户
- getUsers: [User]
- }
- extend type Mutation {
- # 创建用户|修改用户
- saveUser(user:inputUser):User
- }
- input inputUser{
- id:String
- name:String
- passwrod:String
- # 添加了roleid
- roleId:String
- }
- type User{
- 修改user.ts文件代码如下:
- import { model, Schema, Document } from 'mongoose';
- export interface IUserModel extends Document {
- id:string,
- name: String,
- passwrod: String,
- roleId: String,//只是添加了这里
- }
- let UserSchema: Schema = new Schema({
- name: String,
- passwrod: String,
- roleId: String, //只是添加了这里
- createAt: {
- type: Date,
- default: new Date(),
- required: true
- },
- updateAt: {
- type: Date,
- default: new Date(),
- required: true
- },
- })
- export default model<IUserModel>('User', UserSchema);
- 修改user/resolver.ts文件代码如下:
- import UserSchema, { IUserModel } from './user';
- import RoleSchema from '../role/role';
- export class User {
- constructor() {
- }
- //只是添加用户的角色
- static User: any = {
- Role(model) {
- return RoleSchema.findById(model.roleId);
- },
- }
- static Query: any = {
- getUsers(parent, { }, context) {
- return UserSchema.find();
- }
- }
- static Mutation: any = {
- saveUser(parent, { user }, context) {
- return UserSchema.create(user)
- }
- }
- }
- import UserSchema, { IUserModel } from './user';
- 导入用户角色到resolver.ts代码如下:
- import { User } from "./user/resolver";
- import { Role } from "./role/resolver";
- export default {
- Query: {
- ...User.Query,
- ...Role.Query
- },
- Mutation: {
- ...User.Mutation,
- ...Role.Mutation
- },
- User:User.User //只是添加了这一行
- };
- import { User } from "./user/resolver";
- 运行,添加一个角色,根据角色id添加用户,页面查询应该可以看到以下结果:
八,相关的增加修改删除分页代码参考下面代码:
- user.gql
- # 系统用户表
- type User {
- id: ID!
- # 用户登录名
- username: String
- # 姓名
- name: String
- # 邮件
- email:String
- # 密码
- password:String
- # 创建时间
- createAt:Date
- # 修改时间
- updateAt:Date
- #用户角色
- Role:Role
- #是否有效
- isValid:Boolean
- #用户资料
- Profile:Profile
- }
- extend type Query {
- # 查找所有用户
- getUsers: [User]
- # 根据ID查找用户
- getUserById(id:String):User
- # 分页查找
- getUserPage(pageIndex: Int, pageSize: Int,user:searchUser): [User]
- # 查找分页总数
- getUserCount(user:searchUser):Int
- # 根据条件查找
- getUserWhere(user:searchUser): [User]
- # 用户登录
- login (username:String!,password:String!): User
- # 用户退出
- logOut:Boolean,
- #当前登录用户
- currentUser:User
- }
- extend type Mutation {
- # 创建用户|修改用户
- saveUser(user:inputUser):User
- # 删除用户
- deleteUser(id:String):Boolean
- }
- input inputUser{
- id:String
- username: String
- name: String
- email:String
- password:String
- roleId:String
- profileId:String
- isValid:Boolean
- }
- input searchUser{
- username:Json
- roleId:Json
- email:Json
- name:Json
- }
- # 系统用户表
- resolver.ts
- import UserSchema, { IUserModel } from './user';
- import RoleSchema from '../role/role';
- import ProfileSchema from '../profile/profile';
- import { DocumentQuery, MongoosePromise } from 'mongoose';
- export class User {
- constructor() {
- }
- static User: any = {
- Role(model) {
- return RoleSchema.findById(model.roleId);
- },
- Profile(model) {
- return ProfileSchema.findOne({ userId: model.id });
- }
- }
- static Query: any = {
- getUsers(parent, __, context): Promise<Array<IUserModel>> {
- //if (!context.user) return null;
- let promise = new Promise<Array<IUserModel>>((resolve, reject) => {
- UserSchema.find().then(res => {
- resolve(res);
- }).catch(err => resolve(null));
- });
- return promise;
- },
- getUserById(parent, { id }, context): Promise<IUserModel> {
- //if (!context.user) return null;
- let promise = new Promise<IUserModel>((resolve, reject) => {
- UserSchema.findById(id).then(res => {
- resolve(res);
- }).catch(err => resolve(null));
- });
- return promise;
- },
- getUserPage(parent, { pageIndex = 1, pageSize = 10, user }, context) {
- //if (!context.user) return null;
- var skip = (pageIndex - 1) * pageSize
- var userInfo = UserSchema.find(user).skip(skip).limit(pageSize)
- return userInfo;
- },
- getUserWhere(parent, { user }, context) {
- //if (!context.user) return null;
- console.log(user);
- var users = UserSchema.find(user);
- return users;
- },
- getUserCount(parent, { user }, context) {
- //if (!context.user) return 0;
- var count = UserSchema.count(user);
- return count;
- },
- login(parent, { username, password }, context) {
- return new Promise<any>((resolve, reject) => {
- UserSchema.find({ username, password }).then(data => {
- if (data.length > 0) {
- var user=data[0];
- context.session.user = user;
- resolve(user);
- } else {
- context.session.user = null;
- resolve(null);
- }
- })
- })
- },
- logOut(parent, { }, context) {
- context.user = null;
- context.session.user = null;
- return true;
- },
- currentUser(parent, { }, context) {
- //if (!context.user) return null;
- let promise = new Promise<IUserModel>((resolve, reject) => {
- let user = context.user;
- if (user) {
- UserSchema.findById(user._id).then(res => {
- resolve(res);
- }).catch(err => resolve(null));
- } else {
- resolve(null);
- }
- });
- return promise;
- },
- }
- static Mutation: any = {
- saveUser(parent, { user }, context) {
- //正式运行时请取消注释
- // if (!context.user) return null;
- if (user.id && user.id != "0") {
- return new Promise<IUserModel>((resolve, reject) => {
- UserSchema.findByIdAndUpdate(user.id, user, (err, res) => {
- Object.assign(res, user);
- resolve(res);
- })
- });
- }
- return UserSchema.create(user)
- },
- deleteUser(parent, { id }, context): Promise<Boolean> {
- //if (!context.user) return null;
- let promise = new Promise<Boolean>((resolve, reject) => {
- UserSchema.findByIdAndRemove(id, (err, res) => {
- resolve(res != null)
- }).catch(err => reject(err));
- });
- return promise;
- }
- }
- }
- import UserSchema, { IUserModel } from './user';
graphql 数据增删改查分页及关联操作(三)的更多相关文章
- IOS-CoreData(增删改查、表关联、分页和模糊查询、多个数据库)
1>什么是CoreData Core Data是iOS5之后才出现的一个框架,它提供了对象-关系映射(ORM)的功能,即能够将OC对象转化成数据,保存在SQLite数据库文件中,也能够将保存在数 ...
- OracleHelper(对增删改查分页查询操作进行了面向对象的封装,对批量增删改操作的事务封装)
公司的一个新项目使用ASP.NET MVC开发,经理让我写个OracleHelper,我从网上找了一个比较全的OracleHelper类,缺点是查询的时候返回DataSet,数据增删改要写很多代码(当 ...
- salesforce 零基础开发入门学习(六)简单的数据增删改查页面的构建
VisualForce封装了很多的标签用来进行页面设计,本篇主要讲述简单的页面增删改查.使用的内容和设计到前台页面使用的标签相对简单,如果需要深入了解VF相关知识以及标签, 可以通过以下链接查看或下载 ...
- node-express项目的搭建并通过mongoose操作MongoDB实现增删改查分页排序(四)
最近写了一个用node来操作MongoDB完成增.删.改.查.排序.分页功能的示例,并且已经放在了服务器上地址:http://39.105.32.180:3333. Mongoose是在node.js ...
- 【转载】salesforce 零基础开发入门学习(六)简单的数据增删改查页面的构建
salesforce 零基础开发入门学习(六)简单的数据增删改查页面的构建 VisualForce封装了很多的标签用来进行页面设计,本篇主要讲述简单的页面增删改查.使用的内容和设计到前台页面使用的 ...
- C#操作Excel数据增删改查(转)
C#操作Excel数据增删改查. 首先创建ExcelDB.xlsx文件,并添加两张工作表. 工作表1: UserInfo表,字段:UserId.UserName.Age.Address.CreateT ...
- C#操作Excel数据增删改查示例
Excel数据增删改查我们可以使用c#进行操作,首先创建ExcelDB.xlsx文件,并添加两张工作表,接下按照下面的操作步骤即可 C#操作Excel数据增删改查. 首先创建ExcelDB.xlsx文 ...
- SpringMVC4+MyBatis3+SQLServer 2014 整合(包括增删改查分页)
前言 说起整合自然离开ssm,我本身并不太喜欢ORM,尤其是MyBatis,把SQL语句写在xml里,尤其是大SQL,可读性不高,出错也不容易排查. 开发环境 idea2016.SpringMVC4. ...
- C#在winform中操作数据库,实现数据增删改查
1.前言: 运行环境:VS2013+SQL2008+Windows10 程序界面预览: 使用的主要控件:dataGridview和menuStrip等. 2.功能具体介绍: 1.首先,我们要先实现基本 ...
随机推荐
- UVA11082 行列模型
行列二分图模型,行指向列即表示权重w[i][j] 避免零流的方法就是使下界为1 #include<bits/stdc++.h> #define rep(i,j,k) for(int i = ...
- android 快速开发框架
https://github.com/lipanquan/LPQRapidDevelopmentFramework 依赖LPQLibrary https://github.com/lipanquan/ ...
- WPF Canvas转换为位图 (RenderTargetBitmap)
使用 RenderTargetBitmap 的注意事项: 1. 要渲染的Canvas元素要放在Border元素内,并且此Border元素不能设置边框宽度(BorderThickness),不然生成的位 ...
- C语言变参函数的实现原理
1. 变参函数简单示例 #include <stdarg.h> #include <stdio.h> int Accumlate(int nr, ...) { ; ; va_l ...
- 一行CMD命令kill(杀)掉你的进程
查看进程 pi@raspberry:~ $ ps -ef | grep python3 UID PID PPID C STIME TTY TIME CMD pi 4678 4666 0 11:57 p ...
- ECharts基本设置
theme = { // 全图默认背景 // backgroundColor: ‘rgba(0,0,0,0)’, // 默认色板 color: ['#ff7f50','#87cefa','#da70d ...
- CESM部署安装环境和使用
平台信息 Description: CentOS Linux release 7.6.1810 (Core) 安装CESM 安装前提:(小提示:耗时较长,需要耐心)阅读原文 CentOS 7(检查:s ...
- JS 获取get请求方式的参数
//获取页面中的参数 name值参数名称(例如:http://localhost:8099/index.aspx?id=10,name则指的是id)function GetQueryString ...
- maya 安装不上
AUTODESK系列软件着实令人头疼,安装失败之后不能完全卸载!!!(比如maya,cad,3dsmax等).有时手动删除注册表重装之后还是会出现各种问题,每个版本的C++Runtime和.NET f ...
- 查询pthread库的函数
首先需要先安装pthread看的手册文档,然后用如下命令查询: man -k pthread