- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我的数据库模型类中有许多方法可以执行参数化 SQL SELECT
语句。大多数这些查询都包含一个 WHERE
子句,其中包含用于过滤结果的字段。在默认情况下,我想忽略 where 子句中的比较以获得所有结果。一个例子:
def get_notes(self, pcb_serial_no, note_type=None):
''' Get notes recorded against a PCB unit, optionally filtered by note_type. '''
cursor = self.db.execute('''
SELECT pcb_serial_no, note_type, description, username, note_time
FROM pcb_notes_view
WHERE pcb_serial_no=?
AND COALESCE(?, note_type)=note_type
''',
(pcb_serial_no, note_type,)
)
rows = cursor.fetchall()
return len(rows) > 0 and rows
我正在使用默认参数值 None
(映射到 NULL
)和 COALESCE
的组合。这是迄今为止我能想到的可读性最好的解决方案(当然是主观的),但我确信这个“默认参数”是一个常见的要求,并且想知道有哪些惯用的方法来实现它?我也不确定在默认情况下 COALESCE
是否会对性能造成重大影响,尤其是如果该列未编入索引?
最佳答案
不幸的是,评论系统不适合发布示例,但 SQLAlchemy 与原始 SQL 的映射几乎是 1:1,我发现这种方法比从字符串操作编写语句要好。所以这是一个评论而不是一个答案,我希望你能原谅我。
重写您的函数 ORM 样式会产生如下结果:
def get_notes(self, pcb_serial_no, note_type=None):
''' Get notes recorded against a PCB unit, optionally
filtered by note_type. '''
q = sql.select([
pcb_notes_view.pcb_serial_no,
pcb_notes_view.note_type,
pcb_notes_view.description,
pcb_notes_view.username,
pcb_notes_view.note_time
]).where(
pcb_notes_view.pcb_serial_no==pcb_serial_no
)
if note_type is not None:
q = q.where(pcb_notes_view.note_type==note_type)
rows = q.execute().fetch_all()
return len(rows) > 0 and rows
由于 ORM 使查询的重用变得如此容易,并且 ORM 可以猜测表之间的关系(对于具有引用完整性的数据库),我倾向于定义 ORM 查询而不是 View (从 SQLSoup 映射 View 需要更多工作)。结合来自优秀 IDE(我使用 PyCharm)的智能自动完成,我使用 ORM 的效率完全提高了。
但这是一个品味问题。还可以使用存储过程将所有逻辑移至数据库。
关于python - Python 中的默认参数和 SQL 查询 - 习语/模式?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17099745/
这个问题已经有答案了: What is the Java ?: operator called and what does it do? (17 个回答) 已关闭 8 年前。 ltVal = node
我是一名 Java 学生,我在嵌套该程序的条件语句时遇到问题 Exercise CozaLozaWoza (Loop & Condition): Write a program called Coza
首先,我想给出用户想要留下的句子的数量,当他的写作结束时,我的代码开始将每个单词的第一个字母大写(在 Java 中)。 import java.util.Scanner; public class I
我尝试在基类中实现一个函数,该函数使用子函数(defiend 作为基类中的抽象函数)。我认为一个例子可以最好地说明这个问题。 abstract class Animal{ public void
就像在口吃中一样,如果文本为“dean”并且乘数为 3,则结果将是“dddeeeaaannn”。 public static void repeatLetters() { String text
public void insert(int data) { if (root == null) root = new AVLNode(data); else {
我是 XPATH 的新手,并且遇到以下问题: 我有以下代码片段,但似乎无法按我的预期工作: String XML = cdataContent;
例如,Java 数据类型字节将数据从 -128 到 127 存储在单个字节中。为了能够区分 - 1 到 -128 从 0 到 127 将需要额外的数据,这些数据将采用数据类型覆盖其分配的存储空间。不可
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 9
Dataset: P1: Lion, Snow, Chair P2: Min: 0, Max: 28 P3: Min: 34, Max is 39. 我的程序 以一系列数组列表的形式提供上述数据集(P
我正在构建一个应该 24/7 全天候运行的客户端服务器应用程序。应用程序指定检测网络故障(使用心跳)并尽快重新连接到服务器。 我做的第一个测试只是停止客户端或服务器,然后重新启动,一切正常。我想知道是
我怀疑它是编写它的类的类型,但我不是 100% 确定,有人可以证实我的怀疑并可能提供对定义此行为的 Java 语言规范的引用吗? 假设类 A 有一个方法 a(),它在其主体中使用了 this 关键字,
我已经在谷歌上搜索了两个小时,但没有成功。 如果我有一个模板函数并且我想在模板类型上强制执行一个接口(interface),我该怎么做? 例如。 void doStuff(T)(bool param)
我正在尝试获取用户输入并对其进行修改,以便打印不带任何元音的字符串。我已经能够使用以下代码成功完成此操作。 Scanner in = new Scanner(System.in); Syste
每当我使用 Thread.sleep(); 时在 do while 循环中,提示告诉我,“在循环中调用 Thread.sleep 可能会导致性能问题。”我从许多其他网站和书籍上听到过这一点。我可以用什
请不要将其视为以下内容的重复项而将其忽略: How to generate random positive and negative numbers in java 我需要使用带有种子的随机数生成器。
我想在一个数字范围内选择随机数,但权重偏向该范围的一部分。例如: 选择1-10之间的随机数 对其进行加权,使 1-5 比 6-10 的可能性高 20% 这可能吗?我该怎么做? 最佳答案 这取决于您希望
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 8 年前。 Improve this ques
我有一个付款 Activity 和启动 Activity ,它在用户购买后显示内容应用程序。付款 Activity 是Manifest.xml中的默认启动器,我想将启动器 Activity 设置为启动
我有一个指针和长度。如何从他们那里得到一个动态数组? 最佳答案 设ptr是一个指针,len是一个长度,那么很容易如下: ptr[0..len] 请注意,这不会复制数组,而是就地使用数据。 如果要复制数
我是一名优秀的程序员,十分优秀!