有點亂,本身平時,遇到了就記下來,因此沒整理。html
cu = cx.cursor() 這樣定義了一個遊標。遊標對象有如下的操做:python
3,查詢: cu.execute("select * from catalog") 要提取查詢到的數據,使用遊標的fetch***函數,如: print cu.fetchall() 返回結果以下: [(0, 0, u'name1'), (1, 0, u'hello')] 若是咱們使用cu.fetchone(),則首先返回列表中的第一項,再次使用,則返回第二項,依次下去.web
4,修改: cu.execute("update catalog set name='name2' where id = 0") sql
cx.commit() 注意,修改數據之後提交數據庫
5,刪除: cu.execute("delete from catalog where id = 1") cx.commit() 以上簡單的操做反應的Python SQLITE數據庫操做的基本要點,這裏點到爲止.而後,SQLite的強大,並不只限於此,其對SQL高級特性的支持及其小巧靈活的特色,使得 SQLite在衆多領域受到開發者的青睞.編程
一 添加表頭後端
//準備數據模型 QStandardItemModel *student_model = new QStandardItemModel(); student_model->setHorizontalHeaderItem(0, new QStandardItem(QObject::tr("Name"))); student_model->setHorizontalHeaderItem(1, new QStandardItem(QObject::tr("NO."))); student_model->setHorizontalHeaderItem(2, new QStandardItem(QObject::tr("Sex"))); student_model->setHorizontalHeaderItem(3, new QStandardItem(QObject::tr("Age"))); student_model->setHorizontalHeaderItem(4, new QStandardItem(QObject::tr("College"))); //利用setModel()方法將數據模型與QTableView綁定 ui->student_tableview->setModel(student_model);服務器
二 設置表格屬性數據結構
//設置列寬不可變更,即不能經過鼠標拖動增長列寬 ui->student_tableview->horizontalHeader()->setResizeMode(0, QHeaderView::Fixed); ui->student_tableview->horizontalHeader()->setResizeMode(1, QHeaderView::Fixed); ui->student_tableview->horizontalHeader()->setResizeMode(2, QHeaderView::Fixed); ui->student_tableview->horizontalHeader()->setResizeMode(3, QHeaderView::Fixed); ui->student_tableview->horizontalHeader()->setResizeMode(4, QHeaderView::Fixed); app
//設置表格的各列的寬度值 ui->student_tableview->setColumnWidth(0,100); ui->student_tableview->setColumnWidth(1,100); ui->student_tableview->setColumnWidth(2,100); ui->student_tableview->setColumnWidth(3,100); ui->student_tableview->setColumnWidth(4,100);
//默認顯示行頭,若是你以爲不美觀的話,咱們能夠將隱藏 ui->student_tableview->verticalHeader()->hide();
//設置選中時爲整行選中 ui->student_tableview->setSelectionBehavior(QAbstractItemView::SelectRows); //設置表格的單元爲只讀屬性,即不能編輯 ui->student_tableview->setEditTriggers(QAbstractItemView::NoEditTriggers);
//若是你用在QTableView中使用右鍵菜單,需啓用該屬性 ui->tstudent_tableview->setContextMenuPolicy(Qt::CustomContextMenu);
三 動態添加行
在表格中添加行時,咱們只須要在model中插入數據便可,一旦model中的數據發生變化,QTabelView顯示就會作相應的變更
//在第一行添加學生張三的我的信息(setItem函數的第一個參數表示行號,第二個表示列號,第三個爲要顯示的數據) student_model->setItem(0, 0, new QStandardItem(「張三")); student_model->setItem(0, 1, new QStandardItem("20120202")); student_model->setItem(0, 2, new QStandardItem("男")); student_model->setItem(0, 3, new QStandardItem("18")); student_model->setItem(0, 4, new QStandardItem("土木學院"));
四 設置數據顯示的樣式
//設置單元格文本居中,張三的數據設置爲居中顯示 student_model->item(0, 0)->setTextAlignment(Qt::AlignCenter); student_model->item(0, 1)->setTextAlignment(Qt::AlignCenter); student_model->item(0, 2)->setTextAlignment(Qt::AlignCenter); student_model->item(0, 3)->setTextAlignment(Qt::AlignCenter); student_model->item(0, 4)->setTextAlignment(Qt::AlignCenter);
//設置單元格文本顏色,張三的數據設置爲紅色 student_model->item(0, 0)->setForeground(QBrush(QColor(255, 0, 0))); student_model->item(0, 1)->setForeground(QBrush(QColor(255, 0, 0))); student_model->item(0, 2)->setForeground(QBrush(QColor(255, 0, 0))); student_model->item(0, 3)->setForeground(QBrush(QColor(255, 0, 0))); student_model->item(0, 4)->setForeground(QBrush(QColor(255, 0, 0)));
//將字體加粗 student_model->item(0, 0)->setFont( QFont( "Times", 10, QFont::Black ) ); student_model->item(0, 1)->setFont( QFont( "Times", 10, QFont::Black ) ); student_model->item(0, 2)->setFont( QFont( "Times", 10, QFont::Black ) ); student_model->item(0, 3)->setFont( QFont( "Times", 10, QFont::Black ) ); student_model->item(0, 4)->setFont( QFont( "Times", 10, QFont::Black ) );