File: tour.rst

package info (click to toggle)
sqlkit 0.9.5-1
  • links: PTS, VCS
  • area: main
  • in suites: wheezy
  • size: 8,184 kB
  • sloc: python: 17,477; sql: 166; makefile: 95; xml: 23; sh: 11
file content (309 lines) | stat: -rw-r--r-- 8,773 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
=======================  
Sqlkit & Sqledit 
=======================

Sqlkit is a tool to edit **data** of a database (as opposed to schemas) in the
easiest possible way. By **easy** we mean both: easy to write for the *user*
since completion helps you, and easy to write for the *programmer* as a lot of
features are there to help you customize it. It's based on PyGTK_.

It provides:

* a GUI named :ref:`sqledit <sqledit>` that can be used standalone and does
  not require programming knowledge

* a Python package that mainly provides two megawidgets: :ref:`mask` and
  :ref:`table`, very powerful classes to build your application.

A typical usage can be::


  from sqlkit.widgets import SqlTable, SqlMask
  from sqlkit import DbProxy
  
  db = DbProxy(engine='sqlite:///movies.sqlite')
  t = SqlMask('movie', dbproxy=db, single=True)
     
that will pop up an editor for the record. Filter panel will be available
just clicking on the label of the fields.

.. _sqlkit: 

Features
========


**Main features of sqlkit**:

- Editor of databases in 2 modes: :ref:`table` & :ref:`mask`. Mask can
  embed tables of :ref:`related tables <relationships>`.
- Based on sqlalchemy_: can cope with many different database backends
  (PostgreSQL, MySQL, sqlite and firebird the ones sqlkit was tested
  on).  Can be used to edit any  selectable you can build with sqlalchemy.
- Very powerful :ref:`filtering <filters>` capabilities:

  * each field can be used to filter visible records
  * date filtering possible also on relative basis (good for saved
    queries)
  * works on expressions too
  * works on fields in :ref:`related tables <relationships>` embedded in mask

- :ref:`completion` both on normal fields and foreign key fields
- Very easy way to draw a layout for mask views
- :ref:`sqledit`: python script to edit db
- Completely effortless editing of :ref:`relationships`
- Very easy way to set :ref:`defaults`
- Possibility to display :ref:`totals` in numeric fields
- :ref:`constraints`: any possible sql constraint can be attached to a Mask 
  or a Table. It can be expressed as a normal sqlalchemy query or with
  django-like syntax. Works on expressions too.
- SqlMask and SqlTable are widgets with several :ref:`signals`
- :ref:`hooks` for a very easy customization of behavior and for validation
- More than 70 snippets of code to demonstrate each feature

.. _sqlalchemy: http://www.sqlalchemy.org

.. image:: ../img/table-demo.png
   :align: right
   :scale: 50%
   :class: preview
   :alt:   table opened on movies


Table
-----

You can see data in a tabular format using the :ref:`table` widget.

The code is as simple as::

   t = SqlTable('movie', dbproxy=db, )

you can customize which columns to show, possible filters or constraints
(see below), and a lot of others details

Mask
----

.. image:: ../img/mask-demo.png
   :align: right
   :scale: 50%
   :class: preview

Records can be displayed one record at a time with the SqlMask widget.
Tables can be embedded in mask to edit :ref:`relationships`.

that where requested by the following instructions::

   lay = """
      varchar10  
      varchar200  - - -
      {N  { %time
	    {>>.general

	       date        interval
	       datetime    time
	       }
	    {>.hidden_boolean
	       bool    bool_null
	    }
	   }
	 {  %numbers
	    integer
	    float
	    numeric
	 }
	 {  %text
	    text
	    uni_text
	  }
	  } - - - 
   

   """
   t1 = SqlMask('all_types', dbproxy=db, layout=layout, )


Filters
-------

.. image:: ../img/filter-panel.png
   :align: right
   :scale: 50%
   :class: preview

Each label of both views can be clicked to get a :ref:`filter panel
<filters>` through which we can choose an operator and filter records. Filter
let you use a "human" representation of foreign keys, that means that if
``director_id`` points to a numeric id, sqlkit will let you write the (last)
name of the director instead when filtering.

The filter panel will let you navigate in the output list, that can be
completely customized.
   

Completion
----------

:ref:`completion` is triggered by F1 key, Ctrl-Enter or Shift-Enter.  If the
field is a foreign key it will pop up a list of foreign values otherwise it
will show values currently used (just for varchar fields). 

The search for completion is done using the (possibly) already written
letters as filter: Control will match them at the beginning of the field,
Shift (and F1) will match them in any part. The search is made using
``LIKE`` operators or ``regexp`` according to whatever is available in the
db engine in use.


Layout
------

Very easy way to draw a layout. See :ref:`layout` widgets for a tour.
The language used relates to glade as a markup language relates to html.

This GUI description language lets you draw a layout using field_name as
place holders for the widget that you will use to edit it::

  title  
  director_id

will be replaced by a label 'title' followed by an entry and a title
'director_id' followed by a widget suitable to edit a foreign key.

Le language gets more complicated to let you use main gtk widgets as frames,
notebooks, scrollable widgets, tables....
  
Relationships
-------------

.. image:: ../img/o2m.png
   :align: right
   :scale: 50%
   :class: preview

This is probably the most impressive feature.

You can build a layout in which related data are displayed in a totally
natural way. The following layout requires the code::

  lay = """
     first_name
     last_name
     nation
     o2m=movies:title,description,year,date_release
  """
  SqlMask(Movie, layout=lay, dbproxy=db)



now you can edit director and films. The demo has plenty of working examples
for there cases:

:many2one: are just recognized automatically with simple introspection
:many2many: is very simply added to SqlMask declaring in the layout and
            attribute with that name
:one2many:  same as many2many

Many more detail in :ref:`relationships`

.. image:: ../img/totals-embedded.png
   :align: right
   :scale: 40%
   :class: preview
   
Totals
------


It's possible to display totals and subtotals in a table view. 
In this picture you can see how a table embedded into a mask can display
totals.

More in :ref:`totals`

Constraints
-----------

A :ref:`constraint <constraints>` can be as simple as::

  t = SqlTable('movie', dbproxy=db)
  t.add_constraints(actors__country='ITA', genres__name='drama',
    year__gte=1950, year__lte=1970)

And browsing of movies will be constrained into dramas with at least one
italian actor, produced between 1950 and 1970. The double underscore '__'
will allow spanning from one table to a related (provided a relation was
established at sqlalchemy level) and from attribute name to operator to e
used.  

Sqledit
-------

A full featured program (python script) that can browse a database. Many
options (``sqledit -h``).

.. image:: ../img/sqledit.png
   :align: right
   :scale: 50%
   :class: preview

Just try it out on your preferred database using the url in a form as one
of the examples::

  sqledit postgres://localhost/mydb
  sqledit postgres://sandro:passwd@host:5444/mydb
  sqledit mysql://localhost/mydb
  sqledit sqlite:///movies.sqlite


the last is a very minimal db present in ``doc/db/movies.sqlite``

.. _basic_limitations:

Basic assumptions and limitations
=================================

1. You use PrimaryKeys and ForeignKeys throughout the db.
   If you don't use ForeignKeys sqlkit will just work w/o any special
   behavior. If you don't use PrimaryKeys sqlkit will not even open the
   table.

2. ForeignKeys are *simple*. Compound ForeignKeys are not yet supported,
   that means that you can't use::

      class MyTable(Base):
         ...
	 ForeignKeyConstraint('first_field, second_field], [referenced1, referenced2])

   This will be addressed in a future release 

3. You are using one single metadata. This is a limit but it's my normal
   environment. There's not really anything that cannot be changed easily
   about this, simply I didn't have need for this, nor working cases.  (While
   I was plenty of ideas on other features...)

4. Spaces are not allowed in field names. This comes from the layout syntax
   definition.

.. _fkey:

ForeignKeys
===========

Everywhere there's a ForeignKey I try to represent it in
the best possible way. More info in the completion chapter:
:ref:`description`


sqlkit supported backends
=========================

Sqlkit is built on sqlalchemy that allows editing db with many `different
engines`_. I use it with PostgreSQL, MySQL, sqlite and Firebird.  Other
engines are supported but may need a very simple addition that I'd be
willing to do on demand.


.. _`different engines`: http://www.sqlalchemy.org/trac/wiki/DatabaseNotes
.. _PyGTK: http://www.pygtk.org