{"id":9504,"date":"2024-10-27T17:29:20","date_gmt":"2024-10-27T08:29:20","guid":{"rendered":"https:\/\/www.skyer9.pe.kr\/wordpress\/?p=9504"},"modified":"2024-10-29T17:17:41","modified_gmt":"2024-10-29T08:17:41","slug":"python-sqlalchemy","status":"publish","type":"post","link":"https:\/\/www.skyer9.pe.kr\/wordpress\/?p=9504","title":{"rendered":"Python &#8211; SQLAlchemy"},"content":{"rendered":"<h1>Python &#8211; SQLAlchemy<\/h1>\n<p>CRUD \uc758 \uc2dc\uc810\uc744 <code>session.commit()<\/code> \uc774 \ud638\ucd9c\ub418\ub294 \uc2dc\uc810\uc73c\ub85c \ucd5c\ub300\ud55c \ubbf8\ub8e8\uae30\ub54c\ubb38\uc5d0,<br \/>\n\ub370\uc774\ud0c0\ubca0\uc774\uc2a4 \uc811\uc18d\uc744 \ucd5c\uc18c\ud654\ud560 \uc218 \uc788\uc2b5\ub2c8\ub2e4.<\/p>\n<p>\ub2e4\ub9cc, <code>session.commit()<\/code> \uc744 \ub204\ub77d\ud558\uba74 \ub2f9\uc5f0\ud788 \ub864\ubc31\ub429\ub2c8\ub2e4.<\/p>\n<h2>\ud14c\uc774\ube14 \uc0dd\uc131<\/h2>\n<pre><code class=\"language-sql\">CREATE TABLE `user` (\n    `id` INT(11) NOT NULL AUTO_INCREMENT,\n    `username` VARCHAR(256) NOT NULL DEFAULT &#039;0&#039; COLLATE &#039;utf8mb4_general_ci&#039;,\n    `email` VARCHAR(256) NOT NULL DEFAULT &#039;0&#039; COLLATE &#039;utf8mb4_general_ci&#039;,\n    PRIMARY KEY (`id`) USING BTREE\n)\nCOLLATE=&#039;utf8mb4_general_ci&#039;\nENGINE=InnoDB\n;<\/code><\/pre>\n<p>VSCode \uc5d0\uc11c session \uc5d0 \ub300\ud55c \uc790\ub3d9\uc644\uc131\uc774 \ud544\uc694\ud558\uba74 Pylance \ub97c \uc124\uce58\ud574\uc57c \ud569\ub2c8\ub2e4.<br \/>\n\uc124\uce58 \ud6c4 VSCode \ub97c \uc7ac\uc2e4\ud589\ud574\uc57c \ud569\ub2c8\ub2e4.<\/p>\n<pre><code class=\"language-python\">from __future__ import annotations\n\nfrom sqlalchemy import create_engine\nfrom sqlalchemy.orm import sessionmaker, declarative_base\nfrom sqlalchemy import Column, Integer, String, DateTime, Boolean\n\nengine = create_engine(&#039;mysql+mysqldb:\/\/root:12345678@localhost:3306\/testdb&#039;)\nSession = sessionmaker(engine)\nsession = Session()\n\nBase = declarative_base()\n\nclass User(Base):\n    __tablename__ = &#039;user&#039;\n    id = Column(Integer, primary_key=True)\n    username = Column(String)\n    email = Column(String)\n    # time = Column(DateTime, default=datetime.datetime.utcnow, primary_key=True)\n    def __init__(self, user: User):\n        # self.id = user.id\n        self.username = user.username\n        self.email = user.email\n    def __init__(self, username: str, email: str):\n        # self.id = user.id\n        self.username = username\n        self.email = email\n    def update(self, user: User):\n        self.username = user.username\n        self.email = user.email<\/code><\/pre>\n<h2>\ud14c\uc2a4\ud2b8 \ud658\uacbd \uad6c\ucd95<\/h2>\n<pre><code class=\"language-bash\">pip install sqlalchemy\npip install mysqlclient<\/code><\/pre>\n<h2>insert<\/h2>\n<pre><code class=\"language-python\"># insert\nuser = User(username=&quot;Lee&quot;, email=&quot;aaa@aaa.com&quot;)\nsession.add(user)\nsession.commit()<\/code><\/pre>\n<h2>select<\/h2>\n<p><code>user: User<\/code> \uc640 \uac19\uc774 \ud0c0\uc785\uc744 \uba85\uc2dc\ud574 \uc8fc\uc5b4\uc57c \uc790\ub3d9\uc644\uc131\uc774 \uc791\ub3d9\ud569\ub2c8\ub2e4.<\/p>\n<pre><code class=\"language-python\"># select one\nuser: User = session.query(User).filter(User.username == &quot;Lee&quot;).first()\n# user: User = session.query(User).filter(User.username == &quot;Lee 2&quot;, User.id == 2).first()\nprint(user.id)<\/code><\/pre>\n<pre><code class=\"language-python\"># select all\nusers: List[User] = session.query(User).filter(User.username == &quot;Lee&quot;).all()\n# users: List[User] = session.query(User).filter(User.username == &quot;Lee 2&quot;).order_by(User.id.desc()).all()\nfor user in users:\n    print(user.id)<\/code><\/pre>\n<h2>update<\/h2>\n<pre><code class=\"language-python\"># update one\nuser2 = User(username=&quot;Lee 2&quot;, email=&quot;aaa2@aaa.com&quot;)\nuser: User = session.query(User).filter(User.username == &quot;Lee&quot;).first()\nuser.update(user2)\n\n# update list\nuser2 = User(username=&quot;Lee 2&quot;, email=&quot;aaa2@aaa.com&quot;)\nusers: List[User] = session.query(User).filter(User.username == &quot;Lee&quot;).all()\nfor user in users:\n    user.update(user2)\n\n# \ucee4\ubc0b\uc744 \ud560 \ub54c \uc790\ub3d9\uc73c\ub85c update \ubb38\uc774 \uc2e4\ud589\ub41c\ub2e4.\nsession.commit()<\/code><\/pre>\n<h2>delete<\/h2>\n<pre><code class=\"language-python\"># delete\nuser: User = session.query(User).filter(User.id == 1).first()\nif user is not None:\n    session.delete(user)\nsession.commit()<\/code><\/pre>\n","protected":false},"excerpt":{"rendered":"<p>Python &#8211; SQLAlchemy CRUD \uc758 \uc2dc\uc810\uc744 session.commit() \uc774 \ud638\ucd9c\ub418\ub294 \uc2dc\uc810\uc73c\ub85c \ucd5c\ub300\ud55c \ubbf8\ub8e8\uae30\ub54c\ubb38\uc5d0, \ub370\uc774\ud0c0\ubca0\uc774\uc2a4 \uc811\uc18d\uc744 \ucd5c\uc18c\ud654\ud560 \uc218 \uc788\uc2b5\ub2c8\ub2e4. \ub2e4\ub9cc, session.commit() \uc744 \ub204\ub77d\ud558\uba74 \ub2f9\uc5f0\ud788 \ub864\ubc31\ub429\ub2c8\ub2e4. \ud14c\uc774\ube14 \uc0dd\uc131 CREATE TABLE `user` ( `id` INT(11) NOT NULL AUTO_INCREMENT, `username` VARCHAR(256) NOT NULL DEFAULT &#039;0&#039; COLLATE &#039;utf8mb4_general_ci&#039;, `email` VARCHAR(256) NOT NULL DEFAULT &#039;0&#039; COLLATE &#039;utf8mb4_general_ci&#039;, PRIMARY KEY (`id`) USING BTREE\u2026 <span class=\"read-more\"><a href=\"https:\/\/www.skyer9.pe.kr\/wordpress\/?p=9504\">Read More &raquo;<\/a><\/span><\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[15],"tags":[],"class_list":["post-9504","post","type-post","status-publish","format-standard","hentry","category-python"],"_links":{"self":[{"href":"https:\/\/www.skyer9.pe.kr\/wordpress\/index.php?rest_route=\/wp\/v2\/posts\/9504","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.skyer9.pe.kr\/wordpress\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.skyer9.pe.kr\/wordpress\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.skyer9.pe.kr\/wordpress\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.skyer9.pe.kr\/wordpress\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=9504"}],"version-history":[{"count":9,"href":"https:\/\/www.skyer9.pe.kr\/wordpress\/index.php?rest_route=\/wp\/v2\/posts\/9504\/revisions"}],"predecessor-version":[{"id":9513,"href":"https:\/\/www.skyer9.pe.kr\/wordpress\/index.php?rest_route=\/wp\/v2\/posts\/9504\/revisions\/9513"}],"wp:attachment":[{"href":"https:\/\/www.skyer9.pe.kr\/wordpress\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=9504"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.skyer9.pe.kr\/wordpress\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=9504"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.skyer9.pe.kr\/wordpress\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=9504"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}