
在 vue 项目中,使用 clickhouse js 进行增删改查可以分为以下几个步骤:
25175企业客户管理系统能够方便的录入新的信息例如新的项目、新增客户等同时能够清楚的管理一些款项结算。由于功能的强大,用户可以在该系统上发表文章后让员工递交工作计划或工作报告。加强企业工作效率,为企业提高实力。因为该系统可由客户、程序员、负责人等身份登入 所以适合广大企业使用。管理首页:{信息录入|信息修改|信息查询}1信息录入:你可以根据实际情况进行以下操作 1-1新的项目
- 安装 clickhouse js
npm install clickhouse-js
- 封装一个数据库访问层
// clickhouse.js
import { client } from 'clickhouse-js';
class clickhouse {
constructor(config) {
this.client = new client(config);
}
async query(sql) {
return this.client.query(sql);
}
async insert(table, data) {
const sql = `insert into ${table} (${object.keys(data).join(', ')}) values (${object.values(data).map(() => '?').join(', ')})`;
return this.client.query(sql, object.values(data));
}
async update(table, data, where) {
const sql = `update ${table} set ${object.keys(data).map(key => `${key} = ?`).join(', ')} where ${where}`;
return this.client.query(sql, [...object.values(data)]);
}
async delete(table, where) {
const sql = `delete from ${table} where ${where}`;
return this.client.query(sql);
}
}- 在 vue 组件中使用
import ClickHouse from '@/clickhouse';
export default {
data() {
return {
clickHouse: new ClickHouse({host: 'localhost', port: '8123', database: 'test'})
}
},
methods: {
async query() {
const result = await this.clickHouse.query('SELECT * FROM test');
console.log(result);
},
async insert() {
const result = await this.clickHouse.insert('test', {name: 'John Doe', age: 30});
console.log(result);
},
async update() {
const result = await this.clickHouse.update('test', {name: 'Jane Doe'}, 'id = 1');
console.log(result);
},
async delete() {
const result = await this.clickHouse.delete('test', 'id = 1');
console.log(result);
},
}
}









