اس کیوال الکمی

دانشنامه عمومی

اس کیوال الکمی ( انگلیسی: SQLAlchemy ) یک مجموعه ابزار منبع باز اس کیوال و یک نگاشت دهنده شی - رابطه ای ( انگلیسی: object - relational mapper ) یا ORM برای زبان برنامه نویسی پایتون با پروانه ام ای تی ( انگلیسی: MIT Licence ) است.
SQLAlchemy "یک مجموعه کامل از الگوهای مانایی ( انگلیسی: persistence patterns ) که برای دسترسی بهینه و با عملکرد عالی به پایگاه داده طراحی شده اند را فراهم می کند. این مجموعه الگوها در زبان برنامه نویسی پایتون گنجانده شده است. فلسفه SQLAlchemy این است که هنگام دسترسی به پایگاه داده، پایگاه داده های اس کیو ال، هر چه کمتر شبیه مجموعه ای از اشیا رفتار کنند و هنگام افزایش سطح انتزاع هر چه کمتر شبیه جداول و سطر های پایگاه داده رابطه ای به نظر برسند. به همین دلیل SQLAlchemy به جای استفاده از "الگوی ثبت کُنِش وَر" ( انگلیسی: active record pattern ) که پیش از آن بوسیلهٔ تعدادی از نگاشت دهنده های شی - رابطه ای استفاده شده بود، "الگوی نگاشت دهنده داده" ( انگلیسی: data mapper pattern ) ( مثل هایبرنیت در جاوا ) را به کار گرفته است. [ ۴] گرچه افزونه هایی وجود دارد که به کاربر اجازه توسعه با استفاده از نحو اعلانی ( انگلیسی: declarative syntax ) را می دهد. [ ۵]
SQLAlchemy برای اولین بار در مارس ۲۰۰۶ منتشر شد[ ۶] و به سرعت به همراه ORM جنگو، به یکی از ابزارهای نگاشت دهنده شی - رابطه ای پراستفاده در میان برنامه نویسان پایتون تبدیل شد.
مثال زیر نشان دهنده یک رابطه n - به - ۱ بین فیلم ها و کارگرداناننشان است. در این مثال نشان داده خواهد شد که
• چگونه از کلاس های تعریف شده توسط کاربران، جداول پایگاه داده ایجاد می شوند
• چگونه نمونه های دارای رابطه توسط دو سوی رابطه ساخته می شوند
• چگونه قادر هستیم به داده ها دسترسی پیدا کنیم ( که نشان دهنده قابلیت کوئری های SQLی که به صورت خودکار تولید شده اند برای بارگذاری زرنگ ( انگلیسی: eager loading ) و تنبل ( انگلیسی: lazy loading ) است.
ایجاد دو کلاس پایتون و جداول پایگاه داده متناظر در DBMS:
from sqlalchemy import * from sqlalchemy. ext. declarative import declarative_base from sqlalchemy. orm import relation, sessionmaker Base = declarative_base ( ) class Movie ( Base ) : __tablename__ = ' movies' id = Column ( Integer, primary_key=True ) title = Column ( String ( 255 ) , nullable=False ) year = Column ( Integer ) directed_by = Column ( Integer, ForeignKey ( ' directors. id' ) ) director = relation ( " Director" , backref=' movies' , lazy=False ) def __init__ ( self, title=None, year=None ) : self. title = title self. year = year def __repr__ ( self ) : return " Movie ( %r, %r, %r ) " % ( self. title, self. year, self. director ) class Director ( Base ) : __tablename__ = ' directors' id = Column ( Integer, primary_key=True ) name = Column ( String ( 50 ) , nullable=False, unique=True ) def __init__ ( self, name=None ) : self. name = name def __repr__ ( self ) : return " Director ( %r ) " % ( self. name ) engine = create_engine ( ' dbms://user:pwd@host/dbname' ) Base. metadata. create_all ( engine ) عمل Insertion امکان insert کردن رابطه کارگردان - فیلم به وسیلهٔ هر یک از موجودیت ها:
عکس اس کیوال الکمیعکس اس کیوال الکمی
این نوشته برگرفته از سایت ویکی پدیا می باشد، اگر نادرست یا توهین آمیز است، لطفا گزارش دهید: گزارش تخلف

پیشنهاد کاربران