{"cells":[{"cell_type":"code","source":"from google.colab import drive\nimport os\ndrive.mount('/content/gdrive')\n# Establecer ruta de acceso en drive\nimport os\nprint(os.getcwd())\nos.chdir(\"/content/gdrive/My Drive\")","metadata":{"id":"To5mf98BeUz3","colab":{"base_uri":"https://localhost:8080/"},"cell_id":"f3e54e94abf24f5eb361a2e46b8daa2d","outputId":"7b9aefdb-5e07-4929-8c34-08df9f9223ed","executionInfo":{"user":{"userId":"04741209928239412574","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi4e7mWJaOA2l-1KUn-omyigRGSrm83lG6XLzS5=s64","displayName":"david francisco bustos usta"},"status":"ok","elapsed":2017,"user_tz":300,"timestamp":1643069140589},"deepnote_cell_type":"code"},"outputs":[{"output_type":"stream","name":"stdout","text":"Drive already mounted at /content/gdrive; to attempt to forcibly remount, call drive.mount(\"/content/gdrive\", force_remount=True).\n/content/gdrive/My Drive/Clase13_David\n"}],"execution_count":null},{"cell_type":"code","source":"%cd '/content/gdrive/My Drive/Clase13_David'","metadata":{"id":"Pmeq3yTjf29X","colab":{"base_uri":"https://localhost:8080/"},"cell_id":"fa0f5c7ff7334b39bcdc4af017d3ffc7","outputId":"8b129545-c067-40d3-c3f2-fa75c8b883e1","executionInfo":{"user":{"userId":"04741209928239412574","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi4e7mWJaOA2l-1KUn-omyigRGSrm83lG6XLzS5=s64","displayName":"david francisco bustos usta"},"status":"ok","elapsed":237,"user_tz":300,"timestamp":1643069148987},"deepnote_cell_type":"code"},"outputs":[{"output_type":"stream","name":"stdout","text":"/content/gdrive/My Drive/Clase13_David\n"}],"execution_count":null},{"cell_type":"markdown","source":"Tenemos diferentes librerías como SQLite, MySQL y PostgreSQL. Exploraremos un poco en esta oportunidad SQLite","metadata":{"id":"vD0eMXoNlvnz","cell_id":"6a556f99b24c4268b28bf0b140ef7c41","deepnote_cell_type":"markdown"}},{"cell_type":"markdown","source":"Pagina para diagramas ER\n\nhttps://dbdiagram.io/\n\nEjemplo de codigo para crear diagrama entidad relacion:\n\n```sql\n//// -- LEVEL 1\n//// -- Tables and References\n// Creating tables\nTable users as U{\n id int [pk,increment]\n name varchar [not null]\n age int\n gender varchar\n nationality varchar\n}\n\n//// -- LEVEL 2\n//// -- Adding column settings\n\nTable posts {\n id int [pk,increment]\n title varchar [not null]\n description varchar [not null]\n user_id int [ref: > users.id,not null] // inline relationship (many-to-one)\n}\n\nTable comments {\n id int [pk, increment]\n text_ varchar [not null]\n user_id int [ref: > users.id,not null] // inline relationship (many-to-one)\n post_id int [ref: > posts.id, not null]\n}\n\nTable likes {\n id int [pk,increment]\n user_id int [ref: > users.id, not null]\n post_id int [ref: > posts.id, not null]\n}\n\n```","metadata":{"id":"8gi5wBqe7jK7","cell_id":"28d8dc5bec23481ab38e28b1d55ea6ad","deepnote_cell_type":"markdown"}},{"cell_type":"markdown","source":"![ejemplo.jpg]()","metadata":{"id":"0VIskRHz8BsK","cell_id":"4a7c8ba6f82c43b6a42edbb32f96148d","deepnote_cell_type":"markdown"}},{"cell_type":"markdown","source":"# SQL Lite\n\nSQLite es probablemente la base de datos más sencilla para conectarse con una aplicación de Python, ya que no necesita instalar ningún módulo SQL de Python externo para hacerlo. De manera predeterminada, su instalación de Python contiene una biblioteca SQL de Python llamada sqlite3 que puede usar para interactuar con una base de datos SQLite.\n\nAdemás, las bases de datos SQLite no tienen servidor y son independientes, ya que leen y escriben datos en un archivo. Esto significa que, a diferencia de MySQL y PostgreSQL, ¡ni siquiera necesita instalar y ejecutar un servidor SQLite para realizar operaciones de base de datos!\n\nMiremos como conectarnos a sqlite3 con una base de datos en Python:","metadata":{"id":"S5XOdMpZecHs","cell_id":"239ec699cf3146ffa1cbb03525aeaea8","deepnote_cell_type":"markdown"}},{"cell_type":"code","source":"import sqlite3\nfrom sqlite3 import Error # Importar librerias\ndef create_connection(path): # Definir funcion crear conexion\n connection = None\n try:\n connection = sqlite3.connect(path) # uso de connect() que recibe una ruta a la base de datos SQLLite (puede estar en la ram o no)\n print(\"Conexion a SQLite DB exitosa\") # Si la conexion es exitosa se imprime\n except Error as e: # Si existe algun error\n print(f\"El error '{e}' ha ocurrido\") # mostrar el error\n return connection","metadata":{"id":"0Q-u6bE9ec_a","cell_id":"9d56644640574f1083200d2ed2a4a2a8","deepnote_cell_type":"code"},"outputs":[],"execution_count":null},{"cell_type":"markdown","source":"```sqlite3.connect(ruta)``` devuelve un objeto de conexión, que a su vez es devuelto por ```create_connection()```. Este objeto de conexión se puede utilizar para ejecutar consultas en una base de datos SQLite. El siguiente script crea una conexión a la base de datos SQLite:","metadata":{"id":"-T4lyhGtfCLK","cell_id":"ca2b4b8a57c4406fb63acc0ebbbd45da","deepnote_cell_type":"markdown"}},{"cell_type":"code","source":"connection = create_connection(\"E:\\\\sm_app.sqlite\")","metadata":{"id":"8qW2YUR-fbMY","colab":{"base_uri":"https://localhost:8080/"},"cell_id":"5408b1540a5b4c7c9ce2a8e0e28687e6","outputId":"851c035f-2b37-4521-c2ce-eed6a80b4f83","executionInfo":{"user":{"userId":"04741209928239412574","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi4e7mWJaOA2l-1KUn-omyigRGSrm83lG6XLzS5=s64","displayName":"david francisco bustos usta"},"status":"ok","elapsed":369,"user_tz":300,"timestamp":1642989653691},"deepnote_cell_type":"code"},"outputs":[{"output_type":"stream","name":"stdout","text":"Conexion a SQLite DB exitosa\n"}],"execution_count":null},{"cell_type":"code","source":"# Puede tener cualquier nombre\nconnection = create_connection(\"david.sqlite\")","metadata":{"id":"8U9N7UfMaAPw","colab":{"base_uri":"https://localhost:8080/"},"cell_id":"5c3702a6a37146a0841422aeff5cc5b9","outputId":"399d7e5e-0a76-44bc-ebbc-273b4b879f61","executionInfo":{"user":{"userId":"04741209928239412574","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi4e7mWJaOA2l-1KUn-omyigRGSrm83lG6XLzS5=s64","displayName":"david francisco bustos usta"},"status":"ok","elapsed":305,"user_tz":300,"timestamp":1643069544874},"deepnote_cell_type":"code"},"outputs":[{"output_type":"stream","name":"stdout","text":"Conexion a SQLite DB exitosa\n"}],"execution_count":null},{"cell_type":"markdown","source":"Ahora se crea un archivo de base de datos sm_app.sqlite en el directorio raíz. Tenga en cuenta que puede cambiar la ubicación para que coincida con su configuración.","metadata":{"id":"4Gut-NXsfjkI","cell_id":"f06772175e2944799ceb9113579400b4","deepnote_cell_type":"markdown"}},{"cell_type":"markdown","source":"# Crear tablas SQL Lite\n\nPara ejecutar consultas en SQLite, debemos usar ```cursor.execute()```. Definiremos una función llamada ```execute_query()``` que usa este método. Su función aceptará el objeto de conexión y una cadena de consulta, que pasará a ```cursor.execute()```.\n\n```.execute()``` puede ejecutar cualquier consulta que se le pase en forma de string. ","metadata":{"id":"dyqNm9efgMo2","cell_id":"6ef298f92c724312be5f29f15c5daa2c","deepnote_cell_type":"markdown"}},{"cell_type":"code","source":"def execute_query(connection, query):\n cursor = connection.cursor()\n try:\n cursor.execute(query)\n connection.commit()\n print(\"Query ejecutado satisfactoriamente\")\n except Error as e:\n print(f\"El error '{e}' ha ocurrido\")","metadata":{"id":"A1X-PpLrgOVp","cell_id":"815b88803c374d11971259edb3d7c9d9","deepnote_cell_type":"code"},"outputs":[],"execution_count":null},{"cell_type":"markdown","source":"Creamos el query","metadata":{"id":"_TNAxoJ6gw3u","cell_id":"1711b9d97a1d416691f6aa7862703b40","deepnote_cell_type":"markdown"}},{"cell_type":"code","source":"crear_tabla_usuarios = \"\"\"\nCREATE TABLE IF NOT EXISTS users (\n id INTEGER PRIMARY KEY AUTOINCREMENT,\n name TEXT NOT NULL,\n age INTEGER,\n gender TEXT,\n nationality TEXT\n);\n\"\"\"","metadata":{"id":"0RgAnHYzgyHY","cell_id":"2b6ffff49ce5473596e0fc16695c01b0","deepnote_cell_type":"code"},"outputs":[],"execution_count":null},{"cell_type":"code","source":"execute_query(connection, crear_tabla_usuarios) ","metadata":{"id":"W5KkugPhg3g0","colab":{"base_uri":"https://localhost:8080/"},"cell_id":"4ef4db7ffd9a452ca0bddff962442dba","outputId":"d59447a1-b3c5-418f-814f-ca8a7f05e3ac","executionInfo":{"user":{"userId":"04741209928239412574","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi4e7mWJaOA2l-1KUn-omyigRGSrm83lG6XLzS5=s64","displayName":"david francisco bustos usta"},"status":"ok","elapsed":220,"user_tz":300,"timestamp":1643069683946},"deepnote_cell_type":"code"},"outputs":[{"output_type":"stream","name":"stdout","text":"Query ejecutado satisfactoriamente\n"}],"execution_count":null},{"cell_type":"code","source":"crear_tabla_posts = \"\"\"\nCREATE TABLE IF NOT EXISTS posts(\n id INTEGER PRIMARY KEY AUTOINCREMENT, \n title TEXT NOT NULL, \n description TEXT NOT NULL, \n user_id INTEGER NOT NULL, \n FOREIGN KEY (user_id) REFERENCES users (id)\n);\n\"\"\"\n# Dado que existe una relación de uno a muchos entre los usuarios y las publicaciones, \n# veran una clave externa user_id en la tabla de publicaciones que hace referencia \n# a la columna de identificación en la tabla de usuarios. ","metadata":{"id":"WUBwWVTghQgt","cell_id":"b2baa90cd524489094098ba5f0ba1538","deepnote_cell_type":"code"},"outputs":[],"execution_count":null},{"cell_type":"code","source":"execute_query(connection, crear_tabla_posts)","metadata":{"id":"N2VF7x4IhiVw","colab":{"base_uri":"https://localhost:8080/"},"cell_id":"96b174aeb1774c1b9f4c1f44582431e5","outputId":"49ce33ad-da46-4078-c360-8e3f4167ff8f","executionInfo":{"user":{"userId":"04741209928239412574","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi4e7mWJaOA2l-1KUn-omyigRGSrm83lG6XLzS5=s64","displayName":"david francisco bustos usta"},"status":"ok","elapsed":217,"user_tz":300,"timestamp":1643069753230},"deepnote_cell_type":"code"},"outputs":[{"output_type":"stream","name":"stdout","text":"Query ejecutado satisfactoriamente\n"}],"execution_count":null},{"cell_type":"markdown","source":"Creamos dos tablas","metadata":{"id":"ePb_M8_5iTrL","cell_id":"2b65c122addc488ab8c1dfbafefe7ff1","deepnote_cell_type":"markdown"}},{"cell_type":"code","source":"crear_tabla_comentarios = \"\"\"\nCREATE TABLE IF NOT EXISTS comments (\n id INTEGER PRIMARY KEY AUTOINCREMENT, \n text TEXT NOT NULL, \n user_id INTEGER NOT NULL, \n post_id INTEGER NOT NULL, \n FOREIGN KEY (user_id) REFERENCES users (id) FOREIGN KEY (post_id) REFERENCES posts (id)\n);\n\"\"\"\n\ncrear_tabla_likes = \"\"\"\nCREATE TABLE IF NOT EXISTS likes (\n id INTEGER PRIMARY KEY AUTOINCREMENT, \n user_id INTEGER NOT NULL, \n post_id integer NOT NULL, \n FOREIGN KEY (user_id) REFERENCES users (id) FOREIGN KEY (post_id) REFERENCES posts (id)\n);\n\"\"\"\n\nexecute_query(connection, crear_tabla_comentarios) \nexecute_query(connection, crear_tabla_likes) ","metadata":{"id":"yTSGiU76iU5E","colab":{"base_uri":"https://localhost:8080/"},"cell_id":"b83c00e8e63f4dada3b4c477a918cfd8","outputId":"8ffff58a-6b01-4c37-b8fa-713068e76b10","executionInfo":{"user":{"userId":"04741209928239412574","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi4e7mWJaOA2l-1KUn-omyigRGSrm83lG6XLzS5=s64","displayName":"david francisco bustos usta"},"status":"ok","elapsed":216,"user_tz":300,"timestamp":1643069836151},"deepnote_cell_type":"code"},"outputs":[{"output_type":"stream","name":"stdout","text":"Query ejecutado satisfactoriamente\nQuery ejecutado satisfactoriamente\n"}],"execution_count":null},{"cell_type":"markdown","source":"# Insertar records","metadata":{"id":"B5iq3axBipnW","cell_id":"5dc599e74b734974a4e68c66cf26887b","deepnote_cell_type":"markdown"}},{"cell_type":"code","source":"crear_usuarios = \"\"\"\nINSERT INTO\n users (name, age, gender, nationality)\nVALUES\n ('James', 25, 'hombre', 'USA'),\n ('Leila', 32, 'mujer', 'France'),\n ('Brigitte', 35, 'mujer', 'England'),\n ('Mike', 40, 'hombre', 'Denmark'),\n ('Elizabeth', 21, 'mujer', 'Canada');\n\"\"\"\nexecute_query(connection, crear_usuarios) ","metadata":{"id":"GRWi9xh9iq-X","colab":{"base_uri":"https://localhost:8080/"},"cell_id":"2de13a6f26a449d0ae4c07a9fcd2fb0e","outputId":"9b3d778c-0aba-4cc9-854e-8a3c75613503","executionInfo":{"user":{"userId":"04741209928239412574","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi4e7mWJaOA2l-1KUn-omyigRGSrm83lG6XLzS5=s64","displayName":"david francisco bustos usta"},"status":"ok","elapsed":245,"user_tz":300,"timestamp":1643069872035},"deepnote_cell_type":"code"},"outputs":[{"output_type":"stream","name":"stdout","text":"Query ejecutado satisfactoriamente\n"}],"execution_count":null},{"cell_type":"markdown","source":"Como configuramos el id para que se incremente automáticamente, no necesita especificar el valor de la columna de identificación para estos usuarios. La tabla de usuarios completará automáticamente estos cinco registros con valores de identificación del 1 al 5.","metadata":{"id":"XXBL38HrjBO6","cell_id":"f8abba1ff8f7464d9eb2e84854c8aa69","deepnote_cell_type":"markdown"}},{"cell_type":"code","source":"crear_posts = \"\"\"\nINSERT INTO\n posts (title, description, user_id)\nVALUES\n (\"Feliz\", \"Me siento feliz hoy\", 1),\n (\"Caliente\", \"El clima esta caliente hoy\", 2),\n (\"Ayuda\", \"Necesito ayuda en esto\", 2),\n (\"Buenas noticias\", \"Me casare pronto\", 1),\n (\"Juego interesante\", \"Fue genial jugar al tenis\", 5),\n (\"Fiesta\", \"Alguno quiere venir a esta fiesta hoy?\", 3);\n\"\"\"\nexecute_query(connection, crear_posts) ","metadata":{"id":"ba4-iilri-a8","colab":{"base_uri":"https://localhost:8080/"},"cell_id":"27ac473e1ab342948bf3717347e39b90","outputId":"76329f00-d2f5-4048-9bd0-6ab9cf4b168c","executionInfo":{"user":{"userId":"04741209928239412574","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi4e7mWJaOA2l-1KUn-omyigRGSrm83lG6XLzS5=s64","displayName":"david francisco bustos usta"},"status":"ok","elapsed":228,"user_tz":300,"timestamp":1643069908337},"deepnote_cell_type":"code"},"outputs":[{"output_type":"stream","name":"stdout","text":"Query ejecutado satisfactoriamente\n"}],"execution_count":null},{"cell_type":"markdown","source":"Es importante mencionar que la columna ```user_id``` de la tabla de publicaciones es una **llave foranea** que hace referencia a la columna **id** de la tabla de usuarios. Esto significa que la columna ```user_id``` debe contener un valor que ya existe en la columna ```id`` de la tabla de usuarios. Si no existe, habrá un error.","metadata":{"id":"dplkrHcFjkUu","cell_id":"1abf02e3589e4cbaa9fd3339c75b1d4b","deepnote_cell_type":"markdown"}},{"cell_type":"code","source":"crear_comentarios = \"\"\"\nINSERT INTO\n comments (text, user_id, post_id)\nVALUES\n ('Cuenta conmigo', 1, 6),\n ('Que tipo de ayuda?', 5, 3),\n ('Felicitaciones', 2, 4),\n ('Estuve jugando con Rafael', 4, 5),\n ('Te ayudo con tu tesis?', 2, 3),\n ('Muchas felicitaciones', 5, 4);\n\"\"\"\n\ncrear_likes = \"\"\"\nINSERT INTO\n likes (user_id, post_id)\nVALUES\n (1, 6),\n (2, 3),\n (1, 5),\n (5, 4),\n (2, 4),\n (4, 2),\n (3, 6);\n\"\"\"\n\nexecute_query(connection, crear_comentarios)\nexecute_query(connection, crear_likes) ","metadata":{"id":"cpyj35lUjhai","colab":{"base_uri":"https://localhost:8080/"},"cell_id":"e039edb041bd45ab9da0e0670cd2e475","outputId":"24d31604-ca1e-4899-d266-80533f4f3195","executionInfo":{"user":{"userId":"04741209928239412574","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi4e7mWJaOA2l-1KUn-omyigRGSrm83lG6XLzS5=s64","displayName":"david francisco bustos usta"},"status":"ok","elapsed":224,"user_tz":300,"timestamp":1643069930140},"deepnote_cell_type":"code"},"outputs":[{"output_type":"stream","name":"stdout","text":"Query ejecutado satisfactoriamente\nQuery ejecutado satisfactoriamente\n"}],"execution_count":null},{"cell_type":"markdown","source":"# Seleccionando records","metadata":{"id":"d9fc4S7GkLIF","cell_id":"fd1f52f628f245c9918c5c5fb870da54","deepnote_cell_type":"markdown"}},{"cell_type":"code","source":"def execute_read_query(connection, query):\n cursor = connection.cursor()\n result = None\n try:\n cursor.execute(query)\n result = cursor.fetchall()\n return result\n except Error as e:\n print(f\"Error '{e}' ha ocurrido\")","metadata":{"id":"WEWgaW3YkMZe","cell_id":"5bacbba7ff8d479c8536fdfcc1803501","deepnote_cell_type":"code"},"outputs":[],"execution_count":null},{"cell_type":"code","source":"elegir_usuarios = \"SELECT * from users\"\nusers = execute_read_query(connection, elegir_usuarios)\n\nfor user in users:\n print(user)","metadata":{"id":"3ShOFAoTkWNz","colab":{"base_uri":"https://localhost:8080/"},"cell_id":"06c16104ff6742e0b7dd7fcaa33758fa","outputId":"92d903b2-90ee-49f0-d76c-4a01c1e73dad","executionInfo":{"user":{"userId":"04741209928239412574","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi4e7mWJaOA2l-1KUn-omyigRGSrm83lG6XLzS5=s64","displayName":"david francisco bustos usta"},"status":"ok","elapsed":231,"user_tz":300,"timestamp":1643070095247},"deepnote_cell_type":"code"},"outputs":[{"output_type":"stream","name":"stdout","text":"(1, 'James', 25, 'hombre', 'USA')\n(2, 'Leila', 32, 'mujer', 'France')\n(3, 'Brigitte', 35, 'mujer', 'England')\n(4, 'Mike', 40, 'hombre', 'Denmark')\n(5, 'Elizabeth', 21, 'mujer', 'Canada')\n(6, 'James', 25, 'hombre', 'USA')\n(7, 'Leila', 32, 'mujer', 'France')\n(8, 'Brigitte', 35, 'mujer', 'England')\n(9, 'Mike', 40, 'hombre', 'Denmark')\n(10, 'Elizabeth', 21, 'mujer', 'Canada')\n"}],"execution_count":null},{"cell_type":"code","source":"elegir_posts = \"SELECT * FROM posts\"\nposts = execute_read_query(connection, elegir_posts)\n\nfor post in posts:\n print(post)","metadata":{"id":"WB1hhJgAkmzZ","colab":{"base_uri":"https://localhost:8080/"},"cell_id":"0df0b63df0bd4949a0f25b98be6a17b2","outputId":"4fcd3bed-d806-4ab0-ea81-0d4aeed1a678","executionInfo":{"user":{"userId":"04741209928239412574","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi4e7mWJaOA2l-1KUn-omyigRGSrm83lG6XLzS5=s64","displayName":"david francisco bustos usta"},"status":"ok","elapsed":208,"user_tz":300,"timestamp":1643070138748},"deepnote_cell_type":"code"},"outputs":[{"output_type":"stream","name":"stdout","text":"(1, 'Feliz', 'Me siento feliz hoy', 1)\n(2, 'Caliente', 'El clima esta caliente hoy', 2)\n(3, 'Ayuda', 'Necesito ayuda en esto', 2)\n(4, 'Buenas noticias', 'Me casare pronto', 1)\n(5, 'Juego interesante', 'Fue genial jugar al tenis', 5)\n(6, 'Fiesta', 'Alguno quiere venir a esta fiesta hoy?', 3)\n(7, 'Feliz', 'Me siento feliz hoy', 1)\n(8, 'Caliente', 'El clima esta caliente hoy', 2)\n(9, 'Ayuda', 'Necesito ayuda en esto', 2)\n(10, 'Buenas noticias', 'Me casare pronto', 1)\n(11, 'Juego interesante', 'Fue genial jugar al tenis', 5)\n(12, 'Fiesta', 'Alguno quiere venir a esta fiesta hoy?', 3)\n"}],"execution_count":null},{"cell_type":"code","source":"joins_usuarios_posts = \"\"\"\nSELECT\n users.id,\n users.name,\n posts.description\nFROM\n posts\n INNER JOIN users ON users.id = posts.user_id\n\"\"\"\n\nusuarios_posts = execute_read_query(connection, joins_usuarios_posts)\n\nfor x in usuarios_posts:\n print(x)","metadata":{"id":"cYmQyFa6kuJc","colab":{"base_uri":"https://localhost:8080/"},"cell_id":"4f1c7db5ab0b49c8bd66ce53734bc5fc","outputId":"7ca12267-5ef6-4bc8-d489-813806272d3f","executionInfo":{"user":{"userId":"04741209928239412574","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi4e7mWJaOA2l-1KUn-omyigRGSrm83lG6XLzS5=s64","displayName":"david francisco bustos usta"},"status":"ok","elapsed":257,"user_tz":300,"timestamp":1643070254006},"deepnote_cell_type":"code"},"outputs":[{"output_type":"stream","name":"stdout","text":"(1, 'James', 'Me siento feliz hoy')\n(2, 'Leila', 'El clima esta caliente hoy')\n(2, 'Leila', 'Necesito ayuda en esto')\n(1, 'James', 'Me casare pronto')\n(5, 'Elizabeth', 'Fue genial jugar al tenis')\n(3, 'Brigitte', 'Alguno quiere venir a esta fiesta hoy?')\n(1, 'James', 'Me siento feliz hoy')\n(2, 'Leila', 'El clima esta caliente hoy')\n(2, 'Leila', 'Necesito ayuda en esto')\n(1, 'James', 'Me casare pronto')\n(5, 'Elizabeth', 'Fue genial jugar al tenis')\n(3, 'Brigitte', 'Alguno quiere venir a esta fiesta hoy?')\n"}],"execution_count":null},{"cell_type":"markdown","source":"El siguiente script devuelve todas las publicaciones, junto con los comentarios sobre las publicaciones y los nombres de los usuarios que publicaron los comentarios:","metadata":{"id":"K-dogfQTlE5v","cell_id":"90aa80f1d8214fcabe2cd975b1c5c0a2","deepnote_cell_type":"markdown"}},{"cell_type":"code","source":"elegir_publicaciones_comentarios_usuarios = \"\"\"\nSELECT\n posts.description as post,\n text as comment,\n name\nFROM\n posts\n INNER JOIN comments ON posts.id = comments.post_id\n INNER JOIN users ON users.id = comments.user_id\n\"\"\"\n\np_c_u = execute_read_query(\n connection, elegir_publicaciones_comentarios_usuarios\n)\n\nfor y in p_c_u:\n print(y)","metadata":{"id":"anlj5Hv8lHj_","colab":{"base_uri":"https://localhost:8080/"},"cell_id":"0ce490bfe79b4723897f5c3588980c29","outputId":"aee2d4b5-70d3-4941-ae6e-f26b5239a8fe","executionInfo":{"user":{"userId":"04741209928239412574","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi4e7mWJaOA2l-1KUn-omyigRGSrm83lG6XLzS5=s64","displayName":"david francisco bustos usta"},"status":"ok","elapsed":221,"user_tz":300,"timestamp":1643070316573},"deepnote_cell_type":"code"},"outputs":[{"output_type":"stream","name":"stdout","text":"('Alguno quiere venir a esta fiesta hoy?', 'Cuenta conmigo', 'James')\n('Necesito ayuda en esto', 'Que tipo de ayuda?', 'Elizabeth')\n('Me casare pronto', 'Felicitaciones', 'Leila')\n('Fue genial jugar al tenis', 'Estuve jugando con Rafael', 'Mike')\n('Necesito ayuda en esto', 'Te ayudo con tu tesis?', 'Leila')\n('Me casare pronto', 'Muchas felicitaciones', 'Elizabeth')\n('Alguno quiere venir a esta fiesta hoy?', 'Cuenta conmigo', 'James')\n('Necesito ayuda en esto', 'Que tipo de ayuda?', 'Elizabeth')\n('Me casare pronto', 'Felicitaciones', 'Leila')\n('Fue genial jugar al tenis', 'Estuve jugando con Rafael', 'Mike')\n('Necesito ayuda en esto', 'Te ayudo con tu tesis?', 'Leila')\n('Me casare pronto', 'Muchas felicitaciones', 'Elizabeth')\n"}],"execution_count":null},{"cell_type":"markdown","source":"Pueden ver en la salida que ```.fetchall()``` no devuelve los nombres de las columnas. Para devolver los nombres de las columnas, podemos usar el atributo ```.description```. Por ejemplo, la siguiente lista devuelve todos los nombres de columna para la consulta anterior:\n","metadata":{"id":"5Y1OumhHldG9","cell_id":"53e1c3252b0641f0b84804b8107c65f8","deepnote_cell_type":"markdown"}},{"cell_type":"code","source":"cursor = connection.cursor()\ncursor.execute(elegir_publicaciones_comentarios_usuarios)\ncursor.fetchall()\n\ncolumnas = [description[0] for description in cursor.description]\nprint(columnas)","metadata":{"id":"geWvC5HylmDM","colab":{"base_uri":"https://localhost:8080/"},"cell_id":"84b3ef987e3d4b03afc47054bc3b49f4","outputId":"fac17502-cd79-4790-fba0-242a2a481012","executionInfo":{"user":{"userId":"04741209928239412574","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi4e7mWJaOA2l-1KUn-omyigRGSrm83lG6XLzS5=s64","displayName":"david francisco bustos usta"},"status":"ok","elapsed":267,"user_tz":300,"timestamp":1643070384235},"deepnote_cell_type":"code"},"outputs":[{"output_type":"stream","name":"stdout","text":"['post', 'comment', 'name']\n"}],"execution_count":null},{"cell_type":"code","source":"!pip install --upgrade --no-deps git+https://github.com/psychemedia/eralchemy.git","metadata":{"id":"UBWCgxJz0Sv_","colab":{"base_uri":"https://localhost:8080/"},"cell_id":"97ebaacc3dfe4b92acf444fcb78a18b2","outputId":"82e965a3-dd6d-40ba-8eea-c841845044a4","executionInfo":{"user":{"userId":"04741209928239412574","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi4e7mWJaOA2l-1KUn-omyigRGSrm83lG6XLzS5=s64","displayName":"david francisco bustos usta"},"status":"ok","elapsed":2710,"user_tz":300,"timestamp":1642989772734},"deepnote_cell_type":"code"},"outputs":[{"output_type":"stream","name":"stdout","text":"Collecting git+https://github.com/psychemedia/eralchemy.git\n Cloning https://github.com/psychemedia/eralchemy.git to /tmp/pip-req-build-k2dl2w04\n Running command git clone -q https://github.com/psychemedia/eralchemy.git /tmp/pip-req-build-k2dl2w04\nBuilding wheels for collected packages: ERAlchemy\n Building wheel for ERAlchemy (setup.py) ... \u001b[?25l\u001b[?25hdone\n Created wheel for ERAlchemy: filename=ERAlchemy-1.2.9-py2.py3-none-any.whl size=16035 sha256=274e20bc4734e829a30000a97c790231b75b8377145513797515b762efa3f4d2\n Stored in directory: /tmp/pip-ephem-wheel-cache-gf3h31dh/wheels/37/8e/98/e2d119e6234149b152b3944b4504c85d43d00c7299615151f4\nSuccessfully built ERAlchemy\nInstalling collected packages: ERAlchemy\nSuccessfully installed ERAlchemy-1.2.9\n"}],"execution_count":null},{"cell_type":"code","source":"!pip install configparser\n! pip install sqlalchemy\n! pip install pydot\n! pip install sqlalchemy_schemadisplay\n! pip install graphviz","metadata":{"id":"vx2pwfVj1xKM","colab":{"height":542,"base_uri":"https://localhost:8080/"},"cell_id":"dd98b04b61b8499ca36aed6ea469cf2f","outputId":"806e5414-a035-4135-874c-91991b118bd6","executionInfo":{"user":{"userId":"04741209928239412574","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi4e7mWJaOA2l-1KUn-omyigRGSrm83lG6XLzS5=s64","displayName":"david francisco bustos usta"},"status":"ok","elapsed":16378,"user_tz":300,"timestamp":1642990110584},"deepnote_cell_type":"code"},"outputs":[{"output_type":"stream","name":"stdout","text":"Collecting configparser\n Downloading configparser-5.2.0-py3-none-any.whl (19 kB)\nInstalling collected packages: configparser\nSuccessfully installed configparser-5.2.0\n"},{"output_type":"display_data","data":{"application/vnd.colab-display-data+json":{"pip_warning":{"packages":["configparser"]}}},"metadata":{}},{"output_type":"stream","name":"stdout","text":"Requirement already satisfied: sqlalchemy in /usr/local/lib/python3.7/dist-packages (1.4.29)\nRequirement already satisfied: greenlet!=0.4.17 in /usr/local/lib/python3.7/dist-packages (from sqlalchemy) (1.1.2)\nRequirement already satisfied: importlib-metadata in /usr/local/lib/python3.7/dist-packages (from sqlalchemy) (4.10.0)\nRequirement already satisfied: typing-extensions>=3.6.4 in /usr/local/lib/python3.7/dist-packages (from importlib-metadata->sqlalchemy) (3.10.0.2)\nRequirement already satisfied: zipp>=0.5 in /usr/local/lib/python3.7/dist-packages (from importlib-metadata->sqlalchemy) (3.7.0)\nRequirement already satisfied: pydot in /usr/local/lib/python3.7/dist-packages (1.3.0)\nRequirement already satisfied: pyparsing>=2.1.4 in /usr/local/lib/python3.7/dist-packages (from pydot) (3.0.6)\nCollecting sqlalchemy_schemadisplay\n Downloading sqlalchemy_schemadisplay-1.3.zip (11 kB)\nRequirement already satisfied: setuptools in /usr/local/lib/python3.7/dist-packages (from sqlalchemy_schemadisplay) (57.4.0)\nRequirement already satisfied: pydot in /usr/local/lib/python3.7/dist-packages (from sqlalchemy_schemadisplay) (1.3.0)\nRequirement already satisfied: pyparsing>=2.1.4 in /usr/local/lib/python3.7/dist-packages (from pydot->sqlalchemy_schemadisplay) (3.0.6)\nBuilding wheels for collected packages: sqlalchemy-schemadisplay\n Building wheel for sqlalchemy-schemadisplay (setup.py) ... \u001b[?25l\u001b[?25hdone\n Created wheel for sqlalchemy-schemadisplay: filename=sqlalchemy_schemadisplay-1.3-py3-none-any.whl size=5928 sha256=a8d39a03f8145b955336f03e9427bb8cad630235e673d8806c5e8fdbcc65626b\n Stored in directory: /root/.cache/pip/wheels/b7/82/ef/3cb656a5fe084a0c96566ad2aeacdb730e592830ad76ada394\nSuccessfully built sqlalchemy-schemadisplay\nInstalling collected packages: sqlalchemy-schemadisplay\nSuccessfully installed sqlalchemy-schemadisplay-1.3\nRequirement already satisfied: graphviz in /usr/local/lib/python3.7/dist-packages (0.10.1)\n"}],"execution_count":null},{"cell_type":"markdown","source":"\nCreated in deepnote.com \nCreated in Deepnote","metadata":{"created_in_deepnote_cell":true,"deepnote_cell_type":"markdown"}}],"nbformat":4,"nbformat_minor":0,"metadata":{"colab":{"name":"Clase 2- Fundamentos de bases de datos.ipynb","provenance":[],"authorship_tag":"ABX9TyN7u5wKntZTpP4fBDmgegA4","collapsed_sections":[]},"deepnote":{},"kernelspec":{"name":"python3","display_name":"Python 3"},"language_info":{"name":"python"},"deepnote_notebook_id":"20a04cf559e44ddd9c9254f192119426","deepnote_execution_queue":[]}}