Easy to write sql
Project description
pysqler
Easy to write sql to avoid using string slice
更方便的拼写SQL, 免除各种容易出错的拼接字符串操作
eg:
age = some_function()
sql = "select * from people where name=\'barry\' and age = {0}"
if age:
sql = sql.format(sql, age)
else:
sql = sql.format(sql, "null")
above is boring, so try this:
from pysqler import *
age = some_function()
query = Select()
query.select("*")
query.from1("people")
query.where("age", "=", age)
query.and_where("name", "=", "barry")
query_str = str(query)
print(query_str)
you don't need take care of that if if the param is string, number or none ...
Usage
see more samples in tests/test_sqler.py
Build Select SQL
from pysqler import *
query = Select()
query.select("city", "education", "AVG(age) as avg_age")
query.from1("people")
query.where("age", ">", 10)
query.join("orders", "orders.account = people.id",
"orders.time = people.birthday")
query.and_where("job", "like", "%it%")
query.and_where("birthday", ">", "1988-09-12 12:12:12")
query.and_where("address", "!=", None)
query.left_join("vip", "vip.account = people.id")
query.groupby("city", "education")
query.orderby("avg_age", "DESC")
query.limit(10, 8)
output
SELECT city,education,AVG(age) as avg_age
FROM people
INNER JOIN orders
ON orders.account = people.id and orders.time = people.birthday
LEFT JOIN vip ON vip.account = people.id
WHERE age > 10 AND job like "%it%" AND birthday > "1988-09-12 12:12:12"
AND address IS NOT null
GROUP BY city,education ORDER BY avg_age DESC
LIMIT 8,10;
Build Insert SQl
insert one row
from pysqler import *
query = Insert("people")
query.put("name", "barry")
query.put("age", 10, value_on_duplicated=20)
express = Expression()
express.field("salary")
express.operator("+")
express.value(200)
express.operator("*")
express.value(3.5)
query.put("salary", 1000, value_on_duplicated=express)
query.put("address", "shanghai", value_on_duplicated="china")
query.put("education", "bachelor")
query.put("job", "engineer")
query.put("birthday", "2000-01-01")
query_str = str(query)
print(query_str)
output:
INSERT INTO people ( name,age,salary,address,education,jobs,birthday)
VALUES("barry",10,1000,"shanghai","bachelor","engineer","2000-01-01")
ON DUPLICATE KEY UPDATE age = 20,salary = salary + 200 * 3.5,
address = "china";
insert multiple rows
from pysqler import *
query = Insert("people")
query.add_columns("name", "age", "salary", "address", "education", "job", "birthday")
query.add_row("barry", 19, 3100, "shanghai", "bachelor", None,"2010-01-01")
query.add_row("jack", 24, 3600, "shanghai", "bachelor", "engineer","2010-01-09")
query.add_row("bob", 27, 8600, None, "bachelor", "engineer","1990-01-09")
query.add_row("edwin", 30, 10600, "beijing", "bachelor", "engineer","1987-01-09")
query_str = str(query)
print(query_str)
output:
INSERT INTO people ( name,age,salary,address,education,job,birthday )
VALUES( "barry",19,3100,"shanghai","bachelor",null,"2010-01-01" ),
( "jack",24,3600,"shanghai","bachelor","engineer","2010-01-09" ),
( "bob",27,8600,null,"bachelor","engineer","1990-01-09" ),
( "edwin",30,10600,"beijing","bachelor","engineer","1987-01-09" )
Build update SQl
from pysqler import *
query = Update("people")
query.put("name", "barry")
query.put("age", 10)
query.where("age", ">", 15)
query.or_where("age", "<", 5)
query_str = str(query)
print(query_str)
output:
UPDATE people SET name = "barry",age = 10
WHERE age > 15 OR age < 5;
Build delete SQl
from pysqler import *
query = Delete("people")
query.where("age", ">", 15)
query.or_where("name", "in", [9527, "barry", "jack"])
query_str = str(query)
print(query_str)
output:
DELETE FROM people WHERE age > 15 OR name in (9527,"barry","jack");
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
pysqler-0.9.0.tar.gz
(10.0 kB
view details)
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file pysqler-0.9.0.tar.gz.
File metadata
- Download URL: pysqler-0.9.0.tar.gz
- Upload date:
- Size: 10.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.1.0 requests-toolbelt/0.9.1 tqdm/4.34.0 CPython/3.7.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bcb398c39d9b355026e14dbd5e5c8706d7081c5722a9afdc6e7661bc5b1fc493
|
|
| MD5 |
d5ec8a67051394140d9d3a592c9869f3
|
|
| BLAKE2b-256 |
47f2c48e8f02ed72dd06ec6f452e4c0d840a31af7010a9c56ae72ba42ab18424
|
File details
Details for the file pysqler-0.9.0-py2.py3-none-any.whl.
File metadata
- Download URL: pysqler-0.9.0-py2.py3-none-any.whl
- Upload date:
- Size: 10.4 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.1.0 requests-toolbelt/0.9.1 tqdm/4.34.0 CPython/3.7.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d249c3ce45296f9feed58ef90c759e5fa0387af2d13f28a4b0c8279aa0349311
|
|
| MD5 |
a0c075e07f4055ddd3ecc9104fb727db
|
|
| BLAKE2b-256 |
57415593e5e4b4c5c1aa6ff449b460a0b95ce97af91220f74c8b4e1c19a16a41
|