- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在寻找一个可以处理以下场景的 Web 框架(希望基于 Python、Postgresql 和 ORM):
您有一个 Person 表(其中有一个人 Avril Lavigne - 有过两次婚姻):
PersonID Start End PersonName
-------- ----------- ----------- -------------
1 27-Sep-1984 14-Jul-2006 Avril Lavigne
1 15-Jul-2006 30-Jun-2013 Avril Whibley
1 01-Jul-2013 31-Dec-9999 Avril Kroeger
您有一个分配表(这是一个人所拥有的工作分配等,一个人可以在不同地点拥有多个任务):
AssignID Start End PersonID JobID LocID
-------- ----------- ----------- -------- ----- -----
1 27-Sep-1984 26-Sep-1999 1 1 1
1 27-Sep-1999 31-Dec-2002 1 1 2
1 01-Jan-2003 31-Dec-9999 1 1 3
2 01-Jul-2013 31-Dec-9999 1 2 3
有没有一种方法可以让 Pyramid 允许用户选择一个有效日期(比如今天),并且 SQL Alchemy 将能够使用有效日期和 SQL Between
来连接表,以及外键加入PersonID
;带回来:
Avril Kroeger 有 2 项作业,JobID
1 和 2 以及 LocID
3。
Oracle 中的 SQL 语句的位置:
select p.PersonName,
a.JobID,
a.LocID
from Person p,
Assignment a
where a.PersonID = p.PersonID
and trunc(sysdate) between a.Start and a.End
and trunc(sysdate) between p.Start and p.End
我只是担心我要学习另一个无法处理复合主键的 Web 框架以及甚至 SQL 外键也无法处理的上述场景。
那么 ORM 基本上可以处理任意查询吗?如果您采用上述场景,您是否会失去所有 ORM 速记函数?有没有更好的方法来处理上述情况。我应该将生效日期存储为 session 变量吗?
我对该主题的了解不够,无法提供我的解决方案。我更努力避免学习另一个无法解决上述场景的框架。
最佳答案
首先,Pyramid 绝对可以完全处理这种情况,因为 Pyramid 与存储无关,所以它不知道有关数据库、SQL 和其他此类内容的任何信息:) 换句话说,这个问题与 Pyramid 没有任何关系.
其次,SQLAlchemy 确实支持复合主键。从我的想法来看,声明性类看起来像这样:
class Person(sa.Base):
person_id = sa.Column(sa.Integer, primary_key=True)
start = sa.Column(sa.DateTime, primary_key=True)
end = sa.Column(sa.DateTime, primary_key=True)
name = sa.Column(sa.String)
class Assignment(sa.Base):
person_id = sa.Column(sa.Integer, primary_key=True)
start = sa.Column(sa.DateTime, primary_key=True)
end = sa.Column(sa.DateTime, primary_key=True)
...
您的查询将如下所示:
(session.query(Person.name, Assignment.jobId, Assignment.LocID)
.filter(Assignment.person_id==Person.person_id)
.filter(sa.sql.functions.now().between(Person.start, Person.end))
.filter(sa.sql.functions.now().between(Assignment.start, Assignment.end))
)
关于python - SQL Alchemy 和 Pyramid 能否处理日期有效场景,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23315136/
websocket的用途/场景 先总结:高即时性服务,比如聊天室的群聊,server顺序收到了张三,李四的消息,立即就推送给王五,不能让王五等半天。 Ajax也可以一秒一刷,让王五去问张三说话没,如果
前端的工作过程里,本地开发、提供测试环境,总得有个用着顺手的服务器软件,这个场景里nginx很流行。 介绍两个好用的配置项:rewrite try_files @xxxx rewrite 比较
我有一个场景的两个不同角度的 2 个视频文件,我想重建场景的 3D 估计。它类似于 3D 传感器的作用(例如 Kinect、PrimeSense)。我正在寻找一个库,甚至是一个完善的机器视觉算法,以便
我已阅读RebaseProject页面并尝试了一个不平凡的例子(不是对一个完整的分支进行 rebase )。这与 rebase D 的情况类似我场景B。 这是rebase之前的情况: default
有没有办法将我的场景保存在 JavaFx 应用程序中单独的 Java 文件中?我尝试过这样的事情: public class MyApp extends Application { pri
我有这样的场景:用户想要查看大量有关自己的信息。例如:年龄、姓名、地位、收入、工作、爱好、 child 的名字、妻子的名字、酋长的名字、祖父/祖母的名字。大约 50 个变量。他可以选择任何变量来显示信
我希望有人能帮助我解决这个问题:我有一个包含条目的表。我想执行查询并根据模式获取得分最高的记录。模式将是:如果我的话按原样出现,那么该条目的分数将是最高的。如果该单词出现在句子中,则该条目的分数将低于
我正在尝试在我的应用程序委托(delegate)方法中实现一些逻辑。了解当前正在运行哪种场景将非常有帮助。 [[CCDirector sharedDirector] runningScene] 返回当
好的,这是一个有趣的。我有 2 个表:tbl_notes、tbl_notes_categories 简单地说,tbl_notes 有一个 categoryid,我将 2 个表与该 ID 相关联。所以,
我有一个使用并行运行的 Specflow、selenium、NUnit 的测试解决方案在 AssemblyInfo 中添加了这个:[程序集:Parallelizable(ParallelScope.F
我正在尝试弄清楚如何在 SpriteKit 中添加更多场景。如果我在 GameViewController 中使用 SpriteKit 生成的行 if let scene = GameScene.un
目录 1、业务背景 2、场景分析 3、流程设计 1、业务流程 2、导入流程
我是 Unity 的新手,所以修复起来可能非常简单。我使用了一个 3D Google SketchUp 模型,我想让玩家环顾模型。 super 简单。 我添加了 3D 平面,添加了相机并更新了设置以支
我需要标记要跳过的某些测试。但是,有些测试是参数化的,我只需要能够跳过某些场景。 我使用 py.test -m "hermes_only" 调用测试或 py.test -m "not hermes_o
我已经开始使用 SpecFlow 并想知道是否可以在规范之间重用场景 基本上我的想法是这样的(我可能从根本上是错误的:)) 我编写了一项功能来验证导航。 功能:导航 I should be able
在编写验证输入表单上的信息的 BDD 场景时,您将如何列出规则。 选项是: 1) 每个规则一个场景 2)场景大纲,每个领域和规则的例子 我们如何说某些不在特定字符集中的无效内容,例如: 鉴于我输入了一
我们如何使用 StoryQ 来测试预期出现异常的场景? 最佳答案 就实际代码而言,在测试代码的 .Then 部分,您需要创建一个 Action 或 Func 来确定正在测试的内容,然后在代码的 .Th
完成快速初学者努力通过点击按钮向场景添加节点。 我知道我可以使用点击手势来获取点击坐标并执行点击测试,然后在点击的 3D 空间中放置一个对象。但是,我想在设备屏幕的中央显示一个球体或十字准线,当点击屏
如何在表格中传递空格? Background: Given the following books |Author |(here several spaces)
我正在尝试从 Eric Haines' Standard Procedural Database (SPD) 渲染“mount”场景,但折射部分就是不想配合。我已经尝试了所有我能想到的方法来修复它。
我是一名优秀的程序员,十分优秀!