当前位置: 首页 > news >正文

网站的建设初步定位wordpress页面修改密码

网站的建设初步定位,wordpress页面修改密码,苏州市建设培训网站安全员C类查询,小红书软文案例MongoDB核心 基础概念 数据库 数据库是按照数据结构来组织、存储和管理数据的仓库。在内存中运行的#xff0c;一旦程序运行结束或者计算机断电#xff0c;程序运行中的数据都会丢失。我们需要将一些程序运行的数据持久化到硬盘之中#xff0c;以确保数据的安全性。数据库…MongoDB核心 基础概念 数据库 数据库是按照数据结构来组织、存储和管理数据的仓库。在内存中运行的一旦程序运行结束或者计算机断电程序运行中的数据都会丢失。我们需要将一些程序运行的数据持久化到硬盘之中以确保数据的安全性。数据库就是数据持久化的最佳选择。数据库就是存储数据的仓库。 数据库分类 关系型数据库 MySQL、Oracle、DB2、SQL Server ······关系型数据库中全是表 非关系型数据库 MongoDB、 Redis ······键值对数据库 MongoDB MongoDB 是一个基于分布式文件存储的数据库.MongoDB 是为快速开发互联网 Web 应用而设计的数据库系统。MongoDB 的设计目标是极简、灵活、作为Web 应用栈的一部分。MongoDB 的数据模型是面向文档的所谓文档是一种类似于 JSON 的结构简单理解 MongoDB 这个数据库中存的是各种各样的JSON. (BSON) 在MongoDB中有三个重要概念 数据库 (database) 数据库是一个数据仓库数据库服务下可以创建多个数据库数居库中可以存放多个集合集合 (collection) 集合类似于 JS 中的数组在集合中可以存放很多文档文档 (document) 文档是数据库中的最小单位类似于 JS 中的对象 与JSON来对比 JSON文件数据库JSON中的一级数组集合数组中的对象文档  MongoDB Shell MongoDB Shell 是 MongoDB 提供的官方交互式界面允许用户与 MongoDB 数据库进行交互、执行命令和操作数据库。 MongoDB Shell 是基于 JavaScript 的允许用户直接在命令行或者脚本中使用 JavaScript 语言来操作 MongoDB 数据库。 安装完成后可以来使用 MongoDB Shell 连接到 MongoDB 数据库并执行操作。 数据库命令 1.显示所有数据库 show dbs 2. 切换到指定的数据库 use 数据库名 注如果数据库不存在会自动创建数据库。如果数据库内没有集合show dbs指令不会显示该数据库 3.显示当前所在的数据库 db 4. 删除当前数据库 use 库名db.dropDatabase () 集合命令 1. 创建集合 db.createCollection ( 集合名称 ) 2.显示当前数据库中的所有集合 show collections 3.删除某个集合 db. 集合名.drop 4.重命名集合 db.集合名.renameCollection(newName) 文档命令 1.插入文档 db. 集合名.insert (文档对象) 2.查询文档 db. 集合名.find (查询条件)例db.test.find({name:张三}) 注查询后结果中_id 是 mongodb 自动生成的唯一编号用来唯一标识文档 3. 更新文档 db. 集合名.update (查询条件新的文档)例db. test.update ({name: 张三 },{$set:{age:19}}) 注如果新文档不使用$set则会覆盖旧文档  4.删除文档 db. 集合名.remove (查询条件) Mongoose Mongoose简介 Mongoose http://www.mongoosejs.net是一个对象文档模型库 可以让我们使用代码来进行操作 mongodb 数据库 使用方法 连接数据库 首先需要安装Mongoose npm i mongoose //导入mongoose const mongoose require(mongoose);//连接数据库 mongodb://ip:端口/数据库名 mongoose.connect(mongodb://127.0.0.1:27017/test)//设置回调函数 //连接成功回调 mongoose.connection.once(open, () {console.log(数据库连接成功) })//连接失败回调 mongoose.connection.once(err, () {console.log(数据库调用失败); })//连接关闭回调 mongoose.connection.once(close, () {console.log(数据库连接关闭); })//开启定时器关闭链接 setTimeout(() {mongoose.disconnect() }, 3000) 创建文档结构对象和文档模型对象 //导入mongoose const mongoose require(mongoose)//链接数据库 mongoose.connect(mongodb://127.0.0.1:27017/dome)//创建文档结构对象 //该对象用于规定文档结构 let gameSchema new mongoose.Schema({name: String,price: Number })//创建文档模型对象 //该对象内封装方法用于操作数据库 //传参(集合名文档结构对象) let gameModel mongoose.model(games, gameSchema)//设置链接成功后的回调 mongoose.connection.once(open, () {console.log(数据库连接成功);testDocumentation() //调用封装好的方法进行增删改查 }) 字段值验证 Mongoose 有一些内建验证器可以对字段值进行验证 字段值验证在创建文档结构对象时进行 let personSchema new mongoose.Schema({name: {type: String,required: true //必填项},age: {type: Number,default: 18 //默认值},sex: {type: String,enum: [男, 女] //枚举值设置的值必须是数组中的},card: {type: Number,unique: true //唯一值新建集合才有效果} }) 添加文档增 添加文档可以使用文档模型对象中的create方法来添加批量添加可以使用insertMany方法 添加一条时传入参数为符合文档结构对象的对象 async function AddDocumentation() {//添加文档//使用文档模型对象中的create方法try {let add await gameModel.create({name: 艾尔登法环,price: 298})console.log(add);} catch (error) {console.log(error);}//关闭数据库mongoose.disconnect() } 添加多条传入数组数组内为符合文档结构对象的对象 //增加多条 async function AddDocumentationMany() {try {let add await gameModel.insertMany([{name: 无限机兵,price: 159},{name: 匹诺曹,price: 298}])console.log(add);} catch (err) {console.log(err);}//关闭数据库mongoose.disconnect() } 注Mongoose 6.x 版本之后的 API 变更。从 Mongoose 6 开始所有的异步操作如 Model.create()、find()、save() 等都不再支持回调函数而是强制使用 Promise 或 async/await 语法。 控制台输出 删除文档删 删除使用 deleteOne方法和deleteMany方法。 传入一个查询参数即可 deleteOne为单独删除 async function DeleteDocumentOne() {try {let Delete await gameModel.deleteOne({_id: 68522ffc56b9a48fd708b8fc})console.log(Delete);} catch (err) {console.log(err);}mongoose.disconnect() } deleteMany为批量删除 async function DeleteDocumentMany() {try {let Delete await gameModel.deleteMany({name: 黑暗之魂1})console.log(Delete);} catch (err) {console.log(err);}mongoose.disconnect() } 控制台输出 更新文档改 更新使用 updateOne方法和updateMany方法。 需要传入两个参数第一个为查询参数第二个为更新参数 该方法是直接在旧文档进行修改不存在新文档覆盖旧文档故不用$set updateOne为单独更新 async function UpdateDocumentOne() {try {let update await gameModel.updateOne({ _id: 68523020764ff87f3b7cabbd },{ name: 魂5 })console.log(update);} catch (err) {console.log(err);}mongoose.disconnect() } updateMany为批量更新 async function UpdateDocumentMany() {try {let update await gameModel.updateMany({ name: 黑暗之魂3 },{ price: 99 })console.log(update);} catch (err) {console.log(err);}mongoose.disconnect() }控制台输出  查询文档查 查询分为单独查询ID查询和批量查询 分别使用 findOne ( ) , findById ( ) , find ( ) 方法 单独查询需要传入查询参数ID查询需要传入ID批量查询传不传参数都可以 批量查询若不传参则为查询全部数据 单独查询 //查询一条数据 async function FindDocumentOne() {try {let find await gameModel.findOne({ name: 无限机兵 })console.log(find);} catch (err) {console.log(err);} } ID查询 //通过ID查询 async function FindDocumentID() {try {let find await gameModel.findById(6852817f3870d51a37a2df25)console.log(find);} catch (err) {console.log(err);} } 批量查询 //批量查询 async function FindDocumentMany() {try {let find await gameModel.find({ name: 魂5 })console.log(find);} catch (err) {console.log(err);} } 控制台输出 条件控制 在查询文档时我们可以设置查询的条件来获取我们想要的数据 运算符 在mongodb中不可以使用     等运算符需要使用相应的符号来替换 运算符代替符号$gt$lt$gte$lte!$ne 使用语法 { 属性名: { 运算符: 值 } }示例 let find01 await gameModel.find({ price: { $lt: 200 } }) 逻辑运算 运算符逻辑$or逻辑或$and逻辑与 使用语法 { 运算符: [{ 属性名: 值 }, { 属性名: 值 } ] }示例 let find02 await gameModel.find({ $or: [{ price: 298 }, { price: 99 }] }) 混合用法 let find03 await gameModel.find({ $or: [{ price: { $lt: 300 } }, { price: { $gt: 100 } }] }) 正则匹配 条件中可以直接使用正则匹配 let find04 await gameModel.find({ name:/魂/ })let find04 await gameModel.find({ name: new RegExp(魂) }) 个性化读取 字段筛选 在读取完文档后对象中的一部分数据并不一定是我们所需要的 可以通过字段筛选来获取我们想要的属性 语法 文档模型对象 . find ( ) . select ( {  属性名 : 0 , 属性名: 1 } ) 0:不要的字段    1:要的字段 //批量查询 async function FindDocumentMany() {try {let find01 await gameModel.find().select({ _id: 0, name: 1, price: 1 })console.log(find01);} catch (err) {console.log(err);}mongoose.disconnect() } 数据排序  根据规定属性值排序 语法 文档模型对象 . find ( ) . sort( {  属性名 : 0 / 1  } ) 0倒序  1正序 //批量查询 async function FindDocumentMany() {try {let find01 await gameModel.find().select({ _id: 0, name: 1, price: 1 }).sort({ price: 1 })console.log(find01);} catch (err) {console.log(err);}mongoose.disconnect() } 数据截取 从指定位置获取到指定数量的数据 语法 文档模型对象 . find ( ) . skip( 数字 )  //跳过几个数据 文档模型对象 . find ( ) . limit( 数字 )   //获取几个数据 //批量查询 async function FindDocumentMany() {try {let find01 await gameModel.find().select({ _id: 0, name: 1, price: 1 }).sort({ price: 1 }).skip(2).limit(3)console.log(find01);} catch (err) {console.log(err);}mongoose.disconnect() }
http://www.w-s-a.com/news/713874/

相关文章:

  • 手机测评做视频网站宝塔可以做二级域名网站么
  • 代理公司注册济南重庆seo优化效果好
  • 佛山市骏域网站建设专家徐州网站建设价格
  • 公司做网站多济南好的网站建设公司排名
  • 网站维护的方式有哪几种该网站在工信部的icp ip地址
  • 中小企业服务中心网站建设做考勤的网站
  • 大连网站建设报价wordpress实用功能
  • 学校网站建设自查报告电脑网站制作教程
  • 适合推广的网站世界搜索引擎公司排名
  • 合肥网站建设费用ppt在哪个软件制作
  • 湖南省住房和城乡建设厅门户网站网站建设课程性质
  • 如何设计公司网站公司网站空间要多大
  • 建筑公司网站排名5G网站建设要多少个
  • seo怎样新建网站弹簧东莞网站建设
  • 在线做爰直播网站石家庄房产
  • 建筑网站哪里找拓者设计吧首页
  • 广州网站的建设wordpress注册数学验证码
  • 装修平台自己做网站有几个黄页名录网站开发
  • php网站的安全优势平面设计师培训
  • 乐清市网站建设设计重庆沙坪坝区
  • 什么是seo站内优化开发网页的工具有哪些
  • 文化类网站是不是休闲娱乐类网站青州市建设局网站
  • 网站的中英文切换代码做现货黄金网站
  • 万江区网站建设公司前端如何根据ui设计写页面
  • 宿迁公司做网站手机免费创建网站的软件
  • 免费可商用素材网站山东威海网站开发
  • 建设网站什么语言比较合适柳州建设网经济适用房
  • 企业网站的主要功能板块平台推广是做什么的
  • 网页网站自做全搞定西安建设工程信息网诚信平台
  • 网站vip怎么做建网站外包公司