開発環境
- OS X Mavericks - Apple、たまにFreeBSD 10(OS)
- Emacs (CUI)、BBEdit - Bare Bones Software, Inc. (GUI) (Text Editor)
- Python 3.4(プログラミング言語)
- SQLite (RDBMS(Relational Database Management System))
Head First SQL ―頭とからだで覚えるSQLの基本 (Lynn Beighley(著)、 佐藤 直生 (監訳)、 松永 多苗子 (翻訳)、オライリージャパン)の2章(SELECT 文: 天賦のデータ検索)、エクササイズ(p.81)を解いてみる。
エクササイズ(p.81)
コード(BBEdit, Emacs)
sample81.py
#!/usr/bin/env python3 #-*- coding: utf-8 -*- import sqlite3 connection = sqlite3.connect('gregs_list.sqlite') cursor = connection.cursor() def p(msg): print(msg) for row in cursor.fetchall(): print(row) cursor.execute("""SELECT * FROM my_contacts""") print(tuple(map(lambda header: header[0], cursor.description))) p("全て") cursor.execute(""" SELECT email FROM my_contacts WHERE profession = 'コンピュータプログラマ' """) p('全てのコンピュータプログラマのメールアドレス') cursor.execute(""" SELECT first_name, last_name, location FROM my_contacts WHERE birthday = '1970-04-01' """) p('名前と住所') cursor.execute(""" SELECT first_name, last_name, email FROM my_contacts WHERE location = 'ニュージャージー州グローバーズミル (Grover''s Mill)' AND status = '独身' AND gender = 'M' """) p('名前、メールアドレス') cursor.execute(""" SELECT first_name, last_name FROM my_contacts WHERE location = 'カリフォルニア州サンフランシスコ' AND first_name = 'アン' """) p('名前') connection.close()
入出力結果(Terminal, IPython)
$ ./sample81.py ('last_name', 'first_name', 'email', 'gender', 'birthday', 'profession', 'location', 'status', 'interests', 'seeking') 全て ('スティーブ', 'ファンヨン', 'steve@onionflavoredrings.com', 'M', '1970-04-01', 'パンクミュージシャン', "ニュージャージー州グローバーズミル (Grover's Mill)", '独身', '国家の破壊', '同国人、ギタープレイヤー') ('スティーブ', 'ファンヨン', 'steve@onionflavoredrings.com', 'M', '1970-04-01', 'パンクミュージシャン', "ニュージャージー州グローバーズミル (Grover's Mill)", '独身', '国家の破壊', '同国人、ギタープレイヤー') 全てのコンピュータプログラマのメールアドレス 名前と住所 ('ファンヨン', 'スティーブ', "ニュージャージー州グローバーズミル (Grover's Mill)") ('ファンヨン', 'スティーブ', "ニュージャージー州グローバーズミル (Grover's Mill)") 名前、メールアドレス ('ファンヨン', 'スティーブ', 'steve@onionflavoredrings.com') ('ファンヨン', 'スティーブ', 'steve@onionflavoredrings.com') 名前 $
0 コメント:
コメントを投稿