Cloud SQL for MySQL for LangChain
|preview| |pypi| |versions|
Client Library Documentation
_Product Documentation
_
.. |preview| image:: https://img.shields.io/badge/support-preview-orange.svg
:target: https://cloud.google.com/products#product-launch-stages
.. |pypi| image:: https://img.shields.io/pypi/v/langchain-google-cloud-sql-mysql.svg
:target: https://pypi.org/project/langchain-google-cloud-sql-mysql/
.. |versions| image:: https://img.shields.io/pypi/pyversions/langchain-google-cloud-sql-mysql.svg
:target: https://pypi.org/project/langchain-google-cloud-sql-mysql/
.. _Client Library Documentation: https://cloud.google.com/python/docs/reference/langchain-google-cloud-sql-mysql/latest
.. _Product Documentation: https://cloud.google.com/sql/mysql
Quick Start
In order to use this library, you first need to go through the following
steps:
Select or create a Cloud Platform project.
_Enable billing for your project.
_Enable the Google Cloud SQL Admin API.
_Setup Authentication.
_
.. _Select or create a Cloud Platform project.: https://console.cloud.google.com/project
.. _Enable billing for your project.: https://cloud.google.com/billing/docs/how-to/modify-project#enable_billing_for_a_project
.. _Enable the Google Cloud SQL Admin API.: https://console.cloud.google.com/flows/enableapi?apiid=sqladmin.googleapis.com
.. _Setup Authentication.: https://googleapis.dev/python/google-api-core/latest/auth.html
Installation
Install this library in a `virtualenv`_ using pip. `virtualenv`_ is a tool to create isolated Python environments. The basic problem it addresses is
one of dependencies and versions, and indirectly permissions.
With `virtualenv`_, it’s possible to install this library without needing system install permissions, and without clashing with the installed system dependencies.
.. _`virtualenv`: https://virtualenv.pypa.io/en/latest/
Supported Python Versions
^^^^^^^^^^^^^^^^^^^^^^^^^
Python >= 3.8
Mac/Linux
^^^^^^^^^
.. code-block:: console
pip install virtualenv
virtualenv <your-env>
source <your-env>/bin/activate
<your-env>/bin/pip install langchain-google-cloud-sql-mysql
Windows
^^^^^^^
.. code-block:: console
pip install virtualenv
virtualenv <your-env>
<your-env>\Scripts\activate
<your-env>\Scripts\pip.exe install langchain-google-cloud-sql-mysql
Vector Store Usage
Use a vector store to store embedded data and perform vector search.
.. code-block:: python
from langchain_google_cloud_sql_mysql import MySQLEngine, MySQLVectorStore
from langchain_google_vertexai import VertexAIEmbeddings
engine = MySQLEngine.from_instance("project-id", "region", "my-instance", "my-database")
engine.init_vectorstore_table(
table_name="my-table-name",
vector_size=768
)
vectorstore = MySQLVectorStore(
engine,
embedding_service=VertexAIEmbeddings(model_name="textembedding-gecko@003"),
table_name="my-table-name"
)
See the full Vector Store
_ tutorial.
.. _Vector Store
: https://github.com/googleapis/langchain-google-cloud-sql-mysql-python/blob/main/docs/vector_store.ipynb
Document Loader Usage
Use a document loader to load data as LangChain ``Document``\ s.
.. code-block:: python
from langchain_google_cloud_sql_mysql import MySQLEngine, MySQLLoader
engine = MySQLEngine.from_instance("project-id", "region", "my-instance", "my-database")
loader = MySQLLoader(
engine,
table_name="my-table-name"
)
docs = loader.lazy_load()
See the full `Document Loader`_ tutorial.
.. _`Document Loader`: https://github.com/googleapis/langchain-google-cloud-sql-mysql-python/blob/main/docs/document_loader.ipynb
Chat Message History Usage
--------------------------
Use ``ChatMessageHistory`` to store messages and provide conversation
history to LLMs.
.. code:: python
from langchain_google_cloud_sql_mysql import MySQLChatMessageHistory, MySQLEngine
engine = MySQLEngine.from_instance("project-id", "region", "my-instance", "my-database")
history = MySQLChatMessageHistory(
engine,
table_name="my-message-store",
session_id="my-session-id"
)
See the full `Chat Message History`_ tutorial.
.. _`Chat Message History`: https://github.com/googleapis/langchain-google-cloud-sql-mysql-python/blob/main/docs/chat_message_history.ipynb
Contributions
~~~~~~~~~~~~~
Contributions to this library are always welcome and highly encouraged.
See `CONTRIBUTING`_ for more information how to get started.
Please note that this project is released with a Contributor Code of Conduct. By participating in
this project you agree to abide by its terms. See `Code of Conduct`_ for more
information.
.. _`CONTRIBUTING`: https://github.com/googleapis/langchain-google-cloud-sql-mysql-python/blob/main/CONTRIBUTING.md
.. _`Code of Conduct`: https://github.com/googleapis/langchain-google-cloud-sql-mysql-python/blob/main/CODE_OF_CONDUCT.md
License
-------
Apache 2.0 - See
`LICENSE <https://github.com/googleapis/langchain-google-cloud-sql-mysql-python/blob/main/LICENSE>`_
for more information.
Disclaimer
----------
This is not an officially supported Google product.