Android / MySQL: Spinner无法从MySQL中填充数据
创始人
2024-08-12 12:31:34
0

要在Android的Spinner中填充来自MySQL数据库的数据,您需要执行以下步骤:

  1. 在您的Android项目中添加MySQL连接库。您可以使用Volley或OkHttp等库来进行网络请求。

  2. 创建一个类来处理与MySQL数据库的连接和数据获取。这个类应该包括一个方法来执行数据库查询并返回结果。

    public class MySQLConnector {
        private static final String TAG = "MySQLConnector";
        private static final String URL = "http://your-mysql-api-url";
        
        public static void getDataFromMySQL(final Context context, final ArrayAdapter adapter) {
            // 创建一个请求队列
            RequestQueue queue = Volley.newRequestQueue(context);
            
            // 创建一个请求
            StringRequest request = new StringRequest(Request.Method.GET, URL,
                new Response.Listener() {
                    @Override
                    public void onResponse(String response) {
                        // 处理从MySQL获取到的数据
                        try {
                            JSONArray jsonArray = new JSONArray(response);
                            List data = new ArrayList<>();
                            for (int i = 0; i < jsonArray.length(); i++) {
                                JSONObject jsonObject = jsonArray.getJSONObject(i);
                                String item = jsonObject.getString("item");
                                data.add(item);
                            }
                            
                            // 将数据设置到适配器中
                            adapter.clear();
                            adapter.addAll(data);
                            adapter.notifyDataSetChanged();
                        } catch (JSONException e) {
                            e.printStackTrace();
                        }
                    }
                },
                new Response.ErrorListener() {
                    @Override
                    public void onErrorResponse(VolleyError error) {
                        Log.e(TAG, "Error: " + error.getMessage());
                    }
                });
                
            // 将请求添加到队列中
            queue.add(request);
        }
    }
    
  3. 在您的Activity或Fragment中,创建一个Spinner并使用上述MySQLConnector类来填充数据。您需要为Spinner创建一个适配器,并在适配器中设置数据。

    public class MainActivity extends AppCompatActivity {
        private Spinner spinner;
        private ArrayAdapter adapter;
        
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
            
            spinner = findViewById(R.id.spinner);
            
            // 创建适配器
            adapter = new ArrayAdapter<>(this, android.R.layout.simple_spinner_item);
            adapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
            
            // 设置适配器到Spinner
            spinner.setAdapter(adapter);
            
            // 从MySQL获取数据
            MySQLConnector.getDataFromMySQL(this, adapter);
        }
    }
    

通过上述步骤,您将能够从MySQL数据库中填充数据到Android的Spinner中。请确保更改URL变量为您自己的MySQL API URL,并在MySQL数据库中设置正确的数据结构。

相关内容

热门资讯

安卓换鸿蒙系统会卡吗,体验流畅... 最近手机圈可是热闹非凡呢!不少安卓用户都在议论纷纷,说鸿蒙系统要来啦!那么,安卓手机换上鸿蒙系统后,...
安卓系统拦截短信在哪,安卓系统... 你是不是也遇到了这种情况:手机里突然冒出了很多垃圾短信,烦不胜烦?别急,今天就来教你怎么在安卓系统里...
app安卓系统登录不了,解锁登... 最近是不是你也遇到了这样的烦恼:手机里那个心爱的APP,突然就登录不上了?别急,让我来帮你一步步排查...
安卓系统要维护多久,安卓系统维... 你有没有想过,你的安卓手机里那个陪伴你度过了无数日夜的安卓系统,它究竟要陪伴你多久呢?这个问题,估计...
windows官网系统多少钱 Windows官网系统价格一览:了解正版Windows的购买成本Windows 11官方价格解析微软...
安卓系统如何卸载app,轻松掌... 手机里的App越来越多,是不是感觉内存不够用了?别急,今天就来教你怎么轻松卸载安卓系统里的App,让...
怎么复制照片安卓系统,操作步骤... 亲爱的手机控们,是不是有时候想把自己的手机照片分享给朋友,或者备份到电脑上呢?别急,今天就来教你怎么...
安卓系统应用怎么重装,安卓应用... 手机里的安卓应用突然罢工了,是不是让你头疼不已?别急,今天就来手把手教你如何重装安卓系统应用,让你的...
iwatch怎么连接安卓系统,... 你有没有想过,那款时尚又实用的iWatch,竟然只能和iPhone好上好?别急,今天就来给你揭秘,怎...
iphone系统与安卓系统更新... 最近是不是你也遇到了这样的烦恼?手机更新系统总是失败,急得你团团转。别急,今天就来给你揭秘为什么iP...