这里我们介绍ClickHouse的基本语法,使用环境是腾讯云的ClickHouse。默认情况下,ClickHouse 在进行集群纬度执行建表等 DDL 操作时需要手动添加 ON CLUSTER XXX 语法。
下面我会介绍常用的语法 [其中 launch 为我们的数据库名]
我们创建一张广告点击表作为演示案例,点击表click的创建语句
CREATE TABLE click ON CLUSTER default_cluster (
id UInt64,
product_type UInt32,
channel_type String,
agent_name String,
advertiser_id String,
aid String,
request_id String,
imei String,
idfa String,
android_id String,
oaid String,
os String,
mac String,
ip String,
ts String,
callback_url String,
data String,
expire DateTime,
create_time date
)
ENGINE = MergeTree()
PARTITION BY toYYYYMM(create_time)
PRIMARY KEY id
ORDER BY id;
在ClickHouse中可以通过SHOW CREATE TABLE语法来生成建表语句,例如:
SHOW CREATE TABLE test_table
SHOW CREATE launch.click;
在ClickHouse中可以通过RENAME TABLE语法来修改表名语句,例如:
RENAME TABLE table_name TO table_name_new ON CLUSTER default_cluster;
RENAME TABLE click TO click_new ON CLUSTER default_cluster;
在ClickHouse中,可以使用DESCRIBE语法来查看表的结构,例如:
DESCRIBE table_name;
DESCRIBE launch.click;
修改表结构,添加一个新列:
ALTER TABLE table_name ADD COLUMN new_column_name type;
ALTER TABLE click ON CLUSTER default_cluster
ADD COLUMN channel_id String;
ALTER TABLE table_name [on cluster cluster_name]
comment COLUMN column_name "message"
ALTER TABLE click ON CLUSTER default_cluster
comment COLUMN create_time '创建时间';
删除表中的一个列:
ALTER TABLE table_name DROP COLUMN column_name;
ALTER TABLE click ON CLUSTER default_cluster
DROP COLUMN channel_id
修改某个列的数据类型:
ALTER TABLE table_name MODIFY COLUMN column_name new_type;
ALTER TABLE click ON CLUSTER default_cluster
MODIFY COLUMN create_time DateTime;
删除表语法格式:DROP TABLE table_name ;
DROP TABLE click ON CLUSTER default_cluster;
修改单条记录
修改表中指定记录的某个列的值
ALTER TABLE table_name UPDATE column_name = new_value WHERE condition;
ALTER TABLE click
UPDATE agent_name ='xm' where id = 271494392
批量修改记录
批量修改表中的多条记录:
ALTER TABLE table_name UPDATE column_name = new_value WHERE condition;
ALTER TABLE table_name DELETE WHERE condition;
ALTER TABLE click
DELETE where id = 271494392
select * from click_cost
where create_time>='2024-01-16' and create_time<'2024-01-17'
and toFloat32(cost) > 0.01
ClickHouse中的修改操作主要是通过重写表数据来完成的,而不是更新原始数据。这也意味着点击修改操作会带来较大的性能损失,特别是在大表上的修改会极大地影响性能。因此,尽量避免在ClickHouse上进行大量更新操作。
内容是《Web前端开发之Javascript视频》的课件,请配合大师哥《Javascript》视频课程学习。
为了方便构建表格,HTML DOM为表格专门创建了HTMLTableElement 接口;其继承自HTMLElement接口;
该接口提供了专门的属性和方法来处理表格的布局与呈现;
HTMLTableElement接口属性:
var table = document.getElementsByTagName("table")[0];
console.log(table.caption);
console.log(table.tHead);
console.log(table.tBodies);
console.log(table.tFoot);
console.log(table.rows);
console.log(table.rows[0]);
console.log(table.rows[table.rows.length-1]);
另外,HTMLTableElement对象还拥有一些表现性的属性,但这些属性已建议不被使用,因为可以使用CSS来指定样式,如;
以上属性除了summary,都可以使用CSS进行定义,所以尽量不要再使用;
HTMLTableElement接口方法:
createCaption():返回表格元素的标题,如该表没有标题,这个方法创建并返回标题,随后可以使用其他方法对其添加内容;
deleteCaption():移除表格元素的<caption>;
var table = document.getElementsByTagName("table")[0];
// 也可以创建一个,并添加到DOM树中
var table = document.createElement("table");
document.body.appendChild(table);
var caption = table.createCaption();
caption.innerHTML = "Web前端开发课程";
table.deleteCaption();
createTHead():返回表元素的tHead对象,如果表元素中没有<thead>,则创建并返回;注意:如果不存在<thead>,该方法创建<thead>并直接插入表中;
deleteTHead():移除表元素中的<thead>;
var thead = table.createTHead(); // 如果不存在,则创建
console.log(thead);
var row = thead.insertRow(0);
row.insertCell(0);
row.insertCell(1);
row.insertCell(2);
table.deleteTHead();
createTFoot():返回表元素的tHead对象,如果表元素中没有<thead>,则创建并返回;
deleteTFoot():移除表元素中的<tfoot>;
var tfoot = table.createTFoot();
console.log(tfoot);
var row = tfoot.insertRow(0);
row.insertCell(0);
row.insertCell(1);
row.insertCell(2);
table.deleteTFoot();
createTBody()方法:创建并返回表元素的<tbody>;
注意:与createTHead()、createTFoot()方法的不同的是,createTBody()可以创建多个<tbody>元素,新创建的<tbody>在最后位置;
新创建的<tbody>元素会被保存到tBodies集合中;
var tbody = table.createTBody();
console.log(tbody);
var row = tbody.insertRow(0);
row.insertCell(0);
row.insertCell(1);
row.insertCell(2);
console.log(table.tBodies);
insertRow(index):向rows集合中在指定位置插入行;即在表元素中index位置插入新行<tr>,并返回对该新行的类型为HTMLTableRowElement对象;
table及tbody都可以调用该方法;
如果一个表有多个<tbody>元素,默认情况下,新行将插入到最后的<tbody>;
var row = table.insertRow(0); // 第一行
console.log(row);
table.insertRow(); // 最后一行
table.insertRow(-1); // 最后一行
table.insertRow(table.rows.length); // 最后一行
// 如果存在第二个<body>,并且指定的index=4位于该<body>中,则在此处添加
table.insertRow(4);
console.log(table.rows);
要将行插入特定的<tbody>,先取得该<tbody>对象,再使用该对象执行insertRow()方法;但index不能超过此<tbody>的索引下界;
var tbody = table.tBodies[0];
tbody.insertRow(); // 在第一个<body>的最后添加新行
tbody.insertRow(table.rows.length); // 异常
deleteRow(index):删除指定位置的行;如果 index 值为 -1,最后一行会被移除;
table.deleteRow(1);
var tbody = table.tBodies[1];
tbody.deleteRow(1);
HTMLTableRowElement接口对象:
该类型表示表格中的一行(<tr>),它定义了若干操作当前行的属性和方法;
rowIndex属性:返回该行在整个表中的逻辑位置,即索引,如果该行不属于表,则返回-1;
var row = table.rows[1];
console.log(row.rowIndex); // 1
var tbody = table.tBodies[1];
var row = tbody.rows[1];
console.log(row.rowIndex); // 4
sectionRowIndex属性:返回该行在所属部分(如<thead>、<tbody>和<tfoot>部分)中的逻辑位置,如果该行不属于某部分,则返回-1;
var row = table.rows[1];
console.log(row.sectionRowIndex); // 1
var tbody = table.tBodies[1];
var row = tbody.rows[1];
console.log(row.sectionRowIndex); // 1
cells:返回某个行中的所有单元格的HTMLCollection集合;该集合中保存着类型为HTMLTableCellElement的cell对象;
var row = table.rows[1];
console.log(row.cells); // HTMLCollection
console.log(row.cells[0]);
insertCell(index):向cells集合中的指定位置插入一个单元格,即在<tr>的index位置插入<td>,返回对新插入单元格的引用;如果index值为空或者为-1或者等于当前行中单元格的数目,则新的单元格将被追加到当前行的最后;
插入的新Cell对象,可以使用其他DOM方法添加子元素或内容;
var row = table.insertRow(-1);
var cell1 = row.insertCell(0);
cell1.appendChild(document.createTextNode("4"));
var cell2 = row.insertCell(1);
cell2.innerHTML = "Web开发";
该方法不能创建<th>元素,如果需要创建<th>,必须使用document.createElement()方法及Node.insertBefore()或相关的方法来创建和插入<th>元素;
deleteCell(index):删除行中给定位置的单元格;
row.deleteCell(0);
HTMLTableCellElement接口:
表示表元素中的单元格,包括<th>及<td>元素;其继承自HTMLElement接口;
var row = table.insertRow();
var cell = row.insertCell();
cell.innerHTML = "Web前端开发";
console.log(cell.cellIndex); // 0
cell.colSpan = "3"; // 跨3列
var cell = table.rows[1].cells[1];
cell.rowSpan = 2; // 跨行
table.rows[2].deleteCell(2);
使用这些属性和方法,可以极大地减少创建表格所需的代码量,如:
var table = document.createElement("table");
table.border = "1";
table.width = "600px";
var caption = table.createCaption();
caption.innerHTML = "Web前端开发课程";
var thead = table.createTHead();
var row = thead.insertRow();
var th1 = document.createElement("th");
th1.appendChild(document.createTextNode("序号"));
row.appendChild(th1);
var th2 = document.createElement("th");
th2.appendChild(document.createTextNode("课程"));
row.appendChild(th2);
var tbody = table.createTBody();
tbody.insertRow();
tbody.rows[0].insertCell();
tbody.rows[0].cells[0].appendChild(document.createTextNode("1"));
tbody.rows[0].insertCell();
tbody.rows[0].cells[1].appendChild(document.createTextNode("HTML"));
tbody.insertRow();
tbody.rows[1].insertCell();
tbody.rows[1].cells[0].appendChild(document.createTextNode("2"));
tbody.rows[1].insertCell();
tbody.rows[1].cells[1].appendChild(document.createTextNode("CSS"));
var tfoot = table.createTFoot();
tfoot.insertRow();
var cell = tfoot.rows[0].insertCell();
cell.colSpan = 2;
cell.align = "right";
cell.innerHTML = "由大师哥王唯主讲";
document.body.appendChild(table);
生成简单的空表格:
<style>
#mytable{width: 400px; border: 1px solid lightgreen;}
#mytable td{padding: .5em; border: 1px solid lightgreen;}
</style>
<script>
function MyTable(id, caption, rows, cols){
this.id = id ? id : "table";
this.caption = caption ? caption : undefined;
this.rows = rows ? rows : 2;
this.cols = cols ? cols : 2;
var table = document.createElement("table");
table.id = this.id;
if(this.caption){
var _caption = table.createCaption();
_caption.innerText = this.caption;
}
for(var i=0; i<this.rows; i++){
var _rows = table.insertRow();
for(var j = 0; j < this.cols; j++){
var _cell = _rows.insertCell();
_cell.appendChild(document.createTextNode(""));
}
}
return table;
}
var t = new MyTable("mytable","我的表格",4,3);
document.body.appendChild(t);
</script>
控制台表格:
console.table(data [, columns])方法:
将数据以表格的形式显示;这个方法需要一个必须参数data,data必须是一个数组或者是一个对象;
它会把数据data以表格的形式打印出来,数组中的每一个元素(或对象中可枚举的属性)将会以行的形式显示在表格中;
// 打印一个由字符串组成的数组
console.table(["HTML","CSS","Javascript"]);
表格的第一列是index,如果数据data是一个数组,那么这一列的单元格的值就是数组的索引,如果数据是一个对象,那么它们的值就是各对象的属性名称;;
// 打印一个属性值是字符串的对象
function Person(firstName, lastName){
this.firstName = firstName;
this.lastName = lastName;
}
var p = new Person("王","唯");
console.table(p);
打印复合的参数类型:
如果需要打印的元素在一个数组中,或者需要打印的属性在一个对象,并且他们本身就是一个数组或者对象,则将会把这个元素显示在同一行,每个元素的成员占一列;
// 二元数组的打印
var people = [["wang","wei"],["jing","jing"],["juan","zi"]];
console.table(people);
// 打印一个包含对象的数组
var wang = new Person("王","唯");
var jing = new Person("静","静");
var juan = new Person("娟","子");
// 如果数组中包含该对象,打印出来的列标签将是该对象的属性名
console.table([wang, jing, juan]);
// 打印属性名是对象的对象
var family = {};
family.mother = jing;
family.father = wang;
family.daughter = juan;
console.table(family);
选择要隐藏的列:
console.table()会把所有元素罗列在每一列,可以使用columns参数选择要显示的列的子集;其是一个包含列的名称的数组;
// 一个对象数组,只打印 firstName
console.table([wang, jing, juan],"firstName");
按列重新排序:
可以点击每列的顶部标签来重排输出的表格;
Web前端开发之Javascript-零点程序员-王唯
击鼠标这个操作,相信很多职场人都非常的熟悉。我们可以用它来快速打开某个程序。不会真的有人打开程序,还是点一下鼠标左键然后再点一下鼠标右键吧!效率太低了!
在Excel中双击鼠标的作用非常多,大多数都是一些小功能,但是却可以快速的提高我们的工作效率,今天就跟大家分享几个Excel比较实用的双击小技巧吧
想要学习Excel,这里↑↑↑↑
选中一个格式后,双击格式刷,就能锁定格式刷,这样的话就能快速设置多个区域的格式,只有按下ESC键,才会退出格式刷
公式输入完毕后,把鼠标放在单元格的右下角,鼠标就会变为一个黑色的十字,这个时候双击下,就能快速地填充公式,再也不用一行一行的拖动了。
首先在单元格中输入1跟2,然后选择1跟2,将鼠标放在2这个单元格的右下角,当鼠标变为黑色十字,直接双击填充即可快速设置序号
首先点击列标号然后选择序号的整列数据,随后将鼠标放在两列之间的位置,鼠标变为左右方向的黑色箭头,直接双击下,就会将表格调整为合适的列宽
与上一个操作类似,只需根据列标号来选择数据,随后将鼠标放在两行之间,鼠标会变成一个上下方向的黑色箭头,直接双击下即可。
双击Sheet名称,就能快速的更改Sheet名称,再也不用点击鼠标右键来一步一步的更改的。
只需将鼠标放在隐藏区域的行标号或者列标号处,这样的话鼠标就会变为上下或者左右的黑色箭头,只需双击一下,就能快速的取消隐藏的数据
功能区显示状态下,我们只需双击任意一个功能组名称(在这里双击开始)就能将功能组隐藏掉,再次双击工作组名称,隐藏的功能区就会显示出来了
全屏状态下双击Excel最上面的右侧区域,就能快速的将Excel缩小,再次双击这个位置,Excel就会又变为全屏显示
双击Excel的左上角,就能快速的调出Excel的关闭界面,这个感觉作用不是太大,聊胜于无吧~
双击Excel公式,被公式引用的单元格就会被设置颜色,就能快速看出公式引用了哪些单元格,
Excel图表的元素还是比较多的,我们想要设置那一部分,就直接在其上方双击鼠标,就能在右侧显示它对应的设置窗口,还是非常方便的。
以上就是今天分享的12个Excel中双击的小技巧,你还知道哪些实用的双击小技巧呢?可以留言讨论哦~
我是Excel从零到一,关注我,持续分享更多Excel技巧
*请认真填写需求信息,我们会在24小时内与您取得联系。