百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

Node.js 学习笔记:使用数据库

liuian 2025-03-13 17:17 41 浏览

这部分示例将示范SQLite3、MongoDB这两种不同类型的数据库在 Node.js 中的使用方法。首先,我们要在code目录下执行mkdir 06_database命令来创建用于存放这一组示例的目录。

1. SQLite

SQLite3是一个轻量级的关系型数据库,我们在这里用它来示范 Node.js 对关系型数据库的处理。首先,在code/06_database目录下执行mkdir sqlite命令,并执行以下步骤:

  1. 在code/06_database/sqlite目录下执行npm install sqlite3命令,将sqlite3安装到当前示例项目中。
  2. 为控制程序按串行方式执行,需在code/06_database/sqlite目录下执行npm install async命令,将async包安装到当前示例项目中。
  3. 在code/06_database/sqlite目录下执行touch Sqlite.js,创建一个脚本文件,具体如下:
const fs = require('fs')
const sqlite3 = require('sqlite3').verbose()

class SqliteDB {
constructor(file) {
this.db = new sqlite3.Database(file)
const db_exist = fs.existsSync(file)

if ( !db_exist ) {
console.error('数据库文件创建成功!')
fs.openSync(file, 'w')
}
}

createTable(sql) {
this.db.serialize(function() {
this.run(sql, function(err) {
if( err !== null ) {
return console.error('错误信息:' + err.message)
}
})
})
}

insertData(sql, objects) {
this.db.serialize(function() {
const stmt = this.prepare(sql)
for ( let i = 0; i < objects.length; ++i ) {
stmt.run(objects[i])
}

stmt.finalize()
})
}

queryData(sql, callback, message) {
this.db.all(sql, function(err, rows) {
if( err !== null ) {
return console.error('错误信息:' + err.message)
}

if( callback ) {
callback(rows, message)
}
})
}

executeSql(sql) {
this.db.run(sql, function(err) {
if( err !== null ) {
return console.error('错误信息:' + err.message)
}
})
}

close() {
this.db.close()
}
}

module.exports = SqliteDB

4、在code/06_database/sqlite目录下执行touch useSqlite.js,创建一个脚本文件,具体如下:

const async = require('async')
const SqliteDB = require('./Sqlite')
const file = "HRDB.db"
const sqliteDB = new SqliteDB(file)

function dataDeal(objects, message) {
console.log(message)
for ( const i = 0; i < objects.length; ++i ) {
console.log(objects[i])
}
}

async.waterfall([
function (callback) {
// 创建表格
const createTableSql = `
create table if not exists HR_TABLE (
name TEXT,
age TEXT,
sex TEXT,
items TEXT
);`
sqliteDB.createTable(createTableSql)
callback()
},

function (callback) {
// 插入数据
const insertTileSql = `
insert into HR_TABLE
(name, age, sex, items)
values(?, ?, ?, ?)`
const arr = [
['凌杰', '24', '男', '看书, 看电影, 旅游'],
['蔓儿', '25', '女', '看书, 看电影, 写作'],
['张语', '32', '女', '看书, 旅游, 绘画']
]
sqliteDB.insertData(insertTileSql, arr)
callback()
},

function (callback) {
// 查询数据
const querySql = 'select * from HR_TABLE'
sqliteDB.queryData(querySql, dataDeal, '初始数据')
callback()
},

function (callback) {
// 更新数据
const updateSql = `update HR_TABLE set age = 37 where name = "凌杰"`
sqliteDB.executeSql(updateSql)
callback()
},

function (callback) {
// 查询更新后的数据
querySql = `select * from HR_TABLE`
sqliteDB.queryData(querySql, dataDeal, '更新后数据')
callback()
},

function (callback) {
sqliteDB.close()
callback()
}
])

5、保存所有文件后,在code/06_database/sqlite目录下执行node useSqlite.js命令,结果如下:

2. MongoDB

MongoDB是非关系型数据库的一个典型代表,我们在这里用它来示范 Node.js 对关系型数据库的处理。在 Node.js 中操作MongoDB数据库有两个扩展包可以选择,下面我们一一来演示。首先,在code/06_database目录下执行mkdir mongodb命令,并执行以下步骤:

使用mongodb包

  1. 在code/06_database/mongodb目录下执行npm install mongodb命令,将mongodb包安装到当前示例项目中。
  2. 为控制程序按串行方式执行,需在code/06_database/mongodb目录下执行npm install async命令,将async包安装到当前示例项目中。
  3. 在code/06_database/mongodb目录下执行touch useMongodb.js,创建一个脚本文件,具体如下:
 const MongoClient = require('mongodb').MongoClient
const async = require('async')
const server = 'mongodb://localhost:27017'
const dbName = 'hrdb'
const collName = 'hr_table'
const dbPath = server + '/' + dbName

MongoClient.connect(dbPath, { useNewUrlParser: true },
function(err, db) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}

const dbo = db.db(dbName)
console.log(dbName + '数据库创建成功')

const collect = dbo.collection(collName)
console.log(collName + '集合创建成功')

async.series([
// 控制程序串行执行

function (callback) {
// 插入单条数据
const data = {
name : '杨过',
age : '42',
sex : '男',
items : '看书, 喝酒, 习武'
}

collect.insertOne(data, function(err, res) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
console.log('单条数据插入成功')
})
callback()
},

function (callback) {
// 插入多条数据
const dataArray = [
{
name : '小龙女',
age : '24',
sex : '男',
items : '看书, 唱歌, 习武'
},
{
name : '郭靖',
age : '52',
sex : '男',
items : '看书, 喝酒, 习武'
},
{
name : '黄蓉',
age : '45',
sex : '女',
items : '看书, 绘画, 习武'
},
{
name : '雅典娜',
age : '24',
sex : '女',
items : '看书, 音乐, 被救'
}
]

collect.insertMany(dataArray, function(err, res) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
console.log('数组插入成功')
})
callback()
},

function (callback) {
// 列出所有数据
collect. find({}).toArray(function(err, result) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
console.log('列出当前集合中的所有数据:')
console.log(result)
})
callback()
},

function (callback) {
// 更新单一数据
const whereData = {'name' : '小龙女'}
const updataValue = { $set: { 'sex' : '女' } }
collect.updateOne(whereData, updataValue,
function(err, res) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
console.log(whereData['name'] + "的数据更新成功")
})
callback()
},

function (callback) {
// 查询指定数据
const querystr = { 'name' : '小龙女' }
collect. find(querystr).toArray(function(err, result) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
console.log('查看更新后的' + querystr['name'] + '的数据:')
console.log(result)
})
callback()
},

function (callback) {
// 删除指定单一数据
const whereData = { 'name' : '黄蓉' }
collect.deleteOne(whereData,function(err, result) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
console.log(whereData['name'] + '的数据已被删除')
})
callback()
},

function (callback) {
// 查询所有数据,并按name降序排列
const isort = { name : -1 }
collect. find({}).sort(isort).toArray(function(err, result) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
console.log('降序排列当前集合中的所有数据:')
console.log(result)
})
callback()
},

function (callback) {
// 删除指定多条数据
const whereData = { 'age' : '24' }
collect.deleteMany(whereData,function(err, result) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
console.log('年龄为' + whereData['age'] + '的数据已被删除')
})
callback()
},

function (callback) {
// 查询所有数据,并按name升序排列
const isort = { name : 1 }
collect. find({}).sort(isort).toArray(function(err, result) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
console.log('升序排列当前集合中的所有数据:')
console.log(result)
})
callback()
},

function (callback) {
// 删除指定集合
dbo.dropCollection(collName, function(err, delOK) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
if ( delOK !== null ) {
console.log(collName + "集合已删除!")
}
})
callback()
}
])

db.close()
})

4、保存所有文件后,在code/06_database/mongodb目录下执行node useMongodb.js命令,结果如下:

使用mongoose包

  1. 在code/06_database/mongodb目录下执行npm install mongoose命令,将mongoose包安装到当前示例项目中。
  2. 在code/06_database/mongodb目录下执行touch useMongoose.js,创建一个脚本文件,具体如下:
const server = 'mongodb://localhost:27017'
const dbName = 'hrdb'
const collName = 'hr_table'
const dbPath = server + '/' + dbName
const mongoose = require('mongoose');
const async = require('async')
const Schema = mongoose.Schema
const hrSchema = new Schema({
name : {
type : String,
required: true
},
age : {
type : String,
required: true
},
sex : {
type : String,
required: true
},
items : {
type : String,
required: true
}
})
const hrModel = new mongoose.model('Hrobj', hrSchema)
mongoose.connect(dbPath, {useNewUrlParser: true});
const conn = mongoose.connection
conn.on('error', console.error.bind(console, '连接错误:'))
conn.on('open', console.log.bind(console, '数据库连接成功'))
conn.on('disconnected', console.log.bind(console, '断开数据库连接'))

conn.once('open', function(){
async.series([
function(callback) {
// 插入单条数据
const someone = new hrModel ({
name : '杨过',
age : '42',
sex : '男',
items : '看书, 喝酒, 习武'
})
someone.save(function(err, one){
callback(err, one.name+'的数据插入成功')
})
},

function(callback) {
hrModel.find(function(err, hrTable){
callback(err, '插入一条数据后的结果:' + hrTable)
})
},

function(callback) {
// 插入多条数据
const dataArray = [
{
name : '小龙女',
age : '24',
sex : '男',
items : '看书, 唱歌, 习武'
},
{
name : '郭靖',
age : '52',
sex : '男',
items : '看书, 喝酒, 习武'
},
{
name : '黄蓉',
age : '45',
sex : '女',
items : '看书, 绘画, 习武'
},
{
name : '雅典娜',
age : '24',
sex : '女',
items : '看书, 音乐, 被救'
},
{
name : '阿波罗',
age : '24',
sex : '女',
items : '看书, 音乐, 被救'
}
]

hrModel.insertMany(dataArray, function(err) {
callback(err, '数组中的数据插入成功')
})
},

function(callback) {
hrModel.find(function(err, hrTable){
callback(err, '插入多条数据后的结果:' + hrTable)
})
},

function(callback) {
hrModel.updateMany({sex:'男'}, {sex:'女'}, function(err, one){
callback(err, '将所有男人改为女人')
})
},

function(callback) {
hrModel.updateOne({name:'阿波罗'}, {sex:'男'}, function(err, one){
callback(err, '将阿波罗的性别改为:男')
})
},

function(callback) {
hrModel.find({age:'24'}, function(err, hrTable){
callback(err, '所有年龄为24的数据:' + hrTable)
})
},

function(callback) {
hrModel.findOne({age:'24'}, function(err, hrTable){
callback(err, '第一个年龄为24的结果:' + hrTable)
})
},

function(callback) {
hrModel.deleteMany({age:'24'}, function(err, hrTable){
callback(err, '所有年龄为24数据已被删除')
})
},

function(callback) {
hrModel.find({age:'24'}, function(err, hrTable){
callback(err, '所有年龄为24的数据:' + hrTable)
})
},

function(callback) {
hrModel.deleteMany({}, function(err, hrTable){
callback(err, '所有数据已被删除')
})
},

function(callback) {
hrModel.find(function(err, hrTable){
callback(err, '删除所有数据后的结果:' + hrTable)
})
},

function(callback) {
mongoose.disconnect(function(err){
callback(err, '正在断开连接……')
})
}
], function(err, message) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
console.log(message)
})
})

3、保存所有文件后,在code/06_database/mongodb目录下执行node useMongoose.js命令,结果如下:

如果图片重复显示或者内容重复显示影响阅读,请访问:
https://www.cnblogs.com/owlman/p/13588513.html

这部分示例将示范SQLite3、MongoDB这两种不同类型的数据库在 Node.js 中的使用方法。首先,我们要在code目录下执行mkdir 06_database命令来创建用于存放这一组示例的目录。

1. SQLite

SQLite3是一个轻量级的关系型数据库,我们在这里用它来示范 Node.js 对关系型数据库的处理。首先,在code/06_database目录下执行mkdir sqlite命令,并执行以下步骤:

  1. 在code/06_database/sqlite目录下执行npm install sqlite3命令,将sqlite3安装到当前示例项目中。
  2. 为控制程序按串行方式执行,需在code/06_database/sqlite目录下执行npm install async命令,将async包安装到当前示例项目中。
  3. 在code/06_database/sqlite目录下执行touch Sqlite.js,创建一个脚本文件,具体如下:
const fs = require('fs')
const sqlite3 = require('sqlite3').verbose()

class SqliteDB {
constructor(file) {
this.db = new sqlite3.Database(file)
const db_exist = fs.existsSync(file)

if ( !db_exist ) {
console.error('数据库文件创建成功!')
fs.openSync(file, 'w')
}
}

createTable(sql) {
this.db.serialize(function() {
this.run(sql, function(err) {
if( err !== null ) {
return console.error('错误信息:' + err.message)
}
})
})
}

insertData(sql, objects) {
this.db.serialize(function() {
const stmt = this.prepare(sql)
for ( let i = 0; i < objects.length; ++i ) {
stmt.run(objects[i])
}

stmt.finalize()
})
}

queryData(sql, callback, message) {
this.db.all(sql, function(err, rows) {
if( err !== null ) {
return console.error('错误信息:' + err.message)
}

if( callback ) {
callback(rows, message)
}
})
}

executeSql(sql) {
this.db.run(sql, function(err) {
if( err !== null ) {
return console.error('错误信息:' + err.message)
}
})
}

close() {
this.db.close()
}
}

module.exports = SqliteDB

4、在code/06_database/sqlite目录下执行touch useSqlite.js,创建一个脚本文件,具体如下:

const async = require('async')
const SqliteDB = require('./Sqlite')
const file = "HRDB.db"
const sqliteDB = new SqliteDB(file)

function dataDeal(objects, message) {
console.log(message)
for ( const i = 0; i < objects.length; ++i ) {
console.log(objects[i])
}
}

async.waterfall([
function (callback) {
// 创建表格
const createTableSql = `
create table if not exists HR_TABLE (
name TEXT,
age TEXT,
sex TEXT,
items TEXT
);`
sqliteDB.createTable(createTableSql)
callback()
},

function (callback) {
// 插入数据
const insertTileSql = `
insert into HR_TABLE
(name, age, sex, items)
values(?, ?, ?, ?)`
const arr = [
['凌杰', '24', '男', '看书, 看电影, 旅游'],
['蔓儿', '25', '女', '看书, 看电影, 写作'],
['张语', '32', '女', '看书, 旅游, 绘画']
]
sqliteDB.insertData(insertTileSql, arr)
callback()
},

function (callback) {
// 查询数据
const querySql = 'select * from HR_TABLE'
sqliteDB.queryData(querySql, dataDeal, '初始数据')
callback()
},

function (callback) {
// 更新数据
const updateSql = `update HR_TABLE set age = 37 where name = "凌杰"`
sqliteDB.executeSql(updateSql)
callback()
},

function (callback) {
// 查询更新后的数据
querySql = `select * from HR_TABLE`
sqliteDB.queryData(querySql, dataDeal, '更新后数据')
callback()
},

function (callback) {
sqliteDB.close()
callback()
}
])

5、保存所有文件后,在code/06_database/sqlite目录下执行node useSqlite.js命令,结果如下:

2. MongoDB

MongoDB是非关系型数据库的一个典型代表,我们在这里用它来示范 Node.js 对关系型数据库的处理。在 Node.js 中操作MongoDB数据库有两个扩展包可以选择,下面我们一一来演示。首先,在code/06_database目录下执行mkdir mongodb命令,并执行以下步骤:

使用mongodb包

  1. 在code/06_database/mongodb目录下执行npm install mongodb命令,将mongodb包安装到当前示例项目中。
  2. 为控制程序按串行方式执行,需在code/06_database/mongodb目录下执行npm install async命令,将async包安装到当前示例项目中。
  3. 在code/06_database/mongodb目录下执行touch useMongodb.js,创建一个脚本文件,具体如下:
 const MongoClient = require('mongodb').MongoClient
const async = require('async')
const server = 'mongodb://localhost:27017'
const dbName = 'hrdb'
const collName = 'hr_table'
const dbPath = server + '/' + dbName

MongoClient.connect(dbPath, { useNewUrlParser: true },
function(err, db) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}

const dbo = db.db(dbName)
console.log(dbName + '数据库创建成功')

const collect = dbo.collection(collName)
console.log(collName + '集合创建成功')

async.series([
// 控制程序串行执行

function (callback) {
// 插入单条数据
const data = {
name : '杨过',
age : '42',
sex : '男',
items : '看书, 喝酒, 习武'
}

collect.insertOne(data, function(err, res) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
console.log('单条数据插入成功')
})
callback()
},

function (callback) {
// 插入多条数据
const dataArray = [
{
name : '小龙女',
age : '24',
sex : '男',
items : '看书, 唱歌, 习武'
},
{
name : '郭靖',
age : '52',
sex : '男',
items : '看书, 喝酒, 习武'
},
{
name : '黄蓉',
age : '45',
sex : '女',
items : '看书, 绘画, 习武'
},
{
name : '雅典娜',
age : '24',
sex : '女',
items : '看书, 音乐, 被救'
}
]

collect.insertMany(dataArray, function(err, res) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
console.log('数组插入成功')
})
callback()
},

function (callback) {
// 列出所有数据
collect. find({}).toArray(function(err, result) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
console.log('列出当前集合中的所有数据:')
console.log(result)
})
callback()
},

function (callback) {
// 更新单一数据
const whereData = {'name' : '小龙女'}
const updataValue = { $set: { 'sex' : '女' } }
collect.updateOne(whereData, updataValue,
function(err, res) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
console.log(whereData['name'] + "的数据更新成功")
})
callback()
},

function (callback) {
// 查询指定数据
const querystr = { 'name' : '小龙女' }
collect. find(querystr).toArray(function(err, result) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
console.log('查看更新后的' + querystr['name'] + '的数据:')
console.log(result)
})
callback()
},

function (callback) {
// 删除指定单一数据
const whereData = { 'name' : '黄蓉' }
collect.deleteOne(whereData,function(err, result) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
console.log(whereData['name'] + '的数据已被删除')
})
callback()
},

function (callback) {
// 查询所有数据,并按name降序排列
const isort = { name : -1 }
collect. find({}).sort(isort).toArray(function(err, result) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
console.log('降序排列当前集合中的所有数据:')
console.log(result)
})
callback()
},

function (callback) {
// 删除指定多条数据
const whereData = { 'age' : '24' }
collect.deleteMany(whereData,function(err, result) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
console.log('年龄为' + whereData['age'] + '的数据已被删除')
})
callback()
},

function (callback) {
// 查询所有数据,并按name升序排列
const isort = { name : 1 }
collect. find({}).sort(isort).toArray(function(err, result) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
console.log('升序排列当前集合中的所有数据:')
console.log(result)
})
callback()
},

function (callback) {
// 删除指定集合
dbo.dropCollection(collName, function(err, delOK) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
if ( delOK !== null ) {
console.log(collName + "集合已删除!")
}
})
callback()
}
])

db.close()
})

4、保存所有文件后,在code/06_database/mongodb目录下执行node useMongodb.js命令,结果如下:

使用mongoose包

  1. 在code/06_database/mongodb目录下执行npm install mongoose命令,将mongoose包安装到当前示例项目中。
  2. 在code/06_database/mongodb目录下执行touch useMongoose.js,创建一个脚本文件,具体如下:
const server = 'mongodb://localhost:27017'
const dbName = 'hrdb'
const collName = 'hr_table'
const dbPath = server + '/' + dbName
const mongoose = require('mongoose');
const async = require('async')
const Schema = mongoose.Schema
const hrSchema = new Schema({
name : {
type : String,
required: true
},
age : {
type : String,
required: true
},
sex : {
type : String,
required: true
},
items : {
type : String,
required: true
}
})
const hrModel = new mongoose.model('Hrobj', hrSchema)
mongoose.connect(dbPath, {useNewUrlParser: true});
const conn = mongoose.connection
conn.on('error', console.error.bind(console, '连接错误:'))
conn.on('open', console.log.bind(console, '数据库连接成功'))
conn.on('disconnected', console.log.bind(console, '断开数据库连接'))

conn.once('open', function(){
async.series([
function(callback) {
// 插入单条数据
const someone = new hrModel ({
name : '杨过',
age : '42',
sex : '男',
items : '看书, 喝酒, 习武'
})
someone.save(function(err, one){
callback(err, one.name+'的数据插入成功')
})
},

function(callback) {
hrModel.find(function(err, hrTable){
callback(err, '插入一条数据后的结果:' + hrTable)
})
},

function(callback) {
// 插入多条数据
const dataArray = [
{
name : '小龙女',
age : '24',
sex : '男',
items : '看书, 唱歌, 习武'
},
{
name : '郭靖',
age : '52',
sex : '男',
items : '看书, 喝酒, 习武'
},
{
name : '黄蓉',
age : '45',
sex : '女',
items : '看书, 绘画, 习武'
},
{
name : '雅典娜',
age : '24',
sex : '女',
items : '看书, 音乐, 被救'
},
{
name : '阿波罗',
age : '24',
sex : '女',
items : '看书, 音乐, 被救'
}
]

hrModel.insertMany(dataArray, function(err) {
callback(err, '数组中的数据插入成功')
})
},

function(callback) {
hrModel.find(function(err, hrTable){
callback(err, '插入多条数据后的结果:' + hrTable)
})
},

function(callback) {
hrModel.updateMany({sex:'男'}, {sex:'女'}, function(err, one){
callback(err, '将所有男人改为女人')
})
},

function(callback) {
hrModel.updateOne({name:'阿波罗'}, {sex:'男'}, function(err, one){
callback(err, '将阿波罗的性别改为:男')
})
},

function(callback) {
hrModel.find({age:'24'}, function(err, hrTable){
callback(err, '所有年龄为24的数据:' + hrTable)
})
},

function(callback) {
hrModel.findOne({age:'24'}, function(err, hrTable){
callback(err, '第一个年龄为24的结果:' + hrTable)
})
},

function(callback) {
hrModel.deleteMany({age:'24'}, function(err, hrTable){
callback(err, '所有年龄为24数据已被删除')
})
},

function(callback) {
hrModel.find({age:'24'}, function(err, hrTable){
callback(err, '所有年龄为24的数据:' + hrTable)
})
},

function(callback) {
hrModel.deleteMany({}, function(err, hrTable){
callback(err, '所有数据已被删除')
})
},

function(callback) {
hrModel.find(function(err, hrTable){
callback(err, '删除所有数据后的结果:' + hrTable)
})
},

function(callback) {
mongoose.disconnect(function(err){
callback(err, '正在断开连接……')
})
}
], function(err, message) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
console.log(message)
})
})

3、保存所有文件后,在code/06_database/mongodb目录下执行node useMongoose.js命令,结果如下:

相关推荐

驱动网卡(怎么从新驱动网卡)
驱动网卡(怎么从新驱动网卡)

网卡一般是指为电脑主机提供有线无线网络功能的适配器。而网卡驱动指的就是电脑连接识别这些网卡型号的桥梁。网卡只有打上了网卡驱动才能正常使用。并不是说所有的网卡一插到电脑上面就能进行数据传输了,他都需要里面芯片组的驱动文件才能支持他进行数据传输...

2026-01-30 00:37 liuian

win10更新助手装系统(微软win10更新助手)

1、点击首页“系统升级”的按钮,给出弹框,告诉用户需要上传IMEI码才能使用升级服务。同时给出同意和取消按钮。华为手机助手2、点击同意,则进入到“系统升级”功能华为手机助手华为手机助手3、在检测界面,...

windows11专业版密钥最新(windows11专业版激活码永久)

 Windows11专业版的正版密钥,我们是对windows的激活所必备的工具。该密钥我们可以通过微软商城或者通过计算机的硬件供应商去购买获得。获得了windows11专业版的正版密钥后,我...

手机删过的软件恢复(手机删除过的软件怎么恢复)
手机删过的软件恢复(手机删除过的软件怎么恢复)

操作步骤:1、首先,我们需要先打开手机。然后在许多图标中找到带有[文件管理]文本的图标,然后单击“文件管理”进入页面。2、进入页面后,我们将在顶部看到一行文本:手机,最新信息,文档,视频,图片,音乐,收藏,最后是我们正在寻找的[更多],单击...

2026-01-29 23:55 liuian

一键ghost手动备份系统步骤(一键ghost 备份)

  步骤1、首先把装有一键GHOST装系统的U盘插在电脑上,然后打开电脑马上按F2或DEL键入BIOS界面,然后就选择BOOT打USDHDD模式选择好,然后按F10键保存,电脑就会马上重启。  步骤...

怎么创建局域网(怎么创建局域网打游戏)

  1、购买路由器一台。进入路由器把dhcp功能打开  2、购买一台交换机。从路由器lan端口拉出一条网线查到交换机的任意一个端口上。  3、两台以上电脑。从交换机任意端口拉出网线插到电脑上(电脑设置...

精灵驱动器官方下载(精灵驱动手机版下载)

是的。驱动精灵是一款集驱动管理和硬件检测于一体的、专业级的驱动管理和维护工具。驱动精灵为用户提供驱动备份、恢复、安装、删除、在线更新等实用功能。1、全新驱动精灵2012引擎,大幅提升硬件和驱动辨识能力...

一键还原系统步骤(一键还原系统有哪些)

1、首先需要下载安装一下Windows一键还原程序,在安装程序窗口中,点击“下一步”,弹出“用户许可协议”窗口,选择“我同意该许可协议的条款”,并点击“下一步”。  2、在弹出的“准备安装”窗口中,可...

电脑加速器哪个好(电脑加速器哪款好)

我认为pp加速器最好用,飞速土豆太懒,急速酷六根本不工作。pp加速器什么网页都加速,太任劳任怨了!以上是个人观点,具体性能请自己试。ps:我家电脑性能很好。迅游加速盒子是可以加速电脑的。因为有过之...

任何u盘都可以做启动盘吗(u盘必须做成启动盘才能装系统吗)

是的,需要注意,U盘的大小要在4G以上,最好是8G以上,因为启动盘里面需要装系统,内存小的话,不能用来安装系统。内存卡或者U盘或者移动硬盘都可以用来做启动盘安装系统。普通的U盘就可以,不过最好U盘...

u盘怎么恢复文件(u盘文件恢复的方法)

开360安全卫士,点击上面的“功能大全”。点击文件恢复然后点击“数据”下的“文件恢复”功能。选择驱动接着选择需要恢复的驱动,选择接入的U盘。点击开始扫描选好就点击中间的“开始扫描”,开始扫描U盘数据。...

系统虚拟内存太低怎么办(系统虚拟内存占用过高什么原因)

1.检查系统虚拟内存使用情况,如果发现有大量的空闲内存,可以尝试释放一些不必要的进程,以释放内存空间。2.如果系统虚拟内存使用率较高,可以尝试增加系统虚拟内存的大小,以便更多的应用程序可以使用更多...

剪贴板权限设置方法(剪贴板访问权限)
剪贴板权限设置方法(剪贴板访问权限)

1、首先打开iphone手机,触碰并按住单词或图像直到显示选择选项。2、其次,然后选取“拷贝”或“剪贴板”。3、勾选需要的“权限”,最后选择开启,即可完成苹果剪贴板权限设置。仅参考1.打开苹果手机设置按钮,点击【通用】。2.点击【键盘】,再...

2026-01-29 21:37 liuian

平板系统重装大师(平板重装win系统)

如果你的平板开不了机,但可以连接上电脑,那就能好办,楼主下载安装个平板刷机王到你的个人电脑上,然后连接你的平板,平板刷机王会自动识别你的平板,平板刷机王上有你平板的我刷机包,楼主点击下载一个,下载完成...

联想官网售后服务网点(联想官网售后服务热线)

联想3c服务中心是联想旗下的官方售后,是基于互联网O2O模式开发的全新服务平台。可以为终端用户提供多品牌手机、电脑以及其他3C类产品的维修、保养和保险服务。根据客户需求层次,联想服务针对个人及家庭客户...