前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >16. Django 2.1.7 模型 - 条件查询 F对象 Q对象 聚合查询

16. Django 2.1.7 模型 - 条件查询 F对象 Q对象 聚合查询

作者头像
Devops海洋的渔夫
发布于 2022-01-17 01:57:29
发布于 2022-01-17 01:57:29
1.6K00
代码可运行
举报
文章被收录于专栏:Devops专栏Devops专栏
运行总次数:0
代码可运行

上一篇Django 2.1.7 模型 - 条件查询、模糊查询、空查询、比较查询、范围查询、日期查询讲述了关于Django模型的查询。

但是都是条件与常量的查询,以及单条件查询,那么本篇章来介绍F对象、Q对象、聚合查询等功能。

参考文献

https://docs.djangoproject.com/zh-hans/2.1/topics/db/queries/

F对象

之前的查询都是对象的属性与常量值比较,两个属性怎么比较呢? 先来看看已有的mysql数据,如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
mysql> select * from assetinfo_middlewareinfo;
+----+-----------+-------+-----------+-----------+----------------------------+----------------------------+
| id | name      | port  | server_id | is_delete | shelves_date               | update_time                |
+----+-----------+-------+-----------+-----------+----------------------------+----------------------------+
|  1 | memcached | 11211 |         1 |         1 | 2019-06-10 14:56:46.150556 | 2019-06-10 17:37:51.365155 |
|  2 | redis     |  6379 |         1 |         1 | 2019-06-10 14:56:46.150556 | 2019-06-10 17:38:20.712862 |
|  3 | nginx     |    80 |         2 |         1 | 2019-06-10 16:41:52.129517 | 2019-06-10 17:38:18.923155 |
|  4 | kafka     |  9092 |         2 |         1 | 2019-06-10 16:42:25.561732 | 2019-06-10 17:39:29.302349 |
|  5 | test      |   123 |         1 |         1 | 2019-06-10 17:05:16.632773 | 2019-06-10 17:05:16.632773 |
|  6 | test      |   123 |         1 |         1 | 2019-06-10 17:06:20.120658 | 2019-06-10 17:06:20.121656 |
|  7 | test      |   123 |         1 |         1 | 2019-06-10 17:06:43.193412 | 2019-06-10 17:06:43.193412 |
|  8 | test      |   123 |         1 |         1 | 2019-06-10 17:07:03.747395 | 2019-06-10 17:07:03.747395 |
|  9 | test      |   123 |         1 |         1 | 2019-06-10 17:08:43.372097 | 2019-06-10 17:08:43.372097 |
| 10 | test      |   123 |         1 |         1 | 2019-06-10 17:09:37.877019 | 2019-06-10 17:09:37.877019 |
| 11 | test      |   123 |         1 |         1 | 2019-06-10 17:11:45.403627 | 2019-06-10 17:11:45.403627 |
| 12 | mysql     |  3306 |         2 |         0 | 2019-06-10 17:12:12.558217 | 2019-06-10 17:12:12.558217 |
| 13 | mongodb   |  3388 |         2 |         1 | 2019-06-10 17:15:18.327729 | 2019-06-10 17:15:18.327729 |
| 14 | mongodb   |  3306 |         1 |         1 | 2019-06-11 14:01:24.003175 | 2019-06-11 14:06:14.525648 |
| 15 | test      |   123 |         1 |         0 | 2019-06-11 14:04:10.576241 | 2019-06-11 14:04:10.576241 |
| 16 | test      |  3306 |         1 |         0 | 2019-06-11 14:06:05.608006 | 2019-06-11 14:06:05.608006 |
+----+-----------+-------+-----------+-----------+----------------------------+----------------------------+
16 rows in set (0.00 sec)

可以看到上面的数据存在 shelves_date 与 update_time 不相等的情况,之前的常量比较SQL如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
mysql> select * from assetinfo_middlewareinfo where shelves_date > "2019-06-10 17:38:20.712862" ;
+----+---------+------+-----------+-----------+----------------------------+----------------------------+
| id | name    | port | server_id | is_delete | shelves_date               | update_time                |
+----+---------+------+-----------+-----------+----------------------------+----------------------------+
| 14 | mongodb | 3306 |         1 |         1 | 2019-06-11 14:01:24.003175 | 2019-06-11 14:06:14.525648 |
| 15 | test    |  123 |         1 |         0 | 2019-06-11 14:04:10.576241 | 2019-06-11 14:04:10.576241 |
| 16 | test    | 3306 |         1 |         0 | 2019-06-11 14:06:05.608006 | 2019-06-11 14:06:05.608006 |
+----+---------+------+-----------+-----------+----------------------------+----------------------------+
3 rows in set (0.00 sec)

mysql> 

那么如果需要使用 shelves_date 与 update_time 进行大小比较,如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
mysql> select * from assetinfo_middlewareinfo where shelves_date < update_time ;
+----+-----------+-------+-----------+-----------+----------------------------+----------------------------+
| id | name      | port  | server_id | is_delete | shelves_date               | update_time                |
+----+-----------+-------+-----------+-----------+----------------------------+----------------------------+
|  1 | memcached | 11211 |         1 |         1 | 2019-06-10 14:56:46.150556 | 2019-06-10 17:37:51.365155 |
|  2 | redis     |  6379 |         1 |         1 | 2019-06-10 14:56:46.150556 | 2019-06-10 17:38:20.712862 |
|  3 | nginx     |    80 |         2 |         1 | 2019-06-10 16:41:52.129517 | 2019-06-10 17:38:18.923155 |
|  4 | kafka     |  9092 |         2 |         1 | 2019-06-10 16:42:25.561732 | 2019-06-10 17:39:29.302349 |
|  6 | test      |   123 |         1 |         1 | 2019-06-10 17:06:20.120658 | 2019-06-10 17:06:20.121656 |
| 14 | mongodb   |  3306 |         1 |         1 | 2019-06-11 14:01:24.003175 | 2019-06-11 14:06:14.525648 |
+----+-----------+-------+-----------+-----------+----------------------------+----------------------------+
6 rows in set (0.00 sec)

mysql> 

那么这种SQL按照上一篇的内容是无法实现的,下面来介绍F对象来解决这个问题。

语法如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
F(属性名)

使用F对象需要导入库,如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
from django.db.models import F

下面使用模型来查询 shelves_date < update_time 的结果,如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
In [4]: from assetinfo.models import ServerInfo,MiddlewareInfo

In [5]: from django.db.models import F

In [6]: MiddlewareInfo.objects.filter( shelves_date__lt = F('update_time') )
Out[6]: <QuerySet [<MiddlewareInfo: MiddlewareInfo object (1)>, <MiddlewareInfo: MiddlewareInfo object (2)>, <MiddlewareInfo: MiddlewareInfo object (3)>, <MiddlewareInfo: Middlewar
eInfo object (4)>, <MiddlewareInfo: MiddlewareInfo object (6)>, <MiddlewareInfo: MiddlewareInfo object (14)>]>

In [7]: 

对应执行的SQL如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
2019-06-12T15:19:37.735397Z	   12 Query	SELECT `assetinfo_middlewareinfo`.`id`, `assetinfo_middlewareinfo`.`name`, `assetinfo_middlewareinfo`.`port`, `assetinfo_middlewareinfo`.`server_id`, `assetinfo_middlewareinfo`.`shelves_date`, `assetinfo_middlewareinfo`.`update_time`, `assetinfo_middlewareinfo`.`is_delete` FROM `assetinfo_middlewareinfo` WHERE `assetinfo_middlewareinfo`.`shelves_date` < (`assetinfo_middlewareinfo`.`update_time`)  LIMIT 21

可以看到最后的where条件是

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
`assetinfo_middlewareinfo`.`shelves_date` < (`assetinfo_middlewareinfo`.`update_time`)  LIMIT 21

那么如果对于比较的变量还要乘以2倍,例如:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
mysql> select * from assetinfo_middlewareinfo where shelves_date < (update_time*2) ;
+----+-----------+-------+-----------+-----------+----------------------------+----------------------------+
| id | name      | port  | server_id | is_delete | shelves_date               | update_time                |
+----+-----------+-------+-----------+-----------+----------------------------+----------------------------+
|  1 | memcached | 11211 |         1 |         1 | 2019-06-10 14:56:46.150556 | 2019-06-10 17:37:51.365155 |
|  2 | redis     |  6379 |         1 |         1 | 2019-06-10 14:56:46.150556 | 2019-06-10 17:38:20.712862 |
|  3 | nginx     |    80 |         2 |         1 | 2019-06-10 16:41:52.129517 | 2019-06-10 17:38:18.923155 |
|  4 | kafka     |  9092 |         2 |         1 | 2019-06-10 16:42:25.561732 | 2019-06-10 17:39:29.302349 |
|  5 | test      |   123 |         1 |         1 | 2019-06-10 17:05:16.632773 | 2019-06-10 17:05:16.632773 |
|  6 | test      |   123 |         1 |         1 | 2019-06-10 17:06:20.120658 | 2019-06-10 17:06:20.121656 |
|  7 | test      |   123 |         1 |         1 | 2019-06-10 17:06:43.193412 | 2019-06-10 17:06:43.193412 |
|  8 | test      |   123 |         1 |         1 | 2019-06-10 17:07:03.747395 | 2019-06-10 17:07:03.747395 |
|  9 | test      |   123 |         1 |         1 | 2019-06-10 17:08:43.372097 | 2019-06-10 17:08:43.372097 |
| 10 | test      |   123 |         1 |         1 | 2019-06-10 17:09:37.877019 | 2019-06-10 17:09:37.877019 |
| 11 | test      |   123 |         1 |         1 | 2019-06-10 17:11:45.403627 | 2019-06-10 17:11:45.403627 |
| 12 | mysql     |  3306 |         2 |         0 | 2019-06-10 17:12:12.558217 | 2019-06-10 17:12:12.558217 |
| 13 | mongodb   |  3388 |         2 |         1 | 2019-06-10 17:15:18.327729 | 2019-06-10 17:15:18.327729 |
| 14 | mongodb   |  3306 |         1 |         1 | 2019-06-11 14:01:24.003175 | 2019-06-11 14:06:14.525648 |
| 15 | test      |   123 |         1 |         0 | 2019-06-11 14:04:10.576241 | 2019-06-11 14:04:10.576241 |
| 16 | test      |  3306 |         1 |         0 | 2019-06-11 14:06:05.608006 | 2019-06-11 14:06:05.608006 |
+----+-----------+-------+-----------+-----------+----------------------------+----------------------------+
16 rows in set (0.00 sec)

使用模型的F对象也是可以直接乘以 2 倍处理的,如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
In [8]: MiddlewareInfo.objects.filter( shelves_date__lt = F('update_time') * 2 )
Out[8]: <QuerySet [<MiddlewareInfo: MiddlewareInfo object (1)>, <MiddlewareInfo: MiddlewareInfo object (2)>, <MiddlewareInfo: MiddlewareInfo object (3)>, <MiddlewareInfo: Middlewar
eInfo object (4)>, <MiddlewareInfo: MiddlewareInfo object (5)>, <MiddlewareInfo: MiddlewareInfo object (6)>, <MiddlewareInfo: MiddlewareInfo object (7)>, <MiddlewareInfo: Middlewar
eInfo object (8)>, <MiddlewareInfo: MiddlewareInfo object (9)>, <MiddlewareInfo: MiddlewareInfo object (10)>, <MiddlewareInfo: MiddlewareInfo object (11)>, <MiddlewareInfo: Middlew
areInfo object (12)>, <MiddlewareInfo: MiddlewareInfo object (13)>, <MiddlewareInfo: MiddlewareInfo object (14)>, <MiddlewareInfo: MiddlewareInfo object (15)>, <MiddlewareInfo: Mid
dlewareInfo object (16)>]>

对应的SQL语句如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
2019-06-12T15:26:57.158671Z	   12 Query	SELECT `assetinfo_middlewareinfo`.`id`, `assetinfo_middlewareinfo`.`name`, `assetinfo_middlewareinfo`.`port`, `assetinfo_middlewareinfo`.`server_id`, `assetinfo_middlewareinfo`.`shelves_date`, `assetinfo_middlewareinfo`.`update_time`, `assetinfo_middlewareinfo`.`is_delete` FROM `assetinfo_middlewareinfo` WHERE `assetinfo_middlewareinfo`.`shelves_date` < ((`assetinfo_middlewareinfo`.`update_time` * 2))  LIMIT 21

可以看到where条件是

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
`assetinfo_middlewareinfo`.`shelves_date` < ((`assetinfo_middlewareinfo`.`update_time` * 2))  LIMIT 21

Q对象

前面的查询可以看到都是单条件查询,并没有多个条件查询。 例如:执行mysql示例如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
mysql> select * from assetinfo_middlewareinfo where server_id = 2 and shelves_date < update_time ;
+----+-------+------+-----------+-----------+----------------------------+----------------------------+
| id | name  | port | server_id | is_delete | shelves_date               | update_time                |
+----+-------+------+-----------+-----------+----------------------------+----------------------------+
|  3 | nginx |   80 |         2 |         1 | 2019-06-10 16:41:52.129517 | 2019-06-10 17:38:18.923155 |
|  4 | kafka | 9092 |         2 |         1 | 2019-06-10 16:42:25.561732 | 2019-06-10 17:39:29.302349 |
+----+-------+------+-----------+-----------+----------------------------+----------------------------+
2 rows in set (0.00 sec)

mysql> 

可以从上面的where条件看到有两个过滤条件。 第一个则是 server_id = 2 , 第二个则是 shelves_date < update_time 那么再模型中,怎么写出来呢?

可以使用Q对象来实现,用法如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
from django.db.models import Q
Q(属性名__运算符=) & Q(属性名__运算符=)  ==> and
Q(属性名__运算符=) | Q(属性名__运算符=)   ==> or
~Q(属性名__运算符=)                       ==> not

使用模型编写该示例,如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
In [1]: from assetinfo.models import ServerInfo,MiddlewareInfo

In [2]: from django.db.models import F,Q

In [3]: 

In [5]: MiddlewareInfo.objects.filter( Q( server_id__exact = 2 ) & Q( shelves_date__lt = F('update_time')  ) )
Out[5]: <QuerySet [<MiddlewareInfo: MiddlewareInfo object (3)>, <MiddlewareInfo: MiddlewareInfo object (4)>]>

In [6]: 

对应sql如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
2019-06-13T15:43:47.042246Z	   14 Query	SELECT `assetinfo_middlewareinfo`.`id`, `assetinfo_middlewareinfo`.`name`, `assetinfo_middlewareinfo`.`port`, `assetinfo_middlewareinfo`.`server_id`, `assetinfo_middlewareinfo`.`shelves_date`, `assetinfo_middlewareinfo`.`update_time`, `assetinfo_middlewareinfo`.`is_delete` FROM `assetinfo_middlewareinfo` WHERE (`assetinfo_middlewareinfo`.`server_id` = 2 AND `assetinfo_middlewareinfo`.`shelves_date` < (`assetinfo_middlewareinfo`.`update_time`))  LIMIT 21

上面是and条件的示例,那么现在来执行一下 or ,如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
In [6]: MiddlewareInfo.objects.filter( Q( server_id__exact = 2 ) | Q( shelves_date__lt = F('update_time')  ) )
Out[6]: <QuerySet [<MiddlewareInfo: MiddlewareInfo object (1)>, <MiddlewareInfo: MiddlewareInfo object (2)>, <MiddlewareInfo: M
iddlewareInfo object (3)>, <MiddlewareInfo: MiddlewareInfo object (4)>, <MiddlewareInfo: MiddlewareInfo object (6)>, <Middlewar
eInfo: MiddlewareInfo object (12)>, <MiddlewareInfo: MiddlewareInfo object (13)>, <MiddlewareInfo: MiddlewareInfo object (14)>]
>

对应的SQL如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
2019-06-13T15:47:09.063544Z	   14 Query	SELECT `assetinfo_middlewareinfo`.`id`, `assetinfo_middlewareinfo`.`name`, `assetinfo_middlewareinfo`.`port`, `assetinfo_middlewareinfo`.`server_id`, `assetinfo_middlewareinfo`.`shelves_date`, `assetinfo_middlewareinfo`.`update_time`, `assetinfo_middlewareinfo`.`is_delete` FROM `assetinfo_middlewareinfo` WHERE (`assetinfo_middlewareinfo`.`server_id` = 2 OR `assetinfo_middlewareinfo`.`shelves_date` < (`assetinfo_middlewareinfo`.`update_time`))  LIMIT 21

最后再写一个not关系的,如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
In [7]: MiddlewareInfo.objects.filter( ~Q( server_id__exact = 2 ) )
Out[7]: <QuerySet [<MiddlewareInfo: MiddlewareInfo object (1)>, <MiddlewareInfo: MiddlewareInfo object (2)>, <MiddlewareInfo: M
iddlewareInfo object (5)>, <MiddlewareInfo: MiddlewareInfo object (6)>, <MiddlewareInfo: MiddlewareInfo object (7)>, <Middlewar
eInfo: MiddlewareInfo object (8)>, <MiddlewareInfo: MiddlewareInfo object (9)>, <MiddlewareInfo: MiddlewareInfo object (10)>, <
MiddlewareInfo: MiddlewareInfo object (11)>, <MiddlewareInfo: MiddlewareInfo object (14)>, <MiddlewareInfo: MiddlewareInfo obje
ct (15)>, <MiddlewareInfo: MiddlewareInfo object (16)>]>

对应的执行SQL如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
mysql> SELECT `assetinfo_middlewareinfo`.`id`, `assetinfo_middlewareinfo`.`name`, `assetinfo_middlewareinfo`.`port`, `assetinfo_middlewareinfo`.`server_id`, `assetinfo_middlewareinfo`.`shelves_date`, `assetinfo_middlewareinfo`.`update_time`, `assetinfo_middlewareinfo`.`is_delete` FROM `assetinfo_middlewareinfo` WHERE NOT (`assetinfo_middlewareinfo`.`server_id` = 2)  LIMIT 21;
+----+-----------+-------+-----------+----------------------------+----------------------------+-----------+
| id | name      | port  | server_id | shelves_date               | update_time                | is_delete |
+----+-----------+-------+-----------+----------------------------+----------------------------+-----------+
|  1 | memcached | 11211 |         1 | 2019-06-10 14:56:46.150556 | 2019-06-10 17:37:51.365155 |         1 |
|  2 | redis     |  6379 |         1 | 2019-06-10 14:56:46.150556 | 2019-06-10 17:38:20.712862 |         1 |
|  5 | test      |   123 |         1 | 2019-06-10 17:05:16.632773 | 2019-06-10 17:05:16.632773 |         1 |
|  6 | test      |   123 |         1 | 2019-06-10 17:06:20.120658 | 2019-06-10 17:06:20.121656 |         1 |
|  7 | test      |   123 |         1 | 2019-06-10 17:06:43.193412 | 2019-06-10 17:06:43.193412 |         1 |
|  8 | test      |   123 |         1 | 2019-06-10 17:07:03.747395 | 2019-06-10 17:07:03.747395 |         1 |
|  9 | test      |   123 |         1 | 2019-06-10 17:08:43.372097 | 2019-06-10 17:08:43.372097 |         1 |
| 10 | test      |   123 |         1 | 2019-06-10 17:09:37.877019 | 2019-06-10 17:09:37.877019 |         1 |
| 11 | test      |   123 |         1 | 2019-06-10 17:11:45.403627 | 2019-06-10 17:11:45.403627 |         1 |
| 14 | mongodb   |  3306 |         1 | 2019-06-11 14:01:24.003175 | 2019-06-11 14:06:14.525648 |         1 |
| 15 | test      |   123 |         1 | 2019-06-11 14:04:10.576241 | 2019-06-11 14:04:10.576241 |         0 |
| 16 | test      |  3306 |         1 | 2019-06-11 14:06:05.608006 | 2019-06-11 14:06:05.608006 |         0 |
+----+-----------+-------+-----------+----------------------------+----------------------------+-----------+
12 rows in set (0.00 sec)

聚合函数

使用aggregate()过滤器调用聚合函数。聚合函数包括:Avg,Count,Max,Min,Sum,被定义在django.db.models中。

首先执行一个sql的聚合函数,如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
mysql> select count(1) from assetinfo_middlewareinfo;
+----------+
| count(1) |
+----------+
|       16 |
+----------+
1 row in set (0.00 sec)

mysql> 

在日常的业务中,经常有统计表数量的情况,那么模型需要怎么写呢?如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
In [9]: MiddlewareInfo.objects.count()
Out[9]: 16

那么sum方法呢?如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
mysql> select sum(server_id) from assetinfo_middlewareinfo;
+----------------+
| sum(server_id) |
+----------------+
|             20 |
+----------------+
1 row in set (0.00 sec)

对应模型如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
In [14]: from django.db.models import Sum

In [15]: MiddlewareInfo.objects.aggregate(Sum('server_id'))
Out[15]: {'server_id__sum': Decimal('20')}

In [16]: 

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2020-09-20,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 海洋的渔夫 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
韩松、王威廉、杨迪一、方飞、张含望入选,2020 IEEE智能系统十大AI青年科学家出炉
机器之心报道 编辑:泽南、小舟 IEEE 的「AI's 10 to Watch」青年学者榜单出炉了。相比上次,华人学者的比例再次提高。 IEEE 的「十大 AI 青年科学家」榜单每两年推出一次,旨在介绍人工智能领域中年轻而有抱负的科学家。今年 4 月,《IEEE 智能系统》开始接受全球范围内的提名,要求候选人必须在 2014 年之后获得博士学位提名,最终的入选名单由杂志编委会和顾问团队提出。在超过 20 人的名单中,基于研究质量、声誉、影响力、专家认可度及多样性,选出了最后入围的十人。 在 2018 年的
机器之心
2023/03/29
6760
韩松、王威廉、杨迪一、方飞、张含望入选,2020 IEEE智能系统十大AI青年科学家出炉
业界 | 今秋开课!卡内基梅隆大学将开设美国首个人工智能本科学位
机器之心编译 机器之心编辑部 目前,很多美国大学都在计算机科学和计算机工程等学位课程内提供人工智能方向,但以「人工智能」命名的学位还未出现。近日,卡内基梅隆大学(CMU)终于宣布将开设美国首个
机器之心
2018/06/12
4330
全球高校人工智能实力排名出炉,清华力压卡内基梅隆占据第一宝座
近日,麻省理工学院马萨诸塞校区计算机与信息科学学院教授 Emery Berger 发布的全球院校计算机科学领域实力排名的开源项目 CSranking 更新。
AI科技大本营
2018/07/23
2930
全球高校人工智能实力排名出炉,清华力压卡内基梅隆占据第一宝座
2018全球大学计算机科学与人工智能排名:CMU名列第一
机器之心报道 参与:李泽南 计算机科学排名顶级学校排名(CSRankings)旨在帮助人们了解全球各家大学在计算机科学领域体系与师资方面的实力。不同于 US News 和 World Report 的方法(仅仅基于调查),该排名完全基于研究指标,其度量了绝大多数院校教员在计算机科学领域的各大顶会所发布的论文数量。 该项目由麻省大学阿默斯特分校的 Emery Berger 教授发起。由于顶会论文发表难度很高,这种统计排名的方式被认为难以进行造假。目前,卡耐基梅隆大学(CMU)、麻省理工学院(MIT)与斯坦福大
机器之心
2018/05/10
6120
卡耐基梅隆大学利用人工智能、机器人等技术变革农业
据《福布斯》网站报道,卡耐基梅隆大学的研究人员正在利用人工智能、机器人等技术变革农业。 报道表示,预计到2050年世界人口将达到97亿。中国和印度是世界上人口最多的两个国家,其人口总数都在10亿左右。预计四年后,到2022年,印度会超过中国,成为世界上人口最多的国家。这意味着,为了养活地球上的人口,避免出现全球性粮食危机,我们需要更智能的新方法来种植粮食,帮助调节我们对土地、水资源和能源的使用。 卡耐基梅隆大学(Carnegie Mellon University)机器人研究所(Robotics Insti
人工智能快报
2018/03/14
1.1K0
卡耐基梅隆大学利用人工智能、机器人等技术变革农业
2018全球大学人工智能排名发布,中国高校表现强势!
近日,麻省理工学院马萨诸塞校区计算机与信息科学学院教授EmeryBerger发布一个全球院校计算机科学领域实力排名的开源项目CSranking更新了。目前,卡耐基梅隆大学(CMU)、麻省理工学院(MIT)与斯坦福大学名列全球前三。 其中,清华大学位列第13名,北京大学第30名,上海交通大学此次排行第48名。 排名分数计算依据 不同于USNews和WorldReport的方法(仅仅基于调查),CSranking的排名主要依据各个高校在计算机领域的顶级学术会议发表的论文数量,度量了绝大多数院校教员在计算机科学领
WZEARW
2018/04/08
8350
2018全球大学人工智能排名发布,中国高校表现强势!
学界丨Yann LeCun、Jeff Dean频繁亮相普及人工智能知识,全民AI时代来临|AI科技评论周刊
前段时间,吴恩达连续给业界人士写了两篇公开信,为各行各业普及了人工智能在行业中的应用。而在最近,谷歌大脑负责人 Jeff Dean 和 Yann LeCun 也频繁在公众场合露脸,为大众解读机器学习、
AI科技评论
2018/03/09
1K0
学界丨Yann LeCun、Jeff Dean频繁亮相普及人工智能知识,全民AI时代来临|AI科技评论周刊
《安全的人工智能系统开发指南》解读
11月26日,由英国国家网络安全中心(NCSC)、美国网络安全与基础设施安全局(CISA)联合美国国家安全局、美国联邦调查局以及澳大利亚、加拿大、新西兰、德国、法国、日本等10余个国家的网络和/或信息安全部门发布了“安全的人工智能系统开发指南”(Guidelines for secure AI system development [1])。亚马逊、微软、IBM、google等10余家机构参与了指南的制定。该指南旨在为使用人工智能(AI)的任何系统的提供商提供指导原则,帮助提供商构建能够按预期工作、在需要时可用、在不泄露敏感数据的前提下工作的人工智能系统。本文对其主要内容进行解读,以供普通读者阅读了解。人工智能专家或人工智能系统开发人员可根据需要,参阅原文[1]以获取更详细、全面的信息。此外,指南的末尾注记中列出的资料可作为延伸阅读材料,感兴趣的读者可以自行参阅。
绿盟科技研究通讯
2023/12/11
6480
《安全的人工智能系统开发指南》解读
专家称人工集群智能有助于应对人工智能的潜在威胁
最近关于人工智能威胁的讨论越来越多,斯蒂芬·霍金、比尔·盖茨、伊隆·马斯克、史蒂夫·沃兹尼亚克等世界各地名人已经敲响了警钟,称人类可能会失去对人工智能技术的控制,因为人工智能技术创造的是具有自主思想的
人工智能快报
2018/03/07
6450
CMU开设美国首个人工智能本科专业
---- 新智元报道 来源:CMU 编辑:克雷格 【新智元导读】今年秋天开始,卡内基梅隆大学(CMU)计算机科学学院将开设全美首个人工智能本科专业,计划招收大约100名学生,每个班级大约30-35人。2018年秋季,二年级和大三学生可以申请该课程。 卡内基梅隆大学(CMU)计算机科学学院(School of Computer Science,SCS)将在今年秋季开始,提供一个新的人工智能本科学位,为学生们提供如何将大量数据转化为可操作决策的深入知识。 这是美国大学首次开设人工智能本科专业,目的是应对
新智元
2018/05/29
1.2K0
监管人工智能系统:风险、挑战、能力和策略
作者: Matthew U. Scherer   译者: 曹建峰 腾讯研究院法律研究中心研究员                    李金磊 腾讯研究院法律研究中心助理研究员    来源: Harvard journal of law and technology 引言   智能机器时代,人工智能正在全方位侵入我们的生活。人工智能(artificial intelligence,简称AI)正在替代那些以前只能由具有专业知识或者获得政府颁发的许可证的人员才能完成的任务。美国一些州以
腾讯研究院
2018/02/01
1K0
【1996~2016】盘点 20 年 AAAI 人工智能最佳论文
【新智元导读】新智元汇集计算机科学领域1996年到2016年人工智能领域最佳论文,附上题目及摘要的中文翻译,并对这些作品进行系统考察,从中可以看出人工智能这门学科的一些发展走势。过去20年来(空缺年份表示当年没有最佳论文),AAAI 最佳论文覆盖面完善,包括推理、知识、规划、学习、交流、感知、移动和操作物体。论文中使用最多的还是优化、逻辑推演等方法,与刚刚结束的 IJCAI'16相比,机器学习在其中光芒并没那么显著。 2012年,浙江大学EAGLE-Lab及CAD&CG 实验室合作的《基于数据重构的文档摘要
新智元
2018/03/26
1.4K0
多家IT巨头公司就人工智能建立合作组织
全球IT产业的巨头谷歌、微软、IBM、脸书和亚马逊宣布就人工智能联合建立了一个非盈利性组织,其中谷歌子公司DeepMind以独立成员身份参与。 这个新成立的非盈利组织旨在促进公众对人工智能技术(AI)的了解,并就人工智能领域的挑战和机遇制定最佳实践。该组织被命名为“人工智能惠及人类与社会合作伙伴组织”(Partnership on Artificial Intelligence to Benefit People and Society,简称“人工智能合作组织”),学术机构、非盈利组织及政治和伦理道德界的专
人工智能快报
2018/03/07
8560
清华人工智能研究院成立,张钹姚期智分别任院长和主任
今日,清华大学人工智能研究院成立仪式暨清华-谷歌 AI 学术研讨会在清华举行。据介绍,张钹院士将担任院长,图灵奖得主姚期智院士任学术委员会主任,同时,谷歌人工智能部门负责人 Jeff Dean 为清华大学计算机学科顾问委员会委员。
AI科技大本营
2018/07/23
5520
清华人工智能研究院成立,张钹姚期智分别任院长和主任
人工智能在医疗:改善药物依从性、虚拟医疗助手、智能看护、智能药物研发...
摘自:动脉网 网站:http://www.vcbeat.net/ 人工智能用来提高健康医疗服务的效率和自动化程度。人工智能技术的发展在过去备受质疑,然后如今我们发现大数据技术正在推进人工智能的进程,在医疗健康领域也是如此。 分析患者行为,制定个性化肿瘤治疗方案 例如,两位乳腺癌患者可能会得到相同的治疗方案,但其实两者的身体情况可能完全不同。 其中一个可能是马拉松长跑者,另外一个是喜欢安静的读书的人;一个可能是吸烟者,另一个也许是个注重养生的人;一个可能都60多岁了,另一个也就刚刚40。这样的情况在我们身边
大数据文摘
2018/05/21
7510
关于人工智能应该知道的十件事
来源:InfoQ 作者:张天雷 网站:http://www.infoq.com 微信号:infoqchina 人工智能(AI)已经被广泛地应用于软件和在线服务领域,由于机器学习算法和各种相关技术的不断进步,它正变得越来越普遍。但是像基于软件的知觉、人工意识等技术的流行描述却模糊了AI的真正定义以及它的实际利用方式。 本月初,卡耐基梅隆大学计算机科学学院院长Andrew Moore,接受了InformationWeek的采访,谈到了人工智能以及它在人们生活中所发挥的日益增长的重要作用。Moore表示,人工智
大数据文摘
2018/05/22
2740
以人工智能为火种,点燃下一代工业革命!2021年WAIC云帆奖获得者名单公布
机器之心报道 机器之心编辑部 2021年云帆奖获奖者名单公布:以人工智能为火种,点燃下一代工业革命! 7月10日,在2021世界人工智能大会开发者论坛上,最新一届「WAIC云帆奖」得主名单揭晓。作为全球首个面向青年华人AI开发者的奖项,云帆奖已经成为WAIC最具代表性的赛事评奖活动之一。 2021年的WAIC云帆奖共评选出璀璨明星10位和明日之星17位,他们中既有来自斯坦福、加州大学、清华、上海交大、浙大等海内外高校的青年教师及优秀博士生,也有参与创立了思谋科技、循环智能、深势科技、Whale帷幄等新一代
机器之心
2023/03/29
1.6K0
以人工智能为火种,点燃下一代工业革命!2021年WAIC云帆奖获得者名单公布
外媒预测2016人工智能七大趋势
据TechRepublic网站2015年12月15日报道,来自卡内基梅隆大学、德蒙特福德大学与路易斯维尔大学的研究人员就2016年的主要人工智能研究领域做出了以下预测: 1.深度学习 路易斯维尔大学网络安全实验室主任Yampolskiy表示,卷积神经网络的(深度学习)功能将得到显著改进,并且这一功能将与日益增多的超级计算机的大量计算资源相匹配,德蒙特福德大学高级研究员Richardson认为深度学习技术将成为2016年的一个热门研究领域。 2.人工智能取代劳动力 卡内基梅隆大学计算机科学学院院长Moore表
人工智能快报
2018/03/07
4700
【IJCAI】国际人工智能大会看AI趋势
IJCAI 由国际人工智能联合会主办,是中国计算机学会认定为 A 类的人工智能学科顶级会议,在近千种人工智能国际会议中公认排名第一。IJCAI-15 的亮点是把最新研究的问题和应用场景进行了集中展示,例如人工智能与艺术、可持续性论文等。 本届 IJCAI 大会共包括 Main Track(341篇论文)、机器学习(Machine Learning Track,114 篇论文)、知识表示(KR Track,83 篇论文)、人工智能与艺术(AI & Arts Track,16 篇论文)和可持续
新智元
2018/03/13
1.4K0
【IJCAI】国际人工智能大会看AI趋势
【深度长文】人工智能过去60年沉浮史,未来60年将彻底改变人类
导读:对于人工智能来说,前60年的人工智能历程,可以用“无穷动”来形容;后60年的人工智能发展,可以用“无穷大”来期许。
IT阅读排行榜
2018/08/14
1.6K0
【深度长文】人工智能过去60年沉浮史,未来60年将彻底改变人类
推荐阅读
韩松、王威廉、杨迪一、方飞、张含望入选,2020 IEEE智能系统十大AI青年科学家出炉
6760
业界 | 今秋开课!卡内基梅隆大学将开设美国首个人工智能本科学位
4330
全球高校人工智能实力排名出炉,清华力压卡内基梅隆占据第一宝座
2930
2018全球大学计算机科学与人工智能排名:CMU名列第一
6120
卡耐基梅隆大学利用人工智能、机器人等技术变革农业
1.1K0
2018全球大学人工智能排名发布,中国高校表现强势!
8350
学界丨Yann LeCun、Jeff Dean频繁亮相普及人工智能知识,全民AI时代来临|AI科技评论周刊
1K0
《安全的人工智能系统开发指南》解读
6480
专家称人工集群智能有助于应对人工智能的潜在威胁
6450
CMU开设美国首个人工智能本科专业
1.2K0
监管人工智能系统:风险、挑战、能力和策略
1K0
【1996~2016】盘点 20 年 AAAI 人工智能最佳论文
1.4K0
多家IT巨头公司就人工智能建立合作组织
8560
清华人工智能研究院成立,张钹姚期智分别任院长和主任
5520
人工智能在医疗:改善药物依从性、虚拟医疗助手、智能看护、智能药物研发...
7510
关于人工智能应该知道的十件事
2740
以人工智能为火种,点燃下一代工业革命!2021年WAIC云帆奖获得者名单公布
1.6K0
外媒预测2016人工智能七大趋势
4700
【IJCAI】国际人工智能大会看AI趋势
1.4K0
【深度长文】人工智能过去60年沉浮史,未来60年将彻底改变人类
1.6K0
相关推荐
韩松、王威廉、杨迪一、方飞、张含望入选,2020 IEEE智能系统十大AI青年科学家出炉
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档