使用占位符对数据库进行操作

本文通过一个具体的例子展示了如何在Android应用中使用SQLite进行基本的数据增删改操作。包括创建数据库、插入记录、更新记录和删除记录等功能,并提供了完整的代码实现。



 

 



 

在main.xml中:

 

<?xml version="1.0" encoding="utf-8"?>

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"

    android:layout_width="fill_parent"

    android:layout_height="fill_parent"

    android:orientation="vertical"

    android:gravity="center_horizontal">

 

    <Button

        android:id="@+id/insertBut"

        android:layout_marginTop="8dp"

        android:layout_width="wrap_content"

        android:layout_height="wrap_content"

        android:text="增加数据" />

    <Button

        android:id="@+id/updateBut"

        android:layout_width="wrap_content"

        android:layout_height="wrap_content"

        android:text="修改数据" />

    <Button

        android:id="@+id/deleteBut"

        android:layout_width="wrap_content"

        android:layout_height="wrap_content"

        android:text="删除数据" />

 

</LinearLayout>

 

 

 

 

 

创建数据库的建表操作类Mytab.java

 

package com.li.sqlite;

 

import android.database.sqlite.SQLiteDatabase;

 

public class Mytab {

  private static final String TABLENAME = "mytab"; // 表示要操作的数据表名称

  private SQLiteDatabase db = null; // 数据库操作

 

  public Mytab(SQLiteDatabase db) { 

     this.db = db;

  }

  public void insert(String name,String birthday) {  //向表中增加数据

     String sql = "INSERT INTO " + TABLENAME + "(name,birthday) VALUES (?,?)";

     Object args[] = new Object[]{name,birthday};

     this.db.execSQL(sql,args) ;

     this.db.close() ;

  }

 

  public void update(int id, String name, String birthday) {  //修改表的数据

     String sql = "UPDATE " + TABLENAME + " SET name=?,birthday=? WHERE id=?";

     Object args[] = new Object[]{name,birthday,id};

     this.db.execSQL(sql,args);

     this.db.close() ;

  }

 

  public void delete(int id) {     //删除表的数据

     String sql = "DELETE FROM " + TABLENAME + " WHERE id=?";

     Object args[] = new Object[]{id};

     this.db.execSQL(sql,args) ;

     this.db.close() ;

  }

}

 

 

 

 

在MySQLiteDemo.java中:

 

package com.li.sqlite;

 

import android.app.Activity;

import android.database.sqlite.SQLiteOpenHelper;

import android.os.Bundle;

import android.view.View;

import android.view.View.OnClickListener;

import android.widget.Button;

 

public class MySQLiteDemo extends Activity {

  private Button inserBut = null;

  private Button updateBut = null;

  private Button deleteBut = null;

  private SQLiteOpenHelper helper = null;

  private Mytab mtab = null;

  private static int count = 0;

  @Override

  public void onCreate(Bundle savedInstanceState) {

     super.onCreate(savedInstanceState);

     super.setContentView(R.layout.main);

     this.inserBut = (Button)super.findViewById(R.id.insertBut);

     this.updateBut = (Button)super.findViewById(R.id.updateBut);

     this.deleteBut = (Button)super.findViewById(R.id.deleteBut);

     this.helper = new MyDatabaseHelper(this);

     this.inserBut.setOnClickListener(new InertOnClickListenerImpl());

     this.updateBut.setOnClickListener(new UpdateOnClickListenerImpl());

     this.deleteBut.setOnClickListener(new DeleteOnClickListenerImpl());

  }

  private class InertOnClickListenerImpl implements OnClickListener{

     public void onClick(View v) {

       MySQLiteDemo.this.mtab = new Mytab(

            MySQLiteDemo.this.helper.getWritableDatabase());

       MySQLiteDemo.this.mtab.insert("liyewen" + count++, "1988-08-16");

     }

    

  }

  private class UpdateOnClickListenerImpl implements OnClickListener{

     public void onClick(View v) {

       MySQLiteDemo.this.mtab = new Mytab(

            MySQLiteDemo.this.helper.getWritableDatabase());

       MySQLiteDemo.this.mtab.update(30, "update", "1988/8/15");

     }

    

  }

  private class DeleteOnClickListenerImpl implements OnClickListener{

     public void onClick(View v) {

       MySQLiteDemo.this.mtab = new Mytab(

            MySQLiteDemo.this.helper.getWritableDatabase());

       MySQLiteDemo.this.mtab.delete(31);

     }

    

  }

}

 

使用 Qt 进行数据库操作时,插入数据时使用占位符是一种常见且推荐的做法,尤其适用于防止 SQL 注入攻击并提高代码的可读性和安全性。Qt 提供了 `QSqlQuery` 类,支持使用 `bindValue()` 方法绑定占位符参数,允许以乱序方式绑定参数[^1]。 ### 插入数据时使用占位符的示例 假设有一个名为 `users` 的表,包含 `id` 和 `name` 两个字段。可以通过以下方式使用占位符进行插入操作: ```cpp QSqlQuery query; query.prepare("INSERT INTO users (id, name) VALUES (:id, :name)"); // 使用命名占位符 query.bindValue(":id", 1); // 绑定 id 值 query.bindValue(":name", "John Doe"); // 绑定 name 值 if (!query.exec()) { qDebug() << "插入失败:" << query.lastError(); } ``` 在上面的代码中,`:id` 和 `:name` 是命名占位符,通过 `bindValue()` 方法将实际值绑定到这些占位符上。这种方式不仅提高了代码的可读性,还允许以任意顺序绑定参数。 ### 使用位置占位符 除了命名占位符,还可以使用位置占位符(如 `?`)进行插入操作: ```cpp QSqlQuery query; query.prepare("INSERT INTO users (id, name) VALUES (?, ?)"); query.bindValue(0, 2); // 绑定第一个参数 query.bindValue(1, "Jane Doe"); // 绑定第二个参数 if (!query.exec()) { qDebug() << "插入失败:" << query.lastError(); } ``` 在使用位置占位符时,参数的绑定顺序必须与 SQL 语句中的占位符顺序一致。 ### 查询数据时使用占位符 在执行查询操作时,也可以使用占位符来动态传入参数。例如: ```cpp QSqlQuery query; int id = 1; query.prepare("SELECT id, name FROM users WHERE id = ?"); query.bindValue(0, id); if (query.exec()) { while (query.next()) { int id_number = query.value(0).toInt(); QString name = query.value(1).toString(); qDebug() << "ID:" << id_number << "Name:" << name; } } else { qDebug() << "查询失败:" << query.lastError(); } ``` 在上面的代码中,使用了位置占位符 `?`,并通过 `bindValue()` 方法绑定参数,确保查询操作的安全性和灵活性[^3]。 ### 错误处理与调试 在进行数据库操作时,错误处理是必不可少的。可以通过 `QSqlQuery::exec()` 方法的返回值来判断操作是否成功,并使用 `QSqlQuery::lastError()` 方法获取错误信息: ```cpp if (!query.exec()) { qDebug() << "操作失败:" << query.lastError(); } ``` 此外,可以使用 `qDebug()` 输出调试信息,帮助定位问题所在。 ### 总结 在 Qt 中进行数据库操作时,使用占位符可以有效提高代码的安全性和可读性。无论是插入数据还是查询数据,都可以通过 `QSqlQuery` 类的 `prepare()` 和 `bindValue()` 方法实现灵活的参数绑定。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值