Mysql KIVY, выберите обновление (!) И другие операции - PullRequest
0 голосов
/ 13 ноября 2018

Хорошо, я хочу обновить термин в своем приложении (я просто тестирую команды, интегрирующиеся в код kivy), и он ничего не делает с базой данных:

.py

import pymysql

from kivy.app import App

from kivy.uix.boxlayout import BoxLayout
from kivy.uix.recycleview.views import RecycleDataViewBehavior
from kivy.uix.button import Button
from kivy.properties import BooleanProperty, ListProperty, StringProperty, ObjectProperty
from kivy.uix.recyclegridlayout import RecycleGridLayout
from kivy.uix.behaviors import FocusBehavior
from kivy.uix.recycleview.layout import LayoutSelectionBehavior
from kivy.uix.popup import Popup

conn = pymysql.connect(host='127.0.0.1', port=3306, user='root', passwd='', db='python')

class TextInputPopup(Popup):
    obj = ObjectProperty(None)
    obj_text = StringProperty("")

    def __init__(self, obj, **kwargs):
        super(TextInputPopup, self).__init__(**kwargs)
        self.obj = obj
        self.obj_text = obj.text


class SelectableRecycleGridLayout(FocusBehavior, LayoutSelectionBehavior,
                                  RecycleGridLayout):
    ''' Adds selection and focus behaviour to the view. '''


class SelectableButton(RecycleDataViewBehavior, Button):
    ''' Add selection support to the Button '''
    index = None
    selected = BooleanProperty(False)
    selectable = BooleanProperty(True)

    def refresh_view_attrs(self, rv, index, data):
        ''' Catch and handle the view changes '''
        self.index = index
        return super(SelectableButton, self).refresh_view_attrs(rv, index, data)

    def on_touch_down(self, touch):
        ''' Add selection on touch down '''
        if super(SelectableButton, self).on_touch_down(touch):
            return True
        if self.collide_point(*touch.pos) and self.selectable:
            return self.parent.select_with_touch(self.index, touch)

    def apply_selection(self, rv, index, is_selected):
        ''' Respond to the selection of items in the view. '''
        self.selected = is_selected

    def on_press(self):
        popup = TextInputPopup(self)
        popup.open()

    def update_changes(self, txt):
        self.text = txt

    def att_users_NOME(self):
        cursor = conn.cursor()

        cursor.execute("UPDATE Users SET name_us = 'Rafael' WHERE id_us='2'")



class RV(BoxLayout):
    data_items = ListProperty([])

    def __init__(self, **kwargs):
        super(RV, self).__init__(**kwargs)
        self.get_users()

    def get_users(self):
        cursor = conn.cursor()

        cursor.execute("SELECT * FROM Users ORDER BY id_us ASC")
        rows = cursor.fetchall()

        # create data_items
        for row in rows:
            for col in row:
                self.data_items.append(col)



class TestApp(App):
    title = "Kivy RecycleView & SQLite3 Demo"

    def build(self):
        return RV()


if __name__ == "__main__":
    TestApp().run()

.kv

#:kivy 1.10.0

<TextInputPopup>:
title: "Popup"
size_hint: None, None
size: 400, 400
auto_dismiss: False

BoxLayout:
    orientation: "vertical"
    TextInput:
        id: txtinput
        text: root.obj_text
    Button:
        size_hint: 1, 0.2
        text: "Save Changes"
        on_release:
            root.obj.update_changes(txtinput.text)
            root.obj.att_users_NOME
            root.dismiss()
    Button:
        size_hint: 1, 0.2
        text: "Cancel Changes"
        on_release: root.dismiss()


<SelectableButton>:
# Draw a background to indicate selection
canvas.before:
    Color:
        rgba: (.0, 0.9, .1, .3) if self.selected else (0, 0, 0, 1)
    Rectangle:
        pos: self.pos
        size: self.size

<RV>:

BoxLayout:
    orientation: "vertical"

    GridLayout:
        size_hint: 1, None
        size_hint_y: None
        height: 25
        cols: 3

        Label:
            text: "User ID"
        Label:
            text: "User Name"
        Label:
            text: "OS"

    BoxLayout:
        RecycleView:
            viewclass: 'SelectableButton'
            data: [{'text': str(x)} for x in root.data_items]
            SelectableRecycleGridLayout:
                cols: 3
                default_size: None, dp(26)
                default_size_hint: 1, None
                size_hint_y: None
                height: self.minimum_height
                orientation: 'vertical'
                multiselect: True
                touch_multiselect: True

так что список отображается правильно ... и он получает данные из базы данных правильно, но это не обновление, смотрите, что я попробовал ту же команду в базе данных напрямую, и она сработала -> ОБНОВЛЕНИЕ пользователей SET name_us = 'Игорь' ГДЕ id_us = '3';

* кроме того, если кто-то знает, как использовать переменную для обновления или поиска в базе данных с помощью kivy, например, когда я изменяю приложение, оно также меняет имя в базе данных

...